--- qsampler/trunk/configure.ac 2010/01/07 19:39:47 2039 +++ qsampler/trunk/configure.ac 2014/05/21 16:56:18 2570 @@ -1,9 +1,9 @@ # Process this file with autoconf to produce a configure script. -AC_INIT(Qsampler, 0.2.2.6, rncbc@rncbc.org, qsampler) +AC_INIT(Qsampler, 0.2.3.5, rncbc@rncbc.org, qsampler) -AC_CONFIG_SRCDIR(src/qsamplerMainForm.ui) -AC_CONFIG_HEADERS(config.h) -AC_CONFIG_FILES(Makefile qsampler.pro qsampler.spec qsampler.desktop) +AC_CONFIG_SRCDIR(src/qsampler.cpp) +AC_CONFIG_HEADERS(src/config.h) +AC_CONFIG_FILES(Makefile qsampler.spec src/src.pri src/qsampler.desktop) # Set default installation prefix. AC_PREFIX_DEFAULT(/usr/local) @@ -21,30 +21,49 @@ if test "x$ac_debug" = "xyes"; then AC_DEFINE(CONFIG_DEBUG, 1, [Define if debugging is enabled.]) + ac_stacktrace="yes" ac_debug="debug" else + ac_stacktrace="no" ac_debug="release" fi AC_SUBST(ac_debug) + +# Enable Qt4/5 availability. +AC_ARG_ENABLE(qt4, + AC_HELP_STRING([--enable-qt4], [enable Qt4 build (default=yes)]), + [ac_qt4="$enableval"], + [ac_qt4="yes"]) + +AC_ARG_ENABLE(qt5, + AC_HELP_STRING([--enable-qt5], [enable Qt5 build (default=no)]), + [ac_qt5="$enableval"], + [ac_qt5="no"]) + +if test "x$ac_qt4" = "xno"; then + ac_qt5="yes" +fi +if test "x$ac_qt5" = "xyes"; then + ac_qt4="no" +fi + + # Enable libgig availability. AC_ARG_ENABLE(libgig, AC_HELP_STRING([--enable-libgig], [enable libgig interface (default=yes)]), [ac_libgig="$enableval"], [ac_libgig="yes"]) +# Enable debugger stack-trace option (assumes --enable-debug). +AC_ARG_ENABLE(stacktrace, + AC_HELP_STRING([--enable-stacktrace], [enable debugger stack-trace (default=no)]), + [ac_stacktrace="$enableval"]) + + # Standard installation base dirs. ac_with_paths="/usr /usr/local" -# Some a-la-debian alternatives... -for X in /usr/lib /usr/lib64 /usr/share; do - for Y in qt qt4; do - if test -d $X/$Y/bin; then - ac_with_paths="$ac_with_paths $X/$Y" - fi - done -done - # Set for alternate Qt installation dir. AC_ARG_WITH(qt, AC_HELP_STRING([--with-qt=PATH], [use alternate Qt install path]), @@ -60,6 +79,12 @@ AC_HELP_STRING([--with-libgig=PATH], [use alternate libgig install path]), [ac_with_paths="$ac_with_paths $withval"]) + +# Honor user specified flags. +ac_cflags=$CFLAGS +ac_ldflags=$LDFLAGS + + # Checks for programs. AC_PROG_CC AC_PROG_CPP @@ -71,17 +96,47 @@ AC_LANG_C AC_LANG_CPLUSPLUS + +# Check for proper flags. +ac_arch=`uname -m` + +# Check for some a-la-debian alternatives... +ac_qtdirs="qt" + +if test "x$ac_qt4" = "xyes"; then + ac_qtdirs="qt4 $ac_qtdirs" +fi +if test "x$ac_qt5" = "xyes"; then + ac_qtdirs="qt5 $ac_qtdirs" +fi + +ac_topdirs="/usr/share /usr/lib" + +if test "x$ac_arch" = "xx86_64"; then + CFLAGS="-fPIC $CFLAGS" + CPPFLAGS="-fPIC $CPPFLAGS" + ac_topdirs="$ac_topdirs /usr/lib64" +fi + +for X in $ac_topdirs; do + for Y in $ac_qtdirs; do + if test -d $X/$Y/bin; then + ac_with_paths="$X/$Y $ac_with_paths" + fi + done +done + # Prepend alternate dependencies paths. ac_path=$PATH for X in $ac_with_paths; do if test -d $X/bin; then ac_path="$X/bin:$ac_path" fi - if test -x $X/qmake; then - ac_path="$X:$ac_path" - fi +# if test -x $X/qmake; then +# ac_path="$X:$ac_path" +# fi if test -d $X/include; then - for Y in qt qt4; do + for Y in $ac_qtdirs; do if test -d $X/include/$Y; then CFLAGS="-I$X/include/$Y $CFLAGS" CPPFLAGS="-I$X/include/$Y $CPPFLAGS" @@ -92,7 +147,7 @@ CPPFLAGS="-I$X/include $CPPFLAGS" ac_incpath="$X/include $ac_incpath" fi - if test -d $X/lib64; then + if test "x$ac_arch" = "xx86_64" -a -d $X/lib64; then LIBS="-L$X/lib64 $LIBS" ac_libs="-L$X/lib64 $ac_libs" fi @@ -102,19 +157,21 @@ fi done + # Check for proper Qt version. -AC_CACHE_CHECK([for Qt library version >= 4.1], +AC_CACHE_CHECK([for Qt library version >= 4.4], ac_cv_qtversion, [ - AC_TRY_LINK([#include "Qt/qglobal.h"], [ -#if QT_VERSION < 0x040100 -#error Qt library 4.1 or greater required. + AC_TRY_LINK([#include "QtCore/qglobal.h"], [ +#if QT_VERSION < 0x040400 +#error Qt library 4.4 or greater required. #endif ], ac_cv_qtversion="yes", [ - echo "no; Qt 4.1 or greater is required" + echo "no; Qt 4.4 or greater is required" exit ]) ]) + # A common error message: ac_errmsg="not found in current PATH. Maybe QT development environment isn't available (qt-devel)." @@ -170,6 +227,12 @@ AC_MSG_ERROR([LSCP library not found.]) fi ac_libs="$ac_libs -llscp" +case "{$host}" in + *mingw*) + ac_libs="$ac_libs -lws2_32" + LIBS="$LIBS -lws2_32" + ;; +esac AC_CACHE_CHECK([for instrument_name in lscp_channel_info_t], ac_cv_instrument_name, [ @@ -294,17 +357,14 @@ AC_LANG_SAVE AC_LANG_CPLUSPLUS CXXFLAGS="$ac_libs" - AC_TRY_RUN([ + AC_TRY_COMPILE([ #include #include -int main() { + ],[ gig::File file; file.SetAutoLoad(false); - exit(0); -} ], have_libgig_setautoload="yes", - have_libgig_setautoload="no", have_libgig_setautoload="no" ) AC_LANG_RESTORE @@ -321,13 +381,25 @@ AC_DEFINE(CONFIG_ROUND, 1, [Define if round is available.]) fi +# Check for debugging stack-trace. +if test "x$ac_stacktrace" = "xyes"; then + AC_DEFINE(CONFIG_STACKTRACE, 1, [Define if debugger stack-trace is enabled.]) +fi + +# Some recent distros (eg. fedora, debian) require this. +if test "x$ac_cv_lib_X11_main" = "xyes"; then + ac_libs="$ac_libs -lX11" +fi + AC_SUBST(ac_libs) AC_SUBST(ac_incpath) +AC_SUBST(ac_cflags) +AC_SUBST(ac_ldflags) # Checks for header files. AC_HEADER_STDC AC_HEADER_SYS_WAIT -AC_CHECK_HEADERS(fcntl.h sys/ioctl.h unistd.h signal.h) +AC_CHECK_HEADERS(fcntl.h sys/ioctl.h unistd.h signal.h sys/socket.h) AC_CHECK_HEADER(lscp/client.h, [ac_lscp_h="yes"], [ac_lscp_h="no"]) if test "x$ac_lscp_h" = "xno"; then @@ -369,6 +441,8 @@ echo " LSCP device MIDI event support . . . . . . . . . .: $ac_device_midi_event" echo " LSCP runtime max. voices / disk streams support .: $ac_max_voices" echo +echo " Debugger stack-trace (gdb) . . . . . . . . . . . .: $ac_stacktrace" +echo echo " Install prefix . . . . . . . . . . . . . . . . . .: $ac_prefix" echo echo "Now type 'make', followed by 'make install' as root."