From 51ff1497487dc9c5c9255c1e01f03d5012a5c3fe Mon Sep 17 00:00:00 2001 From: Dana Jansens Date: Sat, 11 Jan 2003 04:06:25 +0000 Subject: [PATCH] new autoconf shit woowoo --- .cvsignore | 1 - bootstrap | 2 +- configure.ac | 380 +++---------------------------------------------- src/openbox.cc | 3 +- version.h.in | 1 - 5 files changed, 22 insertions(+), 365 deletions(-) delete mode 100644 version.h.in diff --git a/.cvsignore b/.cvsignore index 91e02423..625eb49d 100644 --- a/.cvsignore +++ b/.cvsignore @@ -20,5 +20,4 @@ mkinstalldirs missing install-sh depcomp -m4 config.rpath diff --git a/bootstrap b/bootstrap index 39f729bd..f0e2b2b0 100755 --- a/bootstrap +++ b/bootstrap @@ -6,7 +6,7 @@ sh() { sh autopoint --force # for GNU gettext sh libtoolize --copy --force --automake -sh aclocal +sh aclocal -I m4 sh autoheader sh autoconf sh automake --foreign --include-deps --add-missing --copy diff --git a/configure.ac b/configure.ac index f68796e8..9d1afcf4 100644 --- a/configure.ac +++ b/configure.ac @@ -1,16 +1,22 @@ +AC_PREREQ([2.50]) AC_INIT([src/main.cc]) -AM_CONFIG_HEADER(config.h) -AM_INIT_AUTOMAKE([openbox], [2.90.0cvs]) +AC_CONFIG_HEADERS(config.h) +AC_LANG(C++) -AC_PREREQ([2.50]) +# Determine build target +OB_DEBUG + +AM_INIT_AUTOMAKE([Openbox], [2.90.0cvs]) test "$prefix" = "NONE" && prefix="$ac_default_prefix" - + AC_PATH_PROG([regex_cmd], [sed]) test "$regex_cmd" || AC_MSG_ERROR([sed not found]) -AC_PROG_CC -AC_PROG_CXX +AM_MAINTAINER_MODE +# Pick compiler specific/build target flags +OB_COMPILER_FLAGS + AC_PROG_LIBTOOL LIBTOOL="$LIBTOOL --silent" AC_PROG_INSTALL @@ -19,364 +25,19 @@ ALL_LINGUAS="" AM_GNU_GETTEXT_VERSION(0.11.5) AM_GNU_GETTEXT([external]) -AC_LANG(C++) - -# Check what compiler we are using -AC_MSG_CHECKING([for GCC]) -if test "$GCC" = "yes"; then - AC_MSG_RESULT([yes]) - CXXFLAGS="$CXXFLAGS -Wall -W" -# -pedantic" -else - AC_MSG_RESULT([no, trying other compilers]) - AC_MSG_CHECKING(for MIPSpro) - mips_pro_ver=`$CXX -version 2>&1 | grep -i mipspro | cut -f4 -d ' '` - if test -z "$mips_pro_ver"; then - AC_MSG_RESULT([no]) - else - AC_MSG_RESULT([yes, version $mips_pro_ver.]) - AC_MSG_CHECKING(for -LANG:std in CXXFLAGS) - lang_std_not_set=`echo $CXXFLAGS | grep "\-LANG:std"` - if test "x$lang_std_not_set" = "x"; then - AC_MSG_RESULT([not set, setting.]) - CXXFLAGS="${CXXFLAGS} -LANG:std" - else - AC_MSG_RESULT([already set.]) - fi - fi -fi - -# Determine if maintainer portions of the Makefiles should be included. -AM_MAINTAINER_MODE - -# Check for system header files +PYTHON_DEVEL + AC_CHECK_HEADERS(ctype.h dirent.h fcntl.h libgen.h locale.h nl_types.h process.h signal.h stdarg.h stdio.h stdlib.h string.h time.h unistd.h sys/param.h sys/select.h sys/signal.h sys/stat.h sys/time.h sys/types.h sys/wait.h) AC_HEADER_TIME - -# Determine the return type of signal handlers # AC_TYPE_SIGNAL -# Check whether to include debugging code -DEBUG="" -AC_MSG_CHECKING([whether to include verbose debugging code]) -AC_ARG_ENABLE([debug], - [ --enable-debug include verbose debugging code @<:@default=no@:>@], - if test "$enableval" = "yes"; then - AC_MSG_RESULT([yes]) - if test "$GCC" = "yes"; then - DEBUG="-DDEBUG -fno-inline -g" - else - DEBUG="-DDEBUG" - fi - else - AC_MSG_RESULT([no]) - DEBUG="-DNDEBUG" - fi, - AC_MSG_RESULT([no]) - DEBUG="-DNDEBUG" -) -CXXFLAGS="$CXXFLAGS $DEBUG" - -# Check for Python -AC_ARG_WITH([python], - [ --with-python=path Set location of Python executable], - [PYTHON="$withval"], - [PYTHON=]) - -# Find the python bin -if ! test "$PYTHON"; then - AC_CHECK_PROGS(PYTHON, $prefix/bin/python python python2.4 python2.3 python2.2 python2.1 python2.0 python1.6 python1.5 python1.4) -fi -if ! test "$PYTHON"; then - AC_MSG_ERROR([Openbox requires the use of Python. This is its secret special formula for extreme sexiness. -See http://www.python.org -]) -fi - -# Find our python paths -AC_MSG_CHECKING([for Python version]) -# Need to do this hack since autoconf replaces __file__ with the name of the configure file -filehack="file__" -PYVERSION=`($PYTHON -c "import string,operator; print operator.getitem(string.split(string.__$filehack,'/'),-2)")` -AC_MSG_RESULT([$PYVERSION]) - -AC_MSG_CHECKING([for Python prefix]) -PYPREFIX=`($PYTHON -c "import sys; print sys.prefix") 2>/dev/null` -AC_MSG_RESULT([$PYPREFIX]) -AC_MSG_CHECKING([for Python exec-prefix]) -PYEPREFIX=`($PYTHON -c "import sys; print sys.exec_prefix") 2>/dev/null` -AC_MSG_RESULT([$PYEPREFIX]) - -# Find the include directory -AC_MSG_CHECKING([for Python header files]) -if test -r "$PYPREFIX/include/$PYVERSION/Python.h"; then - PYTHON_CFLAGS="-I$PYPREFIX/include/$PYVERSION" -fi -if test -z "$PYTHON_CFLAGS"; then - if test -r "$PYPREFIX/include/Py/Python.h"; then - PYTHON_CFLAGS="-I$PYPREFIX/include/Py" - fi -fi -if ! test "$PYTHON_CFLAGS"; then - AC_MSG_ERROR([Not found]) -else - AC_MSG_RESULT([$PYTHON_CFLAGS]) -fi - -# Find the python library -PYTHON_LIBS="" -AC_MSG_CHECKING([for Python library]) -dirs="$PYEPREFIX/lib $PYEPREFIX/lib/$PYVERSION/config \ - $PYEPREFIX/lib/$PYVERSION/lib $PYEPREFIX/lib/python/lib" -for i in $dirs; do - # look for really old versions - if test -r "$i/lib$PYVERSION.so"; then - PYLIB="$i" - PYTHON_LIBS="-L$PYLIB -l$PYVERSION" - break - else - if test -r "$i/libPython.a"; then - PYLIB="$i" - PYTHON_LIBS="-L$PYLIB -lModules -lPython -lObjects -lParser" - break - else - if test -r "$i/lib$PYVERSION.a"; then - PYLIB="$i" - PYTHON_LIBS="-L$PYLIB -l$PYVERSION -lpthread -ldl -lutil -lm" - break - fi - fi - fi -done - -if ! test "$PYLIB"; then - AC_MSG_ERROR([Not found]) -else - AC_MSG_RESULT([$PYLIB]) -fi - -AC_SUBST([PYTHON_CFLAGS]) -AC_SUBST([PYTHON_LIBS]) - -# Check for X headers and libraries -AC_PATH_X -AC_PATH_XTRA -test "$no_x" = "yes" && AC_MSG_ERROR([No Xlibs found.]) -test -z "$x_includes" && x_includes="/usr/include" -test -z "$x_libraries" && x_libraries="/usr/lib" - -CXXFLAGS="$CXXFLAGS $X_CFLAGS" -LIBS="$LIBS $X_LIBS $X_EXTRA_LIBS" -LDFLAGS="$LDFLAGS $X_PRE_LIBS $LIBS $X_EXTRA_LIBS" - -# Check for required functions in -lX11 -AC_CHECK_LIB([X11], [XOpenDisplay], - , - AC_MSG_ERROR([Could not find XOpenDisplay in -lX11.]) -) - - -# Check for Xft >= 2 -XFT_MIN_MAJOR=2 -XFT_MIN_MINOR=0 -XFT_MIN_REVISION=0 -XFT_MIN=$XFT_MIN_MAJOR.$XFT_MIN_MINOR.$XFT_MIN_REVISION -AC_MSG_CHECKING([for Xft version >= $XFT_MIN]) -if ! pkg-config --atleast-version $XFT_MIN xft; then - AC_MSG_RESULT([no]) - AC_MSG_ERROR([Openbox requires the Xft version >= $XFT_MIN font library. -See http://www.fontconfig.org/ -]) -fi - -AC_MSG_RESULT([yes]) - -# Store these -OLDLIBS=$LIBS -OLDCXXFLAGS=$CXXFLAGS - -XFT_CFLAGS="`pkg-config --cflags xft`" -XFT_LIBS="`pkg-config --libs xft`" - -# Set these for checking with the tests below. They'll be restored after -LIBS="$LIBS $XFT_LIBS" -CXXFLAGS="$XFT_CFLAGS $CXXFLAGS" - -AC_CHECK_LIB([Xft], [XftFontOpenName], - AC_MSG_CHECKING([for X11/Xft/Xft.h for Xft >= $XFT_MIN]) - AC_TRY_COMPILE( - [ - #include - #include - ], - [ - #if !defined(XFT_MAJOR) - # error Xft.h is too old - #endif - #if XFT_MAJOR < $XFT_MIN_MAJOR - # error Xft.h is too old - #endif - #if XFT_MAJOR == $XFT_MIN_MAJOR - # if XFT_MINOR < $XFT_MIN_MINOR - # error Xft.h is too old - # endif - #endif - #if XFT_MAJOR == $XFT_MIN_MAJOR - # if XFT_MAJOR == $XFT_MIN_MINOR - # if XFT_REVISION < $XFT_MIN_REVISION - # error Xft.h is too old - # endif - # endif - #endif - - int i = XFT_MAJOR; - XftFont foo; - ], - [ - AC_MSG_RESULT([yes]) - ], - [ - AC_MSG_RESULT([no]) - AC_MSG_ERROR([Openbox requires the Xft version >= $XFT_MIN font library. -See http://www.fontconfig.org/ -]) - ] - ) - - AC_MSG_CHECKING([if we can compile with Xft]) - AC_TRY_LINK( - [ - #include - #include - ], - [ - int i = XFT_MAJOR; - XftFont foo - ], - [ - AC_MSG_RESULT([yes]) - ], - [ - AC_MSG_RESULT([no]) - AC_MSG_ERROR([Unable to compile with the Xft library. -]) - ] - ) -) -# Restore the old values. Use XFT_CFLAGS and XFT_LIBS in the Makefile.am's -LIBS=$OLDLIBS -CXXFLAGS=$OLDCXXFLAGS - -AC_SUBST([XFT_CFLAGS]) -AC_SUBST([XFT_LIBS]) - -# Check for XKB extension support -AC_CHECK_LIB([X11], [XkbBell], - AC_MSG_CHECKING([for X11/XKBlib.h]) - AC_TRY_LINK( - [ - #include - #include - #include - ], - [ - Display *d; - Window w; - XkbBell(d, w, 0, 0); - ], - [ - AC_MSG_RESULT([yes]) - XKB="yes" - AC_DEFINE([XKB], [1], [Found the XKB extension]) - ], - [ - AC_MSG_RESULT([no]) - XKB="no" - ] - ) -) -AC_MSG_CHECKING([for the XKB extension]) -if test "$XKB" = "yes"; then - AC_MSG_RESULT([yes]) -else - AC_MSG_RESULT([no]) -fi - -# Check for XShape extension support -AC_CHECK_LIB([Xext], [XShapeCombineShape], - AC_MSG_CHECKING([for X11/extensions/shape.h]) - AC_TRY_LINK( - [ - #include - #include - #include - ], - [ - long foo = ShapeSet - ], - [ - AC_MSG_RESULT([yes]) - SHAPE="yes" - AC_DEFINE([SHAPE], [1], [Found the XShape extension]) - LIBS="$LIBS -lXext" - ], - [ - AC_MSG_RESULT([no]) - SHAPE="no" - ] - ) -) -AC_MSG_CHECKING([for the XShape extension]) -if test "$SHAPE" = "yes"; then - AC_MSG_RESULT([yes]) -else - AC_MSG_RESULT([no]) -fi - -# Check for Xinerama extension support -AC_MSG_CHECKING([whether to build support for the Xinerama extension]) -XINERAMA="no" -AC_ARG_ENABLE([xinerama], -[ --enable-xinerama enable support of the Xinerama extension @<:@default=no@:>@], - if test "$enableval" = "yes"; then - AC_MSG_RESULT([yes]) - - AC_CHECK_LIB([Xinerama], [XineramaQueryExtension], - [ - AC_MSG_CHECKING([for X11/extensions/Xinerama.h]) - AC_TRY_LINK( - [ - #include - #include - ], - [ - XineramaScreenInfo foo - ], - [ - AC_MSG_RESULT([yes]) - XINERAMA="yes" - AC_DEFINE([XINERAMA], [1], - [Enable support of the Xinerama extension]) - LIBS="$LIBS -lXinerama" - ], - [ - AC_MSG_RESULT([no]) - ] - ) - ] - ) +# Check for Xft2 +XFT_DEVEL(2.0.0) - AC_MSG_CHECKING([for the Xinerama extension]) - if test "$XINRERAMA" = "yes"; then - AC_MSG_RESULT([yes]) - else - AC_MSG_RESULT([no]) - fi - else - AC_MSG_RESULT([no]) - fi, - AC_MSG_RESULT([no]) -) +# Check for X11 extensions +X11_EXT_XKB +X11_EXT_SHAPE +X11_EXT_XINERAMA AC_CONFIG_FILES([Makefile po/Makefile.in otk/Makefile @@ -389,7 +50,6 @@ AC_CONFIG_FILES([Makefile po/Makefile.in data/Makefile data/buttons/Makefile data/styles/Makefile - version.h ]) AC_OUTPUT diff --git a/src/openbox.cc b/src/openbox.cc index 3232827f..42cc1fef 100644 --- a/src/openbox.cc +++ b/src/openbox.cc @@ -4,7 +4,6 @@ # include "../config.h" #endif -#include "../version.h" #include "openbox.hh" #include "client.hh" #include "screen.hh" @@ -265,7 +264,7 @@ void Openbox::parseCommandLine(int argc, char **argv) void Openbox::showVersion() { - printf(_("Openbox - version %s\n"), OPENBOX_VERSION); + printf(_("Openbox - version %s\n"), VERSION); printf(" (c) 2002 - 2002 Ben Jansens\n\n"); } diff --git a/version.h.in b/version.h.in deleted file mode 100644 index 007f2f9d..00000000 --- a/version.h.in +++ /dev/null @@ -1 +0,0 @@ -#define OPENBOX_VERSION "@VERSION@" -- 2.45.2