Mercurial > hg > orthanc-databases
annotate Resources/SyncOrthancFolder.py @ 358:1280b40d6696
switch to OpenSSL 3.0.x
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Mon, 21 Feb 2022 09:27:40 +0100 |
parents | f2e160b2dc3e |
children | c4f0f8087564 1938ba8fba35 |
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' ] |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
15 PLUGIN_SDK_VERSION_NEW = [ '1.9.2' ] |
149 | 16 REPOSITORY = 'https://hg.orthanc-server.com/orthanc/raw-file' |
0 | 17 |
18 FILES = [ | |
285
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
19 ('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
|
20 ('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
|
21 ('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
|
22 ('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
|
23 ('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
|
24 ('default', 'OrthancFramework/Resources/EmbedResources.py', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
25 ('default', 'OrthancFramework/Resources/Toolchains/LinuxStandardBaseToolchain.cmake', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
26 ('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
|
27 ('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
|
28 ('default', 'OrthancFramework/Resources/Toolchains/MinGWToolchain.cmake', '.'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
29 |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
30 # TODO - Replace branch "openssl-3.x" by "default" once it is reintegrated into mainline |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
31 ('openssl-3.x', 'OrthancServer/Plugins/Samples/Common/ExportedSymbolsPlugins.list', 'Plugins'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
32 ('openssl-3.x', 'OrthancServer/Plugins/Samples/Common/OrthancPluginCppWrapper.cpp', 'Plugins'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
33 ('openssl-3.x', 'OrthancServer/Plugins/Samples/Common/OrthancPluginCppWrapper.h', 'Plugins'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
34 ('openssl-3.x', 'OrthancServer/Plugins/Samples/Common/OrthancPluginException.h', 'Plugins'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
35 ('openssl-3.x', 'OrthancServer/Plugins/Samples/Common/OrthancPluginsExports.cmake', 'Plugins'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
36 ('openssl-3.x', 'OrthancServer/Plugins/Samples/Common/VersionScriptPlugins.map', 'Plugins'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
37 ('openssl-3.x', 'OrthancServer/Sources/Search/DatabaseConstraint.cpp', 'Databases'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
38 ('openssl-3.x', 'OrthancServer/Sources/Search/DatabaseConstraint.h', 'Databases'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
39 ('openssl-3.x', 'OrthancServer/Sources/Search/ISqlLookupFormatter.cpp', 'Databases'), |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
40 ('openssl-3.x', 'OrthancServer/Sources/Search/ISqlLookupFormatter.h', 'Databases'), |
0 | 41 ] |
42 | |
43 SDK = [ | |
44 'orthanc/OrthancCPlugin.h', | |
45 'orthanc/OrthancCDatabasePlugin.h', | |
46 ] | |
47 | |
48 | |
49 def Download(x): | |
50 branch = x[0] | |
51 source = x[1] | |
52 target = os.path.join(TARGET, x[2]) | |
53 print target | |
54 | |
55 try: | |
56 os.makedirs(os.path.dirname(target)) | |
57 except: | |
58 pass | |
59 | |
60 url = '%s/%s/%s' % (REPOSITORY, branch, source) | |
61 | |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
62 try: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
63 with open(target, 'w') as f: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
64 f.write(urllib2.urlopen(url).read()) |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
65 except Exception as e: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
66 raise Exception('Cannot download: %s' % url) |
0 | 67 |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
68 |
0 | 69 commands = [] |
70 | |
71 for f in FILES: | |
285
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
72 commands.append([ f[0], # Branch |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
73 f[1], # Source file |
f2e160b2dc3e
use openssl-3.x branch while syncing
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
272
diff
changeset
|
74 os.path.join(f[2], os.path.basename(f[1])) ]) |
0 | 75 |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
76 for version in PLUGIN_SDK_VERSION_OLD: |
28
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
77 for f in SDK: |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
78 commands.append([ |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
79 'Orthanc-%s' % version, |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
80 'Plugins/Include/%s' % f, |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
81 'Sdk-%s/%s' % (version, f) |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
82 ]) |
0 | 83 |
272
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
84 for version in PLUGIN_SDK_VERSION_NEW: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
85 for f in SDK: |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
86 commands.append([ |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
87 'Orthanc-%s' % version, |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
88 'OrthancServer/Plugins/Include/%s' % f, |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
89 'Sdk-%s/%s' % (version, f) |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
90 ]) |
c7dc70a0a477
upgrade to Orthanc SDK 1.9.2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
155
diff
changeset
|
91 |
0 | 92 |
93 pool = multiprocessing.Pool(10) # simultaneous downloads | |
94 pool.map(Download, commands) |