X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/9646482db2f5429ce1bcbeaebeb85c9c1b9af87c..e04f4cb529108fc02c44eda228f96434c1086956:/configure.ac diff --git a/configure.ac b/configure.ac index 7b4fe51..94cffce 100644 --- a/configure.ac +++ b/configure.ac @@ -1,7 +1,7 @@ # Process this file with autoconf to produce a configure script. # # This file is part of DisOrder. -# Copyright (C) 2004-2008 Richard Kettlewell +# Copyright (C) 2004-2009 Richard Kettlewell # Portions copyright (C) 2007 Ross Younger # # This program is free software: you can redistribute it and/or modify @@ -18,9 +18,9 @@ # along with this program. If not, see . # -AC_INIT([disorder], [4.2+], [richard+disorder@sfere.greenend.org.uk]) +AC_INIT([disorder], [4.3+], [richard+disorder@sfere.greenend.org.uk]) AC_CONFIG_AUX_DIR([config.aux]) -AM_INIT_AUTOMAKE(disorder, [4.2+]) +AM_INIT_AUTOMAKE(disorder, [4.3+]) AC_CONFIG_SRCDIR([server/disorderd.c]) AM_CONFIG_HEADER([config.h]) @@ -39,8 +39,24 @@ want_alsa=yes want_oss=yes want_coreaudio=yes +# By default we don't want gtk-osx. But if you ask for --with-gtk-osx... +# +# Disobedience can be built to a native OS X application. There are some +# caveats: +# - you will still need Fink (or something) for other libraries +# - if you wanted an application bundle you are out of luck +# - the menu bar is still in the main window (not at the top of the screen) +# +# So it's still rather rough and ready. But it does work... +# +# See: +# http://www.gtk-osx.org/ +# http://live.gnome.org/GTK%2B/OSX/Framework +want_gtkosx=no + # Checks for programs. AC_PROG_CC +AM_PROG_CC_C_O AC_PROG_AWK AC_SET_MAKE if test "x$GCC" = xyes; then @@ -73,6 +89,10 @@ AC_ARG_WITH([tests], [AS_HELP_STRING([--without-tests], [do not build test suit])], [want_tests=$withval]) +AC_ARG_WITH([gtk-osx], + [AS_HELP_STRING([--with-gtk-osx], + [use native GTK+])], + [want_gtkosx=$withval]) AC_MSG_CHECKING([for a known target platform]) case "$host" in @@ -91,7 +111,7 @@ case "$host" in *-apple-darwin* ) AC_MSG_RESULT([Mac OS X]) if test $want_coreaudio = yes; then - COREAUDIO="-framework CoreAudio" + COREAUDIO="-framework CoreFoundation -framework CoreServices -framework CoreAudio" fi browser=open AC_MSG_CHECKING([Mac OS X target version]) @@ -117,9 +137,11 @@ case "$host" in AC_DEFINE_UNQUOTED([MAC_OS_X_VERSION_MIN_REQUIRED], [$minver], [define to minimum version of Mac OS X to support]) - # Fink's GTK+ is hopelessly broken - PKG_CONFIG_PATH=${PKG_CONFIG_PATH:-/sw/lib/pango-ft219/lib/pkgconfig} - export PKG_CONFIG_PATH + if test $want_gtkosx = no; then + # Fink's GTK+ is hopelessly broken + PKG_CONFIG_PATH=${PKG_CONFIG_PATH:-/sw/lib/pango-ft219/lib/pkgconfig} + export PKG_CONFIG_PATH + fi ;; *-freebsd* ) @@ -320,7 +342,7 @@ if test $want_gtk = yes; then fi fi if test $want_tests = yes && test $want_python = yes; then - AM_PATH_PYTHON([2.4]) + AM_PATH_PYTHON([2.5]) subdirs="${subdirs} python tests" fi AC_SUBST([subdirs]) @@ -416,8 +438,14 @@ AC_CHECK_LIB([pthread], [pthread_create], [missing_libraries="$missing_libraries libpthread"]) if test $want_gtk = yes; then - AM_PATH_GLIB_2_0([],[],[missing_libraries="$missing_libraries libglib"]) - AM_PATH_GTK_2_0([],[],[missing_libraries="$missing_libraries libgtk"]) + if test $want_gtkosx = yes; then + GTK_CFLAGS="-isystem /Library/Frameworks/Gtk.framework/Headers -isystem /Library/Frameworks/Cairo.framework/Headers" + GLIB_CFLAGS="-isystem /Library/Frameworks/GLib.framework/Headers" + GTK_LIBS="-framework Gtk -framework GLib" + else + AM_PATH_GLIB_2_0([],[],[missing_libraries="$missing_libraries libglib"]) + AM_PATH_GTK_2_0([],[],[missing_libraries="$missing_libraries libgtk"]) + fi fi # Some platforms have iconv already @@ -596,10 +624,27 @@ if test $want_server = yes; then ], [rjk_cv_db_version=ok], [rjk_cv_db_version=inadequate]) + if test $rjk_cv_db_version = ok; then + AC_PREPROC_IFELSE([ + #include + #if DB_VERSION_MAJOR == 4 && DB_VERSION_MINOR == 6 + # error http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=510270 + #endif + ], + [rjk_cv_db_version=ok], + [rjk_cv_db_version=toxic]) + fi ]) - if test $rjk_cv_db_version != ok; then - AC_MSG_ERROR([need db.h version at least 4.2]) - fi + case $rjk_cv_db_version in + ok ) + ;; + inadequate ) + AC_MSG_ERROR([need db version at least 4.3 (but not 4.6)]) + ;; + toxic ) + AC_MSG_ERROR([db version 4.6.x does not work - see debian bug 510270]) + ;; + esac fi AM_CONDITIONAL([SERVER], [test x$want_server = xyes])