Mercurial > hg > orthanc-stone
view Resources/SyncOrthancFolder.py @ 1314:9b126de2cde2 broker
Since the observer system now uses shared_ptr and many registrations are
done in the constructors, and since we cannot called shared_from_this() in
the constructors, it is mandatory to split construction from registration.
This has been done by making many ctors protected and replacing them
by factory methods that directly return shared_ptrs + added PostConstructor
method when base classes perform shared_from_this() calls too.
author | Benjamin Golinvaux <bgo@osimis.io> |
---|---|
date | Mon, 16 Mar 2020 11:19:50 +0100 |
parents | 5412adf19980 |
children | 8e5f69c94fea |
line wrap: on
line source
#!/usr/bin/python # # This maintenance script updates the content of the "Orthanc" folder # to match the latest version of the Orthanc source code. # import multiprocessing import os import stat import urllib2 TARGET = os.path.join(os.path.dirname(__file__), 'Orthanc') REPOSITORY = 'https://bitbucket.org/sjodogne/orthanc/raw' FILES = [ 'DownloadOrthancFramework.cmake', 'LinuxStandardBaseToolchain.cmake', 'MinGW-W64-Toolchain32.cmake', 'MinGW-W64-Toolchain64.cmake', 'MinGWToolchain.cmake', ] def Download(x): branch = x[0] source = x[1] target = os.path.join(TARGET, x[2]) print target try: os.makedirs(os.path.dirname(target)) except: pass url = '%s/%s/%s' % (REPOSITORY, branch, source) with open(target, 'w') as f: f.write(urllib2.urlopen(url).read()) commands = [] for f in FILES: commands.append([ 'default', os.path.join('Resources', f), f ]) pool = multiprocessing.Pool(10) # simultaneous downloads pool.map(Download, commands)