Skip to content

Windows build HOWTO

mcallegari edited this page Jan 28, 2013 · 37 revisions

Prepare QT and MinGW32 build system

Get latest Qt prebuilt for MinGW32 here:
http://releases.qt-project.org/qt4/source/
and install them in C:\Qt

Download MinGW installer here:
http://sourceforge.net/projects/mingw/files/Installer/mingw-get-inst/
and install both MinGW and MSYS in the default path proposed by the installer.

Prerequisites

Download pkg-config prebuilt binaries and install them in the MinGW tree
http://ftp.gnome.org/pub/gnome/binaries/win32/dependencies/

I used this: http://ftp.gnome.org/pub/gnome/binaries/win32/dependencies/pkg-config_0.26-1_win32.zip

Download glib devel libraries needed by pkg-config: http://ftp.gnome.org/pub/gnome/binaries/win32/glib/
I used this: http://ftp.gnome.org/pub/gnome/binaries/win32/glib/2.24/glib_2.24.0-2_win32.zip

Download from this URL: http://lrn.no-ip.info/other/mingw/mingw32/
the -ming32-dev version of the following packages and extract them in the MinGW tree:

  • libmad
  • libsndfile
  • flac
  • libogg
  • libvorbis

Enttec/FTDI SDK

To compile the Enttec DMXUSB Output plugin on Windows, you need to:

Download the latest SDK from FTDI Driver page.
Install the package contents for example to C:\CDM20802
Edit /plugins/enttecdmxusb/src/src.pro to point to that directory:

FTD2XXDIR = C:\CDM20802

If you don't need the Enttec DMXUSB plugin and would like to disable building it completely, edit /plugins/plugins.pro and put a hash (#) on the line that says SUBDIRS += enttecdmxusb:

#SUBDIRS += enttecdmxusb

Velleman SDK

To compile the Velleman Output plugin on Windows, you need to:

Download the modified Velleman SDK
Unpack the zip to C:\K8062D
Not applicable yet: If you don't need the Velleman Output plugin and would like to disable building it completely, edit /plugins/plugins.pro and put a hash (#) on the line that says SUBDIRS += velleman:

#SUBDIRS += velleman

OSC support library (liblo)

Download the latest SVN snapshot of liblo from here: http://sourceforge.net/projects/liblo/

Compile libLO by doing:

./autogen.sh
./configure --enable-static --disable-shared --prefix=/mingw
make
make install

Now you need to manually patch libLO pkg-config file to avoid build issues. Edit the file liblo.pc that you can find in your MinGW installation path /lib/pkgconfig folder. (usually C:\MinGW\lib\pkgconfig)
Change the line starting with "Libs:" into:
Libs: -L${libdir} -llo -lpthread -lws2_32 -liphlpapi

Build QLC+

Now compile QLC+ (I use Windows PowerShell to do so):
qmake
make
make install

Post installation

Now to launch QLC+ the dependency libraries are needed as DLLs files. So copy in the main QLC+ folder the following:

  • libFLAC-8.dll
  • libmad-0.dll
  • libogg-0.dll
  • libsndfile-1.dll
  • libstdc++-6.dll
  • libvorbis-0.dll
  • libvorbisenc-2.dll
  • pthreadGC2.dll

Most likely the plugins folder will contain ".a" binaries. Rename them to ".dll" to let QLC+ load them.