##
## This file is part of the sigrok-util project.
##
-## Copyright (C) 2013 Uwe Hermann <uwe@hermann-uwe.de>
+## Copyright (C) 2013-2014 Uwe Hermann <uwe@hermann-uwe.de>
##
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by
# -----------------------------------------------------------------------------
-# Python3
+mkdir -p $PREFIX
+
# Cross-compiling Python is highly non-trivial, so we avoid it for now.
# The download below is a repackaged tarball of the official Python 3.2.3 MSI
-# installer for Windows: http://python.org/ftp/python/3.2.3/python-3.2.3.msi
-# The MSI file has been installed on a Windows box and then the c:\Python32
-# files have been stored in the Python32.tar.gz tarball.
-mkdir -p $PREFIX
+# installer for Windows: http://python.org/ftp/python/3.2.3/python-3.2.3.msi.
+# The MSI file has been installed on a Windows box and then c:\Python32\libs
+# and c:\Python32\include have been stored in the Python32.tar.gz tarball.
$WGET http://www.sigrok.org/tmp/Python32.tar.gz -O $PREFIX/Python32.tar.gz
tar xzf $PREFIX/Python32.tar.gz -C $PREFIX
Cflags: -I$PREFIX/Python32/include
EOF
-# Download the Python 3.2.3 MSI installer (needed for NSIS runs).
-$WGET -c http://python.org/ftp/python/3.2.3/python-3.2.3.msi \
- -O $PREFIX/python-3.2.3.msi
+# The python32.dll and python32.zip files will be shipped in the NSIS
+# Windows installers (required for protocol decoding to work).
+# The file python32.dll (NOT the same as python3.dll) is copied from an
+# installed Python 3.2.3 (see above) from c:\Windows\system32\python32.dll.
+# The file python32.zip contains all files from the 'DLLs', 'Lib', and 'libs'
+# subdirectories from an installed Python on Windows (c:\python32), i.e. some
+# libraries and all Python stdlib modules.
+$WGET http://www.sigrok.org/tmp/python32.dll -O $PREFIX/python32.dll
+$WGET http://www.sigrok.org/tmp/python32.zip -O $PREFIX/python32.zip
# libusb0.dll (needs to be shipped with frontends)
$WGET -c http://$SF_MIRROR/project/libusb-win32/libusb-win32-releases/$VER_LIBUSB_WIN32/libusb-win32-bin-$VER_LIBUSB_WIN32.zip
git clone git://sigrok.org/libsigrokdecode
cd libsigrokdecode
./autogen.sh
+patch -p1 < ../../srd_decodersdir.patch
PKG_CONFIG_PATH_i686_pc_mingw32=$P ./configure $C $L
make $PARALLEL V=1
make install
# sigrok-cli
git clone git://sigrok.org/sigrok-cli
cd sigrok-cli
-patch -p1 < ../../sigrok_cli_decodersdir.patch
./autogen.sh
PKG_CONFIG_PATH_i686_pc_mingw32=$P:$P2 ./configure $C
make $PARALLEL V=1
# PulseView
git clone git://sigrok.org/pulseview
cd pulseview
-patch -p1 < ../../pulseview_decodersdir.patch
PKG_CONFIG_PATH_i686_pc_mingw32=$P:$P2 cmake $CM -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX -DDISABLE_WERROR=y .
make $PARALLEL VERBOSE=1
make install
+++ /dev/null
-diff --git a/main.c b/main.c
-index 9ab3f77..9d34034 100644
---- a/main.c
-+++ b/main.c
-@@ -216,7 +216,7 @@ int main(int argc, char **argv)
- goto done;
-
- if (opt_pds) {
-- if (srd_init(NULL) != SRD_OK)
-+ if (srd_init("decoders") != SRD_OK)
- goto done;
- if (srd_session_new(&srd_sess) != SRD_OK) {
- g_critical("Failed to create new decode session.");
-diff --git a/show.c b/show.c
-index db643d1..55c1bf6 100644
---- a/show.c
-+++ b/show.c
-@@ -65,7 +65,7 @@ void show_version(void)
- printf("\n");
-
- #ifdef HAVE_SRD
-- if (srd_init(NULL) == SRD_OK) {
-+ if (srd_init("decoders") == SRD_OK) {
- printf("Supported protocol decoders:\n");
- srd_decoder_load_all();
- for (l = srd_decoder_list(); l; l = l->next) {
--- /dev/null
+diff --git a/srd.c b/srd.c
+index f5b885f..1599957 100644
+--- a/srd.c
++++ b/srd.c
+@@ -140,16 +140,32 @@ SRD_API int srd_init(const char *path)
+ /* Add our own module to the list of built-in modules. */
+ PyImport_AppendInittab("sigrokdecode", PyInit_sigrokdecode);
+
++ /*
++ * MinGW: Hardcode the frontend's install dir as PYTHONHOME.
++ * The NSIS installers will place python*.dll and python*.zip (which
++ * contains all required libs and Python modules) there.
++ *
++ * Also hardcode that only the Python stdlib and the libsigrokdecode
++ * PDs in the 'decoders' subdirectory in the frontend's install
++ * directory are ever used/found by Python. This avoids various issues
++ * with other Python libs and modules installed on the same system.
++ */
++
+ /* Initialize the Python interpreter. */
++ Py_SetPythonHome(L".");
+ Py_Initialize();
++ PyRun_SimpleString("import sys; sys.path = ['python32.zip']");
+
++#if 0
+ /* Installed decoders. */
+ if ((ret = srd_decoder_searchpath_add(DECODERS_DIR)) != SRD_OK) {
+ Py_Finalize();
+ return ret;
+ }
++#endif
+
+ /* Path specified by the user. */
++ path = "decoders";
+ if (path) {
+ if ((ret = srd_decoder_searchpath_add(path)) != SRD_OK) {
+ Py_Finalize();