فهرست منبع

Fix windows deployment.

Antti Aalto 8 سال پیش
والد
کامیت
401155e909
1فایلهای تغییر یافته به همراه14 افزوده شده و 8 حذف شده
  1. 14 8
      deployment/windows/buildwin32.py

+ 14 - 8
deployment/windows/buildwin32.py

@@ -10,6 +10,8 @@ import zipfile
 
 builddir = 'win32exe'
 
+pythonversion = str(sys.version_info[0]) + '.' + str(sys.version_info[1])
+
 if os.path.exists(builddir):
     shutil.rmtree(builddir)
 os.mkdir(builddir)
@@ -30,7 +32,7 @@ if gccpath == '':
 source = open('wrapper.c', 'w')
 source.write(
 """
-#include <python3.5m/python.h>
+#include <python""" + pythonversion +"""m/python.h>
 #include <windows.h>
 #include <wchar.h>
 #include <string>
@@ -59,12 +61,12 @@ int wmain(int argc , wchar_t *argv[] )
 }
 """)
 source.close()
-subprocess.check_call('g++ wrapper.c -lpython3.5m -lshlwapi -municode -o ' + builddir + '/borg.exe')
+subprocess.check_call('g++ wrapper.c -lpython' + pythonversion + 'm -lshlwapi -municode -o ' + builddir + '/borg.exe')
 os.remove('wrapper.c')
 
 print('Searching modules')
 
-modulepath = os.path.abspath(os.path.join(gccpath, '../lib/python3.5/'))
+modulepath = os.path.abspath(os.path.join(gccpath, '../lib/python' + pythonversion + '/'))
 
 # Bundle all encodings - In theory user may use any encoding in command prompt
 for file in os.listdir(os.path.join(modulepath, 'encodings')):
@@ -76,7 +78,8 @@ finder.run_script('src/borg/__main__.py')
 
 # For some reason modulefinder does not find these, add them manually
 extramodules = [os.path.join(modulepath, 'site.py'), os.path.join(modulepath, 'encodings/idna.py'),
-    os.path.join(modulepath, 'stringprep.py'), os.path.join(modulepath, 'ctypes/wintypes.py')]
+    os.path.join(modulepath, 'stringprep.py'), os.path.join(modulepath, 'ctypes/wintypes.py'),
+    os.path.join(modulepath, 'lib-dynload/_sysconfigdata_m_win32_.py')]
 
 for module in extramodules:
     finder.run_script(module)
@@ -113,7 +116,7 @@ for name, mod in items:
         os.makedirs(os.path.join(builddir, 'bin', os.path.split(relpath)[0]), exist_ok=True)
         shutil.copyfile(file, os.path.join(builddir, 'bin', relpath))
     else:
-        relativepath = file[file.find('lib')+len('lib/python3.5/'):]
+        relativepath = file[file.find('lib')+len('lib/python' + pythonversion + '/'):]
         if 'encodings' in file:
             continue
         if relativepath not in library.namelist():
@@ -130,10 +133,13 @@ for dll in finddlls(os.path.join(builddir, "borg.exe")):
         shutil.copyfile(dll, os.path.join(builddir, os.path.split(dll)[1]))
 
 shutil.copyfile(os.path.join('src', 'borg', '__main__.py'), os.path.join(builddir, 'bin', 'borg', '__main__.py'))
-library.write(os.path.join(modulepath, 'site.py'), 'site.py')
+library.write(os.path.join(modulepath, 'lib-dynload/_sysconfigdata_m_win32_.py'), '_sysconfigdata_m_win32_.py')
+library.write(os.path.join(modulepath, 'ctypes/wintypes.py'), 'ctypes/wintypes.py')
 
-for extmodule in ['src/borg/chunker-cpython-35m.dll', 'src/borg/compress-cpython-35m.dll',
-    'src/borg/crypto-cpython-35m.dll', 'src/borg/hashindex-cpython-35m.dll']:
+for extmodule in ['src/borg/chunker-cpython-' + str(sys.version_info[0]) + str(sys.version_info[1]) + 'm.dll',
+    'src/borg/compress-cpython-' + str(sys.version_info[0]) + str(sys.version_info[1]) + 'm.dll',
+    'src/borg/item-cpython-' + str(sys.version_info[0]) + str(sys.version_info[1]) + 'm.dll',
+    'src/borg/hashindex-cpython-' + str(sys.version_info[0]) + str(sys.version_info[1]) + 'm.dll']:
     for dll in finddlls(extmodule):
         if builddir not in dll:
             shutil.copyfile(dll, os.path.join(builddir, os.path.split(dll)[1]))