Mercurial > hg > orthanc-databases
annotate Resources/SyncOrthancFolder.py @ 405:1938ba8fba35
sync
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Sat, 15 Apr 2023 13:49:53 +0200 |
parents | f2e160b2dc3e |
children | de6de66d70b2 |
rev | line source |
---|---|
0 | 1 #!/usr/bin/python |
2 | |
3 # | |
4 # This maintenance script updates the content of the "Orthanc" folder | |
5 # to match the latest version of the Orthanc source code. | |
6 # | |
7 | |
8 import multiprocessing | |
9 import os | |
10 import stat | |
11 import urllib2 | |
12 | |
13 TARGET = os.path.join(os.path.dirname(__file__), 'Orthanc') | |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
14 PLUGIN_SDK_VERSION_OLD = [ '0.9.5', '1.4.0', '1.5.2', '1.5.4' ] |
405 | 15 PLUGIN_SDK_VERSION_NEW = [ '1.9.2', '1.12.0' ] |
16 HAS_PROTOCOL_BUFFERS = [ '1.12.0' ] | |
149 | 17 REPOSITORY = 'https://hg.orthanc-server.com/orthanc/raw-file' |
0 | 18 |
19 FILES = [ | |
285
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
20 ('default', 'OrthancFramework/Resources/CMake/AutoGeneratedCode.cmake', 'CMake'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
21 ('default', 'OrthancFramework/Resources/CMake/Compiler.cmake', 'CMake'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
22 ('default', 'OrthancFramework/Resources/CMake/DownloadOrthancFramework.cmake', 'CMake'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
23 ('default', 'OrthancFramework/Resources/CMake/DownloadPackage.cmake', 'CMake'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
24 ('default', 'OrthancFramework/Resources/CMake/GoogleTestConfiguration.cmake', 'CMake'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
25 ('default', 'OrthancFramework/Resources/EmbedResources.py', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
26 ('default', 'OrthancFramework/Resources/Toolchains/LinuxStandardBaseToolchain.cmake', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
27 ('default', 'OrthancFramework/Resources/Toolchains/MinGW-W64-Toolchain32.cmake', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
28 ('default', 'OrthancFramework/Resources/Toolchains/MinGW-W64-Toolchain64.cmake', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
29 ('default', 'OrthancFramework/Resources/Toolchains/MinGWToolchain.cmake', '.'), |
405 | 30 ('default', 'OrthancServer/Plugins/Samples/Common/ExportedSymbolsPlugins.list', 'Plugins'), |
31 ('default', 'OrthancServer/Plugins/Samples/Common/OrthancPluginCppWrapper.cpp', 'Plugins'), | |
32 ('default', 'OrthancServer/Plugins/Samples/Common/OrthancPluginCppWrapper.h', 'Plugins'), | |
33 ('default', 'OrthancServer/Plugins/Samples/Common/OrthancPluginException.h', 'Plugins'), | |
34 ('default', 'OrthancServer/Plugins/Samples/Common/OrthancPluginsExports.cmake', 'Plugins'), | |
35 ('default', 'OrthancServer/Plugins/Samples/Common/VersionScriptPlugins.map', 'Plugins'), | |
36 ('default', 'OrthancServer/Sources/Search/DatabaseConstraint.cpp', 'Databases'), | |
37 ('default', 'OrthancServer/Sources/Search/DatabaseConstraint.h', 'Databases'), | |
38 ('default', 'OrthancServer/Sources/Search/ISqlLookupFormatter.cpp', 'Databases'), | |
39 ('default', 'OrthancServer/Sources/Search/ISqlLookupFormatter.h', 'Databases'), | |
0 | 40 ] |
41 | |
42 SDK = [ | |
43 'orthanc/OrthancCPlugin.h', | |
44 'orthanc/OrthancCDatabasePlugin.h', | |
45 ] | |
46 | |
405 | 47 SDK_PROTOCOL_BUFFERS = [ |
48 'orthanc/OrthancCPlugin.h', | |
49 'orthanc/OrthancCDatabasePlugin.h', | |
50 'orthanc/OrthancDatabasePlugin.proto', | |
51 ] | |
52 | |
0 | 53 |
54 def Download(x): | |
55 branch = x[0] | |
56 source = x[1] | |
57 target = os.path.join(TARGET, x[2]) | |
58 print target | |
59 | |
60 try: | |
61 os.makedirs(os.path.dirname(target)) | |
62 except: | |
63 pass | |
64 | |
65 url = '%s/%s/%s' % (REPOSITORY, branch, source) | |
66 | |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
67 try: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
68 with open(target, 'w') as f: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
69 f.write(urllib2.urlopen(url).read()) |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
70 except Exception as e: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
71 raise Exception('Cannot download: %s' % url) |
0 | 72 |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
73 |
0 | 74 commands = [] |
75 | |
76 for f in FILES: | |
285
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
77 commands.append([ f[0], # Branch |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
78 f[1], # Source file |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
79 os.path.join(f[2], os.path.basename(f[1])) ]) |
0 | 80 |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
81 for version in PLUGIN_SDK_VERSION_OLD: |
28
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
82 for f in SDK: |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
83 commands.append([ |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
84 'Orthanc-%s' % version, |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
85 'Plugins/Include/%s' % f, |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
86 'Sdk-%s/%s' % (version, f) |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
87 ]) |
0 | 88 |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
89 for version in PLUGIN_SDK_VERSION_NEW: |
405 | 90 if version in HAS_PROTOCOL_BUFFERS: |
91 files = SDK_PROTOCOL_BUFFERS | |
92 else: | |
93 files = SDK | |
94 | |
95 for f in files: | |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
96 commands.append([ |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
97 'Orthanc-%s' % version, |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
98 'OrthancServer/Plugins/Include/%s' % f, |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
99 'Sdk-%s/%s' % (version, f) |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
100 ]) |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
101 |
0 | 102 |
103 pool = multiprocessing.Pool(10) # simultaneous downloads | |
104 pool.map(Download, commands) |