From ad6496e426f81bd1519dfbd9cc092298d6dae8c0 Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Wed, 19 Feb 2020 18:00:10 +0200 Subject: [PATCH 1/5] Make it possible to build and use ext on windows - change ext attributes and c source for windows allowing to build pyd - remove trailing slashes in data_files - try to load pyd in proofofwork by ctypes.PyDLL() --- setup.py | 13 ++++++++++--- src/bitmsghash/bitmsghash.cpp | 5 +++++ src/proofofwork.py | 8 +++++++- 3 files changed, 22 insertions(+), 4 deletions(-) diff --git a/setup.py b/setup.py index 77ec81c8..d0d733bc 100644 --- a/setup.py +++ b/setup.py @@ -59,6 +59,13 @@ if __name__ == "__main__": libraries=['pthread', 'crypto'], ) + if sys.platform[:3] == 'win': + bitmsghash.libraries = ['libeay32', 'ws2_32'] + openssl_dir = os.getenv('OPENSSL_DIR') + if openssl_dir: + bitmsghash.library_dirs = [os.path.join(openssl_dir, 'lib')] + bitmsghash.include_dirs = [os.path.join(openssl_dir, 'include')] + installRequires = ['six'] packages = [ 'pybitmessage', @@ -90,11 +97,11 @@ if __name__ == "__main__": packages += ['pybitmessage.fallback.umsgpack'] data_files = [ - ('share/applications/', + ('share/applications', ['desktop/pybitmessage.desktop']), - ('share/icons/hicolor/scalable/apps/', + ('share/icons/hicolor/scalable/apps', ['desktop/icons/scalable/pybitmessage.svg']), - ('share/icons/hicolor/24x24/apps/', + ('share/icons/hicolor/24x24/apps', ['desktop/icons/24x24/pybitmessage.png']) ] diff --git a/src/bitmsghash/bitmsghash.cpp b/src/bitmsghash/bitmsghash.cpp index 24775475..b65c3265 100644 --- a/src/bitmsghash/bitmsghash.cpp +++ b/src/bitmsghash/bitmsghash.cpp @@ -163,3 +163,8 @@ extern "C" EXPORT unsigned long long BitmessagePOW(unsigned char * starthash, un free(threaddata); return successval; } + +// workaround for building setuptools ext on Windows +// https://stackoverflow.com/questions/34689210 +void initbitmsghash() {} //Python 2.7 +void PyInit_bitmsghash() {} //Python 3.5 diff --git a/src/proofofwork.py b/src/proofofwork.py index f170aa5f..b2842462 100644 --- a/src/proofofwork.py +++ b/src/proofofwork.py @@ -298,7 +298,13 @@ def init(): bitmsglib = 'bitmsghash64.dll' try: # MSVS - bso = ctypes.WinDLL(os.path.join(paths.codePath(), "bitmsghash", bitmsglib)) + libfile = os.path.join(paths.codePath(), "bitmsghash", bitmsglib) + if os.path.isfile(libfile): + bso = ctypes.WinDLL(libfile) + else: + bitmsglib = 'bitmsghash.pyd' + libfile = os.path.join(paths.codePath(), "bitmsghash", bitmsglib) + bso = ctypes.PyDLL(libfile) logger.info("Loaded C PoW DLL (stdcall) %s", bitmsglib) bmpow = bso.BitmessagePOW bmpow.restype = ctypes.c_ulonglong From e8ffa19a45351473a78d2b9889b7732941c7c18b Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Tue, 20 Oct 2020 17:21:03 +0300 Subject: [PATCH 2/5] PyInstaller package: use OPENSSL_DIR and bitmsghash.pyd if no dll --- packages/pyinstaller/bitmessagemain.spec | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/packages/pyinstaller/bitmessagemain.spec b/packages/pyinstaller/bitmessagemain.spec index d7d4d70d..6b7101b9 100644 --- a/packages/pyinstaller/bitmessagemain.spec +++ b/packages/pyinstaller/bitmessagemain.spec @@ -12,7 +12,7 @@ arch = 32 if ctypes.sizeof(ctypes.c_voidp) == 4 else 64 cdrivePath = site_root[0:3] srcPath = os.path.join(spec_root[:-20], "pybitmessage") 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") outPath = os.path.join(spec_root, "bitmessagemain") qtBase = "PyQt4" @@ -83,12 +83,19 @@ 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 += [ # No effect: libeay32.dll will be taken from PyQt if installed ('libeay32.dll', os.path.join(openSSLPath, 'libeay32.dll'), 'BINARY'), - (os.path.join('bitmsghash', 'bitmsghash%i.dll' % arch), - os.path.join(srcPath, 'bitmsghash', 'bitmsghash%i.dll' % arch), - 'BINARY'), + ext_lib, (os.path.join('bitmsghash', 'bitmsghash.cl'), os.path.join(srcPath, 'bitmsghash', 'bitmsghash.cl'), 'BINARY'), (os.path.join('sslkeys', 'cert.pem'), From fe9c168b8708e60834f8b3f02678b13e50e6ae2f Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Tue, 20 Oct 2020 18:32:55 +0300 Subject: [PATCH 3/5] Experimental 32bit build with pyd instead of dll --- buildscripts/winbuild.sh | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/buildscripts/winbuild.sh b/buildscripts/winbuild.sh index 5a59222b..3c9edb4b 100755 --- a/buildscripts/winbuild.sh +++ b/buildscripts/winbuild.sh @@ -88,9 +88,11 @@ function install_openssl(){ if [ "${MACHINE_TYPE}" == 'x86_64' ]; then echo "Installing OpenSSL ${OPENSSL_VERSION} 64b" wine Win64OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysilent /sp- /suppressmsgboxes + export OPENSSL_DIR="$HOME/.wine64/drive_c/OpenSSL-Win64" else echo "Installing OpenSSL ${OPENSSL_VERSION} 32b" wine Win32OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysilent /sp- /suppressmsgboxes + export OPENSSL_DIR="$HOME/.wine64/drive_c/OpenSSL-Win32" fi } @@ -131,8 +133,8 @@ function install_pyopencl() function build_dll(){ cd "${BASE_DIR}" || exit 1 - cd src/bitmsghash || exit 1 if [ "${MACHINE_TYPE}" == 'x86_64' ]; then + cd src/bitmsghash || exit 1 echo "Create dll" x86_64-w64-mingw32-g++ -D_WIN32 -Wall -O3 -march=native \ "-I$HOME/.wine64/drive_c/OpenSSL-Win64/include" \ @@ -147,18 +149,20 @@ function build_dll(){ -fPIC -shared -lcrypt32 -leay32 -lwsock32 \ -o bitmsghash64.dll -Wl,--out-implib,bitmsghash.a else - echo "Create dll" - i686-w64-mingw32-g++ -D_WIN32 -Wall -m32 -O3 -march=native \ - "-I$HOME/.wine32/drive_c/OpenSSL-Win32/include" \ - -I/usr/i686-w64-mingw32/include \ - "-L$HOME/.wine32/drive_c/OpenSSL-Win32/lib" \ - -c bitmsghash.cpp - i686-w64-mingw32-g++ -static-libgcc -shared bitmsghash.o \ - -D_WIN32 -O3 -march=native \ - "-I$HOME/.wine32/drive_c/OpenSSL-Win32/include" \ - "-L$HOME/.wine32/drive_c/OpenSSL-Win32/lib/MinGW" \ - -fPIC -shared -lcrypt32 -leay32 -lwsock32 \ - -o bitmsghash32.dll -Wl,--out-implib,bitmsghash.a + echo "Create pyd" + # FIXME: check for VCPython and build dll if not found + wine python setup.py build_ext --inplace + # i686-w64-mingw32-g++ -D_WIN32 -Wall -m32 -O3 -march=native \ + # "-I$HOME/.wine32/drive_c/OpenSSL-Win32/include" \ + # -I/usr/i686-w64-mingw32/include \ + # "-L$HOME/.wine32/drive_c/OpenSSL-Win32/lib" \ + # -c bitmsghash.cpp + # i686-w64-mingw32-g++ -static-libgcc -shared bitmsghash.o \ + # -D_WIN32 -O3 -march=native \ + # "-I$HOME/.wine32/drive_c/OpenSSL-Win32/include" \ + # "-L$HOME/.wine32/drive_c/OpenSSL-Win32/lib/MinGW" \ + # -fPIC -shared -lcrypt32 -leay32 -lwsock32 \ + # -o bitmsghash32.dll -Wl,--out-implib,bitmsghash.a fi } From e55eaa3b94f5e9f4f9e645e8fc3a3cc7e42e12fa Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Sun, 27 Jun 2021 22:28:39 +0300 Subject: [PATCH 4/5] Download and install vcpython27 for WINEARCH=win32 --- buildscripts/winbuild.sh | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/buildscripts/winbuild.sh b/buildscripts/winbuild.sh index 3c9edb4b..42ea75f0 100755 --- a/buildscripts/winbuild.sh +++ b/buildscripts/winbuild.sh @@ -18,7 +18,8 @@ function download_sources_32 { https://web.archive.org/web/20210420044701/https://download.microsoft.com/download/1/1/1/1116b75a-9ec3-481a-a3c8-1777b5381140/vcredist_x86.exe \ https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/PyQt${PYQT_VERSION}-x32.exe?raw=true \ https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/Win32OpenSSL-${OPENSSL_VERSION}.exe?raw=true \ - https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win32.whl?raw=true + https://github.com/Bitmessage/ThirdPartyLibraries/blob/master/pyopencl-2015.1-cp27-none-win32.whl?raw=true \ + https://web.archive.org/web/20190720195601/https://download.microsoft.com/download/7/9/6/796EF2E4-801B-4FC4-AB28-B59FBF6D907B/VCForPython27.msi } function download_sources_64 { @@ -64,8 +65,10 @@ function install_python(){ wine msiexec -i python-${PYTHON_VERSION}.msi /q /norestart # MSVCR 2008 required for Windows XP cd ${SRCPATH} || exit 1 - echo "Installing vc_redist (2008) for 32 bit " + echo "Installing vc_redist (2008) for 32 bit" wine vcredist_x86.exe /Q + echo "Installing vcpython27" + wine msiexec -i VCForPython27.msi /qn /norestart fi echo "Installing pytools 2020.2" # last version compatible with python 2 From 3b73df5027212049b3794dcca18040d18f0e364a Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Tue, 29 Jun 2021 15:41:57 +0300 Subject: [PATCH 5/5] Also change OPENSSL_DIR to windows path for 32b build --- buildscripts/winbuild.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/buildscripts/winbuild.sh b/buildscripts/winbuild.sh index 42ea75f0..d832689a 100755 --- a/buildscripts/winbuild.sh +++ b/buildscripts/winbuild.sh @@ -95,7 +95,7 @@ function install_openssl(){ else echo "Installing OpenSSL ${OPENSSL_VERSION} 32b" wine Win32OpenSSL-${OPENSSL_VERSION}.exe /q /norestart /silent /verysilent /sp- /suppressmsgboxes - export OPENSSL_DIR="$HOME/.wine64/drive_c/OpenSSL-Win32" + export OPENSSL_DIR="C:\\OpenSSL-Win32" fi }