PyInstaller package: use OPENSSL_DIR and bitmsghash.pyd if no dll

This commit is contained in:
Dmitri Bogomolov 2020-10-20 17:21:03 +03:00
parent 02b2bfdfd0
commit f3e2771bc2
Signed by untrusted user: g1itch
GPG Key ID: 720A756F18DEED13

View File

@ -11,7 +11,7 @@ arch = 32 if ctypes.sizeof(ctypes.c_voidp) == 4 else 64
cdrivePath = site_root[0:3] cdrivePath = site_root[0:3]
srcPath = os.path.join(spec_root[:-20], "src") srcPath = os.path.join(spec_root[:-20], "src")
sslName = 'OpenSSL-Win%i' % arch sslName = 'OpenSSL-Win%i' % arch
openSSLPath = os.path.join(cdrivePath, sslName) openSSLPath = os.getenv('OPENSSL_DIR') or os.path.join(cdrivePath, sslName)
msvcrDllPath = os.path.join(cdrivePath, "windows", "system32") msvcrDllPath = os.path.join(cdrivePath, "windows", "system32")
outPath = os.path.join(spec_root, "bitmessagemain") outPath = os.path.join(spec_root, "bitmessagemain")
qtBase = "PyQt4" qtBase = "PyQt4"
@ -83,12 +83,19 @@ excluded_binaries = [
] ]
a.binaries = TOC([x for x in a.binaries if x[0] not in excluded_binaries]) a.binaries = TOC([x for x in a.binaries if x[0] not in excluded_binaries])
ext_lib = os.path.join('bitmsghash', 'bitmsghash%i.dll' % arch)
if os.path.isfile(ext_lib):
ext_lib = (ext_lib, os.path.join(srcPath, ext_lib), 'BINARY')
else:
ext_lib = (
os.path.join('bitmsghash', 'bitmsghash.pyd'),
os.path.join(srcPath, 'bitmsghash', 'bitmsghash.pyd'), 'EXTENSION')
a.binaries += [ a.binaries += [
# No effect: libeay32.dll will be taken from PyQt if installed # No effect: libeay32.dll will be taken from PyQt if installed
('libeay32.dll', os.path.join(openSSLPath, 'libeay32.dll'), 'BINARY'), ('libeay32.dll', os.path.join(openSSLPath, 'libeay32.dll'), 'BINARY'),
(os.path.join('bitmsghash', 'bitmsghash%i.dll' % arch), ext_lib,
os.path.join(srcPath, 'bitmsghash', 'bitmsghash%i.dll' % arch),
'BINARY'),
(os.path.join('bitmsghash', 'bitmsghash.cl'), (os.path.join('bitmsghash', 'bitmsghash.cl'),
os.path.join(srcPath, 'bitmsghash', 'bitmsghash.cl'), 'BINARY'), os.path.join(srcPath, 'bitmsghash', 'bitmsghash.cl'), 'BINARY'),
(os.path.join('sslkeys', 'cert.pem'), (os.path.join('sslkeys', 'cert.pem'),