@ -4,47 +4,40 @@ from PyInstaller.utils.hooks import collect_data_files, collect_submodules, coll
import sys, os
import sys, os
PYPKG="electrum"
MAIN_SCRIPT="run_electrum"
PROJECT_ROOT = "C:/electrum"
ICONS_FILE=f"{PROJECT_ROOT}/{PYPKG}/gui/icons/electrum.ico"
cmdline_name = os.environ.get("ELECTRUM_CMDLINE_NAME")
cmdline_name = os.environ.get("ELECTRUM_CMDLINE_NAME")
if not cmdline_name:
if not cmdline_name:
raise Exception('no name')
raise Exception('no name')
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(f"{PYPKG}.plugins")
hiddenimports += collect_submodules('safetlib')
hiddenimports += collect_submodules('btchip') # device plugin: ledger
hiddenimports += collect_submodules('ledger_bitcoin') # device plugin: ledger
hiddenimports += collect_submodules('keepkeylib')
hiddenimports += collect_submodules('websocket')
hiddenimports += collect_submodules('ckcc')
hiddenimports += collect_submodules('bitbox02')
hiddenimports += ['electrum.plugins.jade.jade']
hiddenimports += ['electrum.plugins.jade.jadepy.jade']
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]]
# add libsecp256k1, libusb, etc:
binaries += [(f"{PROJECT_ROOT}/{PYPKG}/*.dll", '.')]
binaries += [('C:/tmp/libsecp256k1-2.dll', '.')]
binaries += [('C:/tmp/libusb-1.0.dll', '.')]
binaries += [('C:/tmp/libzbar-0.dll', '.')]
datas = [
datas = [
(home+'electrum/*.json', 'electrum' ),
(f"{PROJECT_ROOT}/{PYPKG}/*.json", PYPKG),
(home+'electrum/lnwire/*.csv', 'electrum/lnwire' ),
(f"{PROJECT_ROOT}/{PYPKG}/lnwire/*.csv", f"{PYPKG}/lnwire" ),
(home+'electrum/wordlist/english.txt', 'electrum/wordlist' ),
(f"{PROJECT_ROOT}/{PYPKG}/wordlist/english.txt", f"{PYPKG}/wordlist" ),
(home+'electrum/wordlist/slip39.txt', 'electrum/wordlist' ),
(f"{PROJECT_ROOT}/{PYPKG}/wordlist/slip39.txt", f"{PYPKG}/wordlist" ),
(home+'electrum/locale', 'electrum/locale' ),
(f"{PROJECT_ROOT}/{PYPKG}/locale", f"{PYPKG}/locale" ),
(home+'electrum/plugins', 'electrum/plugins' ),
(f"{PROJECT_ROOT}/{PYPKG}/plugins", f"{PYPKG}/plugins" ),
(home+'electrum/gui/icons', 'electrum/gui/icons' ),
(f"{PROJECT_ROOT}/{PYPKG}/gui/icons", f"{PYPKG}/gui/icons" ),
]
]
datas += collect_data_files('trezorlib')
datas += collect_data_files(f"{PYPKG}.plugins")
datas += collect_data_files('trezorlib') # TODO is this needed? and same question for other hww libs
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')
@ -52,29 +45,19 @@ 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([f"{PROJECT_ROOT}/{MAIN_SCRIPT}",
home+'electrum/gui/qt/main_window.py',
f"{PROJECT_ROOT}/{PYPKG}/gui/qt/main_window.py",
home+'electrum/gui/qt/qrreader/qtmultimedia/camera_dialog.py',
f"{PROJECT_ROOT}/{PYPKG}/gui/qt/qrreader/qtmultimedia/camera_dialog.py",
home+'electrum/gui/text.py',
f"{PROJECT_ROOT}/{PYPKG}/gui/text.py",
home+'electrum/util.py',
f"{PROJECT_ROOT}/{PYPKG}/util.py",
home+'electrum/wallet.py',
f"{PROJECT_ROOT}/{PYPKG}/wallet.py",
home+'electrum/simple_config.py',
f"{PROJECT_ROOT}/{PYPKG}/simple_config.py",
home+'electrum/bitcoin.py',
f"{PROJECT_ROOT}/{PYPKG}/bitcoin.py",
home+'electrum/dnssec.py',
f"{PROJECT_ROOT}/{PYPKG}/dnssec.py",
home+'electrum/commands.py',
f"{PROJECT_ROOT}/{PYPKG}/commands.py",
home+'electrum/plugins/cosigner_pool/qt.py',
home+'electrum/plugins/trezor/qt.py',
home+'electrum/plugins/safe_t/client.py',
home+'electrum/plugins/safe_t/qt.py',
home+'electrum/plugins/keepkey/qt.py',
home+'electrum/plugins/ledger/qt.py',
home+'electrum/plugins/coldcard/qt.py',
home+'electrum/plugins/jade/qt.py',
#home+'packages/requests/utils.py'
],
],
binaries=binaries,
binaries=binaries,
datas=datas,
datas=datas,
#pathex=[home+'lib', home+'gui', home+'plugins'],
hiddenimports=hiddenimports,
hiddenimports=hiddenimports,
hookspath=[])
hookspath=[])
@ -125,11 +108,11 @@ exe_standalone = EXE(
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", PYPKG, f"{cmdline_name} .exe"),
debug=False,
debug=False,
strip=None,
strip=None,
upx=False,
upx=False,
icon=home+'electrum/gui/icons/electrum.ico' ,
icon=ICONS_FILE ,
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
@ -138,11 +121,11 @@ exe_portable = EXE(
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", PYPKG, f"{cmdline_name} -portable.exe"),
debug=False,
debug=False,
strip=None,
strip=None,
upx=False,
upx=False,
icon=home+'electrum/gui/icons/electrum.ico' ,
icon=ICONS_FILE ,
console=False)
console=False)
#####
#####
@ -152,22 +135,22 @@ 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", PYPKG, f"{cmdline_name}.exe" ),
debug=False,
debug=False,
strip=None,
strip=None,
upx=False,
upx=False,
icon=home+'electrum/gui/icons/electrum.ico' ,
icon=ICONS_FILE ,
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", PYPKG, f"{cmdline_name}-debug.exe "),
debug=False,
debug=False,
strip=None,
strip=None,
upx=False,
upx=False,
icon=home+'electrum/gui/icons/electrum.ico' ,
icon=ICONS_FILE ,
console=True)
console=True)
coll = COLLECT(
coll = COLLECT(
@ -179,6 +162,6 @@ coll = COLLECT(
strip=None,
strip=None,
upx=True,
upx=True,
debug=False,
debug=False,
icon=home+'electrum/gui/icons/electrum.ico' ,
icon=ICONS_FILE ,
console=False,
console=False,
name=os.path.join('dist', 'electrum' ))
name=os.path.join('dist', PYPKG ))