tuse pyinstaller for OSX builds - electrum - Electrum Bitcoin wallet HTML git clone https://git.parazyd.org/electrum DIR Log DIR Files DIR Refs DIR Submodules --- DIR commit f7200cb6162ba30f4ebd0e94d933f7b7d559cdb2 DIR parent 5665b4299972e923c8d148c72b6033fa86e65eac HTML Author: ThomasV <thomasv@electrum.org> Date: Tue, 24 Oct 2017 22:52:53 +0200 use pyinstaller for OSX builds Diffstat: M contrib/make_osx | 3 ++- A contrib/osx.spec | 69 ++++++++++++++++++++++++++++++ M electrum | 6 +----- D setup-release.py | 89 ------------------------------- 4 files changed, 72 insertions(+), 95 deletions(-) --- DIR diff --git a/contrib/make_osx b/contrib/make_osx t@@ -1,6 +1,7 @@ #!/bin/bash rm -rf dist +export PYTHONHASHSEED=22 VERSION=`git describe --tags` -python3 setup-release.py py2app +pyinstaller --noconfirm --ascii contrib/osx.spec hdiutil create -fs HFS+ -volname "Electrum" -srcfolder dist/Electrum.app dist/electrum-$VERSION.dmg DIR diff --git a/contrib/osx.spec b/contrib/osx.spec t@@ -0,0 +1,69 @@ +# -*- mode: python -*- + +from PyInstaller.utils.hooks import collect_data_files, collect_submodules + +home = '/Users/voegtlin/electrum/' +block_cipher=None + +# see https://github.com/pyinstaller/pyinstaller/issues/2005 +hiddenimports = [] +hiddenimports += collect_submodules('trezorlib') +hiddenimports += collect_submodules('btchip') +hiddenimports += collect_submodules('keepkeylib') + +datas = [ + (home+'lib/currencies.json', 'electrum'), + (home+'lib/servers.json', 'electrum'), + (home+'lib/wordlist/english.txt', 'electrum/wordlist'), + (home+'lib/locale', 'electrum/locale'), + (home+'plugins', 'electrum_plugins'), +] +datas += collect_data_files('trezorlib') +datas += collect_data_files('btchip') +datas += collect_data_files('keepkeylib') + +# 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+'electrum', + home+'gui/qt/main_window.py', + home+'gui/text.py', + home+'lib/util.py', + home+'lib/wallet.py', + home+'lib/simple_config.py', + home+'lib/bitcoin.py', + home+'lib/dnssec.py', + home+'lib/commands.py', + home+'plugins/cosigner_pool/qt.py', + home+'plugins/email_requests/qt.py', + home+'plugins/trezor/client.py', + home+'plugins/trezor/qt.py', + home+'plugins/keepkey/qt.py', + home+'plugins/ledger/qt.py', + ], + datas=datas, + hiddenimports=hiddenimports, + hookspath=[]) + +# http://stackoverflow.com/questions/19055089/pyinstaller-onefile-warning-pyconfig-h-when-importing-scipy-or-scipy-signal +for d in a.datas: + if 'pyconfig' in d[0]: + a.datas.remove(d) + break + +pyz = PYZ(a.pure, a.zipped_data, cipher=block_cipher) + +exe = EXE(pyz, + a.scripts, + a.binaries, + a.datas, + name='Electrum', + debug=False, + strip=False, + upx=True, + icon=home+'electrum.icns', + console=False) + +app = BUNDLE(exe, + name='Electrum.app', + icon=home+'electrum.icns', + bundle_identifier=None) + DIR diff --git a/electrum b/electrum t@@ -43,7 +43,7 @@ if jnius: script_dir = os.path.dirname(os.path.realpath(__file__)) is_bundle = getattr(sys, 'frozen', False) -is_local = not is_bundle and os.path.exists(os.path.join(script_dir, "setup-release.py")) +is_local = not is_bundle and os.path.exists(os.path.join(script_dir, "electrum.desktop")) is_android = 'ANDROID_DATA' in os.environ # move this back to gui/kivy/__init.py once plugins are moved t@@ -51,8 +51,6 @@ os.environ['KIVY_DATA_DIR'] = os.path.abspath(os.path.dirname(__file__)) + '/gui if is_local or is_android: sys.path.insert(0, os.path.join(script_dir, 'packages')) -elif is_bundle and sys.platform=='darwin': - is_local = True def check_imports(): t@@ -75,8 +73,6 @@ def check_imports(): from google.protobuf import descriptor_pb2 from jsonrpclib import SimpleJSONRPCServer # make sure that certificates are here - if is_bundle and sys.platform=='darwin': - requests.utils.DEFAULT_CA_BUNDLE_PATH = os.path.join(os.path.dirname(__file__), 'cacert.pem') assert os.path.exists(requests.utils.DEFAULT_CA_BUNDLE_PATH) DIR diff --git a/setup-release.py b/setup-release.py t@@ -1,89 +0,0 @@ -""" -py2app/py2exe build script for Electrum - -Usage (Mac OS X): - python setup.py py2app - -Usage (Windows): - python setup.py py2exe -""" - -from setuptools import setup -import os -import re -import shutil -import sys - -from lib.version import ELECTRUM_VERSION as version - - -name = "Electrum" -mainscript = 'electrum' - -if sys.version_info[:3] < (3, 4, 0): - print("Error: " + name + " requires Python version >= 3.4.0...") - sys.exit(1) - -if sys.platform == 'darwin': - from plistlib import Plist - plist = Plist.fromFile('Info.plist') - plist.update(dict(CFBundleIconFile='electrum.icns')) - shutil.copy(mainscript, 'run_electrum.py') - mainscript = 'run_electrum.py' - extra_options = dict( - setup_requires=['py2app'], - app=[mainscript], - options=dict(py2app=dict(argv_emulation=False, - includes=['PyQt5.QtCore', 'PyQt5.QtGui', 'PyQt5.QtWebKit', 'PyQt5.QtNetwork', 'sip'], - packages=['lib', 'gui', 'plugins'], - iconfile='electrum.icns', - plist=plist, - resources=['icons', 'cacert.pem'])), - ) -elif sys.platform == 'win32': - extra_options = dict( - setup_requires=['py2exe'], - app=[mainscript], - ) -else: - extra_options = dict( - # Normally unix-like platforms will use "setup.py install" - # and install the main script as such - scripts=[mainscript], - ) - -setup( - name=name, - version=version, - **extra_options -) -from distutils import dir_util - -if sys.platform == 'darwin': - # Remove the copied py file - os.remove(mainscript) - resource = "dist/" + name + ".app/Contents/Resources/" - - # Try to locate qt_menu - # Let's try the port version first! - if os.path.isfile("/opt/local/lib/Resources/qt_menu.nib"): - qt_menu_location = "/opt/local/lib/Resources/qt_menu.nib" - else: - # No dice? Then let's try the brew version - if os.path.exists("/usr/local/Cellar"): - qt_menu_location = os.popen("find /usr/local/Cellar -name qt_menu.nib | tail -n 1").read() - # no brew, check /opt/local - else: - qt_menu_location = os.popen("find /opt/local -name qt_menu.nib | tail -n 1").read() - qt_menu_location = re.sub('\n', '', qt_menu_location) - - if (len(qt_menu_location) == 0): - print("Sorry couldn't find your qt_menu.nib this probably won't work") - else: - print("Found your qib: " + qt_menu_location) - - # Need to include a copy of qt_menu.nib - shutil.copytree(qt_menu_location, resource + "qt_menu.nib") - # Need to touch qt.conf to avoid loading 2 sets of Qt libraries - fname = resource + "qt.conf" - os.utime(fname, None)