1 changed files with 185 additions and 185 deletions
@ -1,185 +1,185 @@ |
|||||||
# -*- mode: python -*- |
# -*- mode: python -*- |
||||||
|
|
||||||
from PyInstaller.utils.hooks import collect_data_files, collect_submodules, collect_dynamic_libs |
from PyInstaller.utils.hooks import collect_data_files, collect_submodules, collect_dynamic_libs |
||||||
|
|
||||||
import sys |
import sys |
||||||
for i, x in enumerate(sys.argv): |
for i, x in enumerate(sys.argv): |
||||||
if x == '--name': |
if x == '--name': |
||||||
cmdline_name = sys.argv[i+1] |
cmdline_name = sys.argv[i+1] |
||||||
break |
break |
||||||
else: |
else: |
||||||
raise Exception('no name') |
raise Exception('no name') |
||||||
|
|
||||||
home = 'C:\\electrum\\' |
home = 'C:\\electrum\\' |
||||||
|
|
||||||
# see https://github.com/pyinstaller/pyinstaller/issues/2005 |
# see https://github.com/pyinstaller/pyinstaller/issues/2005 |
||||||
hiddenimports = [] |
hiddenimports = [] |
||||||
hiddenimports += collect_submodules('pkg_resources') # workaround for https://github.com/pypa/setuptools/issues/1963 |
hiddenimports += collect_submodules('pkg_resources') # workaround for https://github.com/pypa/setuptools/issues/1963 |
||||||
hiddenimports += collect_submodules('trezorlib') |
hiddenimports += collect_submodules('trezorlib') |
||||||
hiddenimports += collect_submodules('safetlib') |
hiddenimports += collect_submodules('safetlib') |
||||||
hiddenimports += collect_submodules('btchip') |
hiddenimports += collect_submodules('btchip') |
||||||
hiddenimports += collect_submodules('keepkeylib') |
hiddenimports += collect_submodules('keepkeylib') |
||||||
hiddenimports += collect_submodules('websocket') |
hiddenimports += collect_submodules('websocket') |
||||||
hiddenimports += collect_submodules('ckcc') |
hiddenimports += collect_submodules('ckcc') |
||||||
hiddenimports += collect_submodules('bitbox02') |
hiddenimports += collect_submodules('bitbox02') |
||||||
hiddenimports += ['electrum.plugins.jade.jade'] |
hiddenimports += ['electrum.plugins.jade.jade'] |
||||||
hiddenimports += ['electrum.plugins.jade.jadepy.jade'] |
hiddenimports += ['electrum.plugins.jade.jadepy.jade'] |
||||||
hiddenimports += ['PyQt5.QtPrintSupport'] # needed by Revealer |
hiddenimports += ['PyQt5.QtPrintSupport'] # needed by Revealer |
||||||
|
|
||||||
|
|
||||||
binaries = [] |
binaries = [] |
||||||
|
|
||||||
# Workaround for "Retro Look": |
# Workaround for "Retro Look": |
||||||
binaries += [b for b in collect_dynamic_libs('PyQt5') if 'qwindowsvista' in b[0]] |
binaries += [b for b in collect_dynamic_libs('PyQt5') if 'qwindowsvista' in b[0]] |
||||||
|
|
||||||
binaries += [('C:/tmp/libsecp256k1-0.dll', '.')] |
binaries += [('C:/tmp/libsecp256k1-0.dll', '.')] |
||||||
binaries += [('C:/tmp/libusb-1.0.dll', '.')] |
binaries += [('C:/tmp/libusb-1.0.dll', '.')] |
||||||
binaries += [('C:/tmp/libzbar-0.dll', '.')] |
binaries += [('C:/tmp/libzbar-0.dll', '.')] |
||||||
|
|
||||||
datas = [ |
datas = [ |
||||||
(home+'electrum/*.json', 'electrum'), |
(home+'electrum/*.json', 'electrum'), |
||||||
(home+'electrum/lnwire/*.csv', 'electrum/lnwire'), |
(home+'electrum/lnwire/*.csv', 'electrum/lnwire'), |
||||||
(home+'electrum/wordlist/english.txt', 'electrum/wordlist'), |
(home+'electrum/wordlist/english.txt', 'electrum/wordlist'), |
||||||
(home+'electrum/wordlist/slip39.txt', 'electrum/wordlist'), |
(home+'electrum/wordlist/slip39.txt', 'electrum/wordlist'), |
||||||
(home+'electrum/locale', 'electrum/locale'), |
(home+'electrum/locale', 'electrum/locale'), |
||||||
(home+'electrum/plugins', 'electrum/plugins'), |
(home+'electrum/plugins', 'electrum/plugins'), |
||||||
(home+'electrum/gui/icons', 'electrum/gui/icons'), |
(home+'electrum/gui/icons', 'electrum/gui/icons'), |
||||||
] |
] |
||||||
datas += collect_data_files('trezorlib') |
datas += collect_data_files('trezorlib') |
||||||
datas += collect_data_files('safetlib') |
datas += collect_data_files('safetlib') |
||||||
datas += collect_data_files('btchip') |
datas += collect_data_files('btchip') |
||||||
datas += collect_data_files('keepkeylib') |
datas += collect_data_files('keepkeylib') |
||||||
datas += collect_data_files('ckcc') |
datas += collect_data_files('ckcc') |
||||||
datas += collect_data_files('bitbox02') |
datas += collect_data_files('bitbox02') |
||||||
|
|
||||||
# We don't put these files in to actually include them in the script but to make the Analysis method scan them for imports |
# We don't put these files in to actually include them in the script but to make the Analysis method scan them for imports |
||||||
a = Analysis([home+'run_electrum', |
a = Analysis([home+'run_electrum', |
||||||
home+'electrum/gui/qt/main_window.py', |
home+'electrum/gui/qt/main_window.py', |
||||||
home+'electrum/gui/qt/qrreader/qtmultimedia/camera_dialog.py', |
home+'electrum/gui/qt/qrreader/qtmultimedia/camera_dialog.py', |
||||||
home+'electrum/gui/text.py', |
home+'electrum/gui/text.py', |
||||||
home+'electrum/util.py', |
home+'electrum/util.py', |
||||||
home+'electrum/wallet.py', |
home+'electrum/wallet.py', |
||||||
home+'electrum/simple_config.py', |
home+'electrum/simple_config.py', |
||||||
home+'electrum/bitcoin.py', |
home+'electrum/bitcoin.py', |
||||||
home+'electrum/dnssec.py', |
home+'electrum/dnssec.py', |
||||||
home+'electrum/commands.py', |
home+'electrum/commands.py', |
||||||
home+'electrum/plugins/cosigner_pool/qt.py', |
home+'electrum/plugins/cosigner_pool/qt.py', |
||||||
home+'electrum/plugins/trezor/qt.py', |
home+'electrum/plugins/trezor/qt.py', |
||||||
home+'electrum/plugins/safe_t/client.py', |
home+'electrum/plugins/safe_t/client.py', |
||||||
home+'electrum/plugins/safe_t/qt.py', |
home+'electrum/plugins/safe_t/qt.py', |
||||||
home+'electrum/plugins/keepkey/qt.py', |
home+'electrum/plugins/keepkey/qt.py', |
||||||
home+'electrum/plugins/ledger/qt.py', |
home+'electrum/plugins/ledger/qt.py', |
||||||
home+'electrum/plugins/coldcard/qt.py', |
home+'electrum/plugins/coldcard/qt.py', |
||||||
home+'electrum/plugins/jade/qt.py', |
home+'electrum/plugins/jade/qt.py', |
||||||
#home+'packages/requests/utils.py' |
#home+'packages/requests/utils.py' |
||||||
], |
], |
||||||
binaries=binaries, |
binaries=binaries, |
||||||
datas=datas, |
datas=datas, |
||||||
#pathex=[home+'lib', home+'gui', home+'plugins'], |
#pathex=[home+'lib', home+'gui', home+'plugins'], |
||||||
hiddenimports=hiddenimports, |
hiddenimports=hiddenimports, |
||||||
hookspath=[]) |
hookspath=[]) |
||||||
|
|
||||||
|
|
||||||
# http://stackoverflow.com/questions/19055089/pyinstaller-onefile-warning-pyconfig-h-when-importing-scipy-or-scipy-signal |
# http://stackoverflow.com/questions/19055089/pyinstaller-onefile-warning-pyconfig-h-when-importing-scipy-or-scipy-signal |
||||||
for d in a.datas: |
for d in a.datas: |
||||||
if 'pyconfig' in d[0]: |
if 'pyconfig' in d[0]: |
||||||
a.datas.remove(d) |
a.datas.remove(d) |
||||||
break |
break |
||||||
|
|
||||||
# Strip out parts of Qt that we never use. Reduces binary size by tens of MBs. see #4815 |
# Strip out parts of Qt that we never use. Reduces binary size by tens of MBs. see #4815 |
||||||
qt_bins2remove=('qt5web', 'qt53d', 'qt5game', 'qt5designer', 'qt5quick', |
qt_bins2remove=('qt5web', 'qt53d', 'qt5game', 'qt5designer', 'qt5quick', |
||||||
'qt5location', 'qt5test', 'qt5xml', r'pyqt5\qt\qml\qtquick') |
'qt5location', 'qt5test', 'qt5xml', r'pyqt5\qt\qml\qtquick') |
||||||
print("Removing Qt binaries:", *qt_bins2remove) |
print("Removing Qt binaries:", *qt_bins2remove) |
||||||
for x in a.binaries.copy(): |
for x in a.binaries.copy(): |
||||||
for r in qt_bins2remove: |
for r in qt_bins2remove: |
||||||
if x[0].lower().startswith(r): |
if x[0].lower().startswith(r): |
||||||
a.binaries.remove(x) |
a.binaries.remove(x) |
||||||
print('----> Removed x =', x) |
print('----> Removed x =', x) |
||||||
|
|
||||||
qt_data2remove=(r'pyqt5\qt\translations\qtwebengine_locales',) |
qt_data2remove=(r'pyqt5\qt\translations\qtwebengine_locales',) |
||||||
print("Removing Qt datas:", *qt_data2remove) |
print("Removing Qt datas:", *qt_data2remove) |
||||||
for x in a.datas.copy(): |
for x in a.datas.copy(): |
||||||
for r in qt_data2remove: |
for r in qt_data2remove: |
||||||
if x[0].lower().startswith(r): |
if x[0].lower().startswith(r): |
||||||
a.datas.remove(x) |
a.datas.remove(x) |
||||||
print('----> Removed x =', x) |
print('----> Removed x =', x) |
||||||
|
|
||||||
# not reproducible (see #7739): |
# not reproducible (see #7739): |
||||||
print("Removing *.dist-info/ from datas:") |
print("Removing *.dist-info/ from datas:") |
||||||
for x in a.datas.copy(): |
for x in a.datas.copy(): |
||||||
if ".dist-info\\" in x[0].lower(): |
if ".dist-info\\" in x[0].lower(): |
||||||
a.datas.remove(x) |
a.datas.remove(x) |
||||||
print('----> Removed x =', x) |
print('----> Removed x =', x) |
||||||
|
|
||||||
|
|
||||||
# hotfix for #3171 (pre-Win10 binaries) |
# hotfix for #3171 (pre-Win10 binaries) |
||||||
a.binaries = [x for x in a.binaries if not x[1].lower().startswith(r'c:\windows')] |
a.binaries = [x for x in a.binaries if not x[1].lower().startswith(r'c:\windows')] |
||||||
|
|
||||||
pyz = PYZ(a.pure) |
pyz = PYZ(a.pure) |
||||||
|
|
||||||
|
|
||||||
##### |
##### |
||||||
# "standalone" exe with all dependencies packed into it |
# "standalone" exe with all dependencies packed into it |
||||||
|
|
||||||
exe_standalone = EXE( |
exe_standalone = EXE( |
||||||
pyz, |
pyz, |
||||||
a.scripts, |
a.scripts, |
||||||
a.binaries, |
a.binaries, |
||||||
a.datas, |
a.datas, |
||||||
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name + ".exe"), |
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name + ".exe"), |
||||||
debug=False, |
debug=False, |
||||||
strip=None, |
strip=None, |
||||||
upx=False, |
upx=False, |
||||||
icon=home+'electrum/gui/icons/electrum.ico', |
icon=home+'electrum/gui/icons/electrum.ico', |
||||||
console=False) |
console=False) |
||||||
# console=True makes an annoying black box pop up, but it does make Electrum output command line commands, with this turned off no output will be given but commands can still be used |
# console=True makes an annoying black box pop up, but it does make Electrum output command line commands, with this turned off no output will be given but commands can still be used |
||||||
|
|
||||||
exe_portable = EXE( |
exe_portable = EXE( |
||||||
pyz, |
pyz, |
||||||
a.scripts, |
a.scripts, |
||||||
a.binaries, |
a.binaries, |
||||||
a.datas + [('is_portable', 'README.md', 'DATA')], |
a.datas + [('is_portable', 'README.md', 'DATA')], |
||||||
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name + "-portable.exe"), |
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name + "-portable.exe"), |
||||||
debug=False, |
debug=False, |
||||||
strip=None, |
strip=None, |
||||||
upx=False, |
upx=False, |
||||||
icon=home+'electrum/gui/icons/electrum.ico', |
icon=home+'electrum/gui/icons/electrum.ico', |
||||||
console=False) |
console=False) |
||||||
|
|
||||||
##### |
##### |
||||||
# exe and separate files that NSIS uses to build installer "setup" exe |
# exe and separate files that NSIS uses to build installer "setup" exe |
||||||
|
|
||||||
exe_inside_setup_noconsole = EXE( |
exe_inside_setup_noconsole = EXE( |
||||||
pyz, |
pyz, |
||||||
a.scripts, |
a.scripts, |
||||||
exclude_binaries=True, |
exclude_binaries=True, |
||||||
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name), |
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name), |
||||||
debug=False, |
debug=False, |
||||||
strip=None, |
strip=None, |
||||||
upx=False, |
upx=False, |
||||||
icon=home+'electrum/gui/icons/electrum.ico', |
icon=home+'electrum/gui/icons/electrum.ico', |
||||||
console=False) |
console=False) |
||||||
|
|
||||||
exe_inside_setup_console = EXE( |
exe_inside_setup_console = EXE( |
||||||
pyz, |
pyz, |
||||||
a.scripts, |
a.scripts, |
||||||
exclude_binaries=True, |
exclude_binaries=True, |
||||||
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name+"-debug"), |
name=os.path.join('build\\pyi.win32\\electrum', cmdline_name+"-debug"), |
||||||
debug=False, |
debug=False, |
||||||
strip=None, |
strip=None, |
||||||
upx=False, |
upx=False, |
||||||
icon=home+'electrum/gui/icons/electrum.ico', |
icon=home+'electrum/gui/icons/electrum.ico', |
||||||
console=True) |
console=True) |
||||||
|
|
||||||
coll = COLLECT( |
coll = COLLECT( |
||||||
exe_inside_setup_noconsole, |
exe_inside_setup_noconsole, |
||||||
exe_inside_setup_console, |
exe_inside_setup_console, |
||||||
a.binaries, |
a.binaries, |
||||||
a.zipfiles, |
a.zipfiles, |
||||||
a.datas, |
a.datas, |
||||||
strip=None, |
strip=None, |
||||||
upx=True, |
upx=True, |
||||||
debug=False, |
debug=False, |
||||||
icon=home+'electrum/gui/icons/electrum.ico', |
icon=home+'electrum/gui/icons/electrum.ico', |
||||||
console=False, |
console=False, |
||||||
name=os.path.join('dist', 'electrum')) |
name=os.path.join('dist', 'electrum')) |
||||||
|
|||||||
Loading…
Reference in new issue