WxPythonCygwin

= How to Build and Install wxPython for Microsoft Windows under Cygwin =

Introduction
This procedure produces a version of wxPython that works with the Cygwin build of Python 2.6 (using the Cygwin C runtime library) and uses native Windows graphics (i.e., direct GDI calls, not X Window calls). This combination is intended to work with a Cygwin version of GNU Radio (one that also uses the Cygwin C runtime library).

These instructions are current as of December 2010 and assume you are using wxPython 2.8.11.0 and current versions of all Cygwin tools and libraries. Updates have been applied to be current as of January 2015 using wxPython 3.0.2.0. These instruction will probably work with later releases as well, but this remains to be seen.

Step-by-Step Instructions.
Feel free to modify this recipe to suit your preferences:

(1) Download the wxWidgets and wxPython source code from the wxPython-src link at http://www.wxpython.org/download.php#sources to /usr/src.

(2) Unpack the source distribution:

cd /usr/src tar -jxf wxPython-src-2.8.11.0.tar.bz2 This will create the directory /usr/src/wxPython-src-2.8.11.0. For convenience (especially if you want to put your code somewhere else) I will call this directory  in what follows. To make the commands work as written, run the command

export WXDIR=/usr/src/wxPython-src-2.8.11.0 (3) Create a build directory:

cd $WXDIR mkdir build-local Choose any name for your build directory; I use  here.

(4) Configure wxWidgets:

cd $WXDIR/build-local ../configure --with-msw (4a) Apply patches:

These instructions apply to release 2.8.11.0. They may not be needed in later versions.

Find the file  and after the line:

add the line:
 * 1) define wxUSE_DATEPICKCTRL 1

If you are installing release 3.0.2.0 or later, the wxUSE_DATEPICKCTRL_GENERIC definition already exists in setup.h but still needs to be modified.
 * 1) define wxUSE_DATEPICKCTRL_GENERIC 1

Find the file, find the above #define wxUSE_DATEPICKCTRL_GENERIC line, and update the value from 0 to 1.

This change must be repeated if you rerun.

You also need to apply a patch to Python 2.x distutils. For python 2.6, download the patch file attachment:cygwinccompiler.patch to  and apply the patch with

cd /usr/lib/python2.6/distutils patch -i cygwinccompiler.patch For Python 2.7, download the patch file attachment:cygwinccompiler27.patch to  and apply the patch with

cd /usr/lib/python2.7/distutils patch -i cygwinccompiler27.patch This change only needs to be repeated if you reinstall python.

(5) Compile and link wxWidgets:

cd $WXDIR/build-local make make -C contrib/src/stc You may do  to compile and link the gizmos package. The gizmos package has some fun tools for developing Python programs but is not required for GNU Radio.

@ @

With Cygwin 1.7.1, you may get an error during the  about conflicts between   and. You can work around this error by temporarily renaming select.h:

cd /usr/include/sys mv select.h select.h-x and repeating the. You will need to undo the renaming

cd /usr/include/sys mv select.h-x select.h before going to the next step.

@ @

(6) Install wxWidgets:

cd $WXDIR/build-local make install make -C contrib/src/stc install This installs the wxWidgets DLLs in /usr/local/lib. If you compiled the gizmos package, install it with.

Depending on how you installed Cygwin, you might get an error like

/usr/bin/install -c -d /usr/local/lib /usr/bin/install: cannot change permissions of @/usr/local/lib': Permission denied You can fix this by changing /usr/local/lib and /usr/local/bin to give you ownership of these directories. See the instructions in hints, tips, known problems, and solutions for Windows.

@ @

(7) Move the DLLs to /usr/local/bin:

mv /usr/local/lib/cygwx*.dll /usr/local/bin Unless /usr/local/lib is in your PATH, it is easier to have the DLLs in /usr/local/bin. (If you know how to make the configure/build process do this for you, please let me know.)

@ @

(8) Test the build and installation of wxWidgets:

cd $WXDIR/build-local/samples/minimal make ./minimal.exe This should produce an empty window to prove that wxWidgets works.

@ @

(9) Build wxPython:

cd $WXDIR/wxPython python setup.py build_ext --inplace WXPORT=msw COMPILER=cygwin BUILD_GLCANVAS=0 BUILD_GIZMOS=0 UNICODE=0 This builds the Python connection to wxWidgets. If you built gizmos you should omit the  flag.

@ @

(10) Install wxPython:

cd $WXDIR/wxPython python setup.py install WXPORT=msw COMPILER=cygwin BUILD_GLCANVAS=0 BUILD_GIZMOS=0 UNICODE=0 This installs wxPython. If you build gizmos you should omit the  flag.

@ @

(11) Test your wxPython installation:

cd $WXDIR/wxPython/demo python demo.py This should present you with a green snake (and a window showing what wxPython can do). If this works, you are done. You should now be able to &quot;import wx&quot;, build gr-wxgui, and &quot;import wxgui&quot;.

If  doesn't work your version of Cygwin may be out of date (see hints, tips, known problems, and solutions for Windows).