X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/8da897110dbfa9fc6b742ecbb055368bc45b0f07..57e3ccf624ce817558c2601e17fca346dbad5b71:/configure.in diff --git a/configure.in b/configure.in index 0d4af16..6cc9feb 100644 --- a/configure.in +++ b/configure.in @@ -2,8 +2,8 @@ dnl Process this file with autoconf to create a configure script. dnl General initialization. AC_REVISION([$Id$]) -AC_PREREQ(2.60) -AC_INIT([X3],[1.5],[evilnet-devel@lists.sourceforge.net]) +AC_PREREQ(2.61) +AC_INIT([X3],[1.6],[evilnet-devel@lists.sourceforge.net]) CODENAME=X3 AC_CONFIG_HEADERS(src/config.h) AC_CONFIG_SRCDIR(src/opserv.c) @@ -70,7 +70,7 @@ AC_HEADER_TIME AC_STRUCT_TM dnl Would rather not bail on headers, BSD has alot of the functions elsewhere. -Jedi -AC_CHECK_HEADERS(GeoIP.h GeoIPCity.h fcntl.h tgmath.h malloc.h netdb.h netinet/in.h sys/resource.h sys/timeb.h sys/times.h sys/param.h sys/socket.h sys/time.h sys/types.h sys/wait.h unistd.h getopt.h memory.h arpa/inet.h sys/mman.h sys/stat.h dirent.h ,,) +AC_CHECK_HEADERS(GeoIP.h GeoIPCity.h fcntl.h math.h tgmath.h malloc.h netdb.h netinet/in.h sys/resource.h sys/timeb.h sys/times.h sys/param.h sys/socket.h sys/time.h sys/types.h sys/wait.h unistd.h getopt.h memory.h arpa/inet.h sys/mman.h sys/stat.h dirent.h ,,) dnl portability stuff, hurray! -Jedi AC_CHECK_MEMBER([struct sockaddr.sa_len], @@ -319,6 +319,11 @@ AC_ARG_ENABLE(modules, AC_MSG_RESULT(none) ]) +AC_ARG_ENABLE(python, +[ --disable-python don't build the python plugin], + python=$enableval, python=yes) + + MY_SUBDIRS="" RX_INCLUDES="" RX_LIBS="" @@ -379,18 +384,18 @@ AC_ARG_WITH(tre, PATH/lib/libtre.so and PATH/include/tre/regex.h exist.], ) if test "x$withval" != "x"; then AC_MSG_RESULT(Using include dir $withval to find libtre) - CPPFLAGS="-I$withval/include -L$withval/lib" + CPPFLAGS="$CPPFLAGS -I$withval/include -L$withval/lib" LIBS="$LIBS -L$withval/lib" else AC_MSG_RESULT([Looking for tre in system and home dirs (${HOME})...]) - CPPFLAGS="-I${HOME}/include -L${HOME}/lib" + CPPFLAGS="$CPPFLAGS -I${HOME}/include -L${HOME}/lib" LIBS="$LIBS -L${HOME}/lib" fi -AC_CHECK_HEADER(tre/regex.h, , [AC_MSG_ERROR([tre/regex.h, the TRE regex headers, were not found. Install tre or use --with-tre=PATH to tell me how to find it, where PATH/include/tre/regex.h exists. For conveniance, just type 'tools/tre_install.sh' now, to install tre in your home directory.])],) -AC_CHECK_LIB(tre, regexec, , [AC_MSG_ERROR([TRE regex library not found. Install tre, or use --with-tre=PATH to tell me how to find it, where PATH/lib/libtre.so exists. For conveniance, just type 'tools/tre_install.sh' now, to install tre in your home directory.])]) +AC_CHECK_HEADER(tre/regex.h, , [AC_MSG_ERROR([tre/regex.h, the TRE regex headers, were not found. Install tre or use --with-tre=PATH to tell me how to find it, where PATH/include/tre/regex.h exists. For convenience, just type 'tools/tre_install.sh' now, to install tre in your home directory.])],) +AC_CHECK_LIB(tre, regexec, , [AC_MSG_ERROR([TRE regex library not found. Install tre, or use --with-tre=PATH to tell me how to find it, where PATH/lib/libtre.so exists. For convenience, just type 'tools/tre_install.sh' now, to install tre in your home directory.])]) dnl core dumper checking -core_version="0.2" +core_version="1.1" withval='' AC_ARG_WITH(coredumper, [ --with-coredumper=PATH Base path to where core dumper is installed, such @@ -398,15 +403,50 @@ AC_ARG_WITH(coredumper, PATH/include/google/coredumper.h exist.], ) if test "x$withval" != "x"; then AC_MSG_RESULT(Using include dir $withval to find coredumper) - CPPFLAGS="-I$withval/include -L$withval/lib" + CPPFLAGS="$CPPFLAGS -I$withval/include -L$withval/lib" LIBS="$LIBS -L$withval/lib" else AC_MSG_RESULT([Looking for coredumper in system and home dirs (${HOME})...]) - CPPFLAGS="-I${HOME}/include -L${HOME}/lib" - LIBS="$LIBS -L${HOME}/lib" + CPPFLAGS="$CPPFLAGS -I${HOME}/include -L${HOME}/lib" + LIBS="$LIBS -Wl,--rpath -Wl,${HOME}/lib" fi -AC_CHECK_HEADER(google/coredumper.h, , [AC_MSG_RESULT([google/coredumper.h, the coredumper headers, were not found. Install coredumper or use --with-coredumper=PATH to tell me how to find it, where PATH/include/google/coredumper.h exists. For conveniance, just type 'tools/core_install.sh' now, to install coredumper in your home directory.])],) -AC_CHECK_LIB(coredumper, WriteCoreDump, , [AC_MSG_RESULT([Coredumper library not found. Install coredumper, or use --with-coredumper=PATH to tell me how to find it, where PATH/lib/libcoredumper.so exists. For conveniance, just type 'tools/core_install.sh' now, to install coredumper in your home directory.])]) +AC_CHECK_HEADER(google/coredumper.h, , [AC_MSG_RESULT([google/coredumper.h, the coredumper headers, were not found. Install coredumper or use --with-coredumper=PATH to tell me how to find it, where PATH/include/google/coredumper.h exists. For convenience, just type 'tools/core_install.sh' now, to install coredumper in your home directory.])],) +AC_CHECK_LIB(coredumper, WriteCoreDump, , [AC_MSG_RESULT([Coredumper library not found. Install coredumper, or use --with-coredumper=PATH to tell me how to find it, where PATH/lib/libcoredumper.so exists. For convenience, just type 'tools/core_install.sh' now, to install coredumper in your home directory.])]) + +dnl openssl checking +withval='' +AC_ARG_WITH(ssl, +[ --with-ssl=PATH Base path to where openssl is installed],) +if test "x$withval" != "x"; then + AC_MSG_RESULT(Using include dir $withval to find openssl) + CPPFLAGS="$CPPFLAGS -I$withval/include -L$withval/lib" + LIBS="$LIBS -L$withval/lib" +else + AC_MSG_RESULT([Looking for openssl in system ]) +fi + +AC_CHECK_LIB(ssl, BIO_new, +[ +LIBS="-lssl $LIBS" +AC_CHECK_HEADERS(openssl/bio.h, +[ +AC_DEFINE(WITH_SSL, 1, [Define if SSL libs are linked]) +ssl_message="LDAP library: enabled" +], +[ +if test "x$withval" != "x"; then + AC_MSG_ERROR([ssl headers not found]) +fi +]) +], +[ +if test "x$withval" != "x"; then + AC_MSG_ERROR([libldap not found or not valid]) +fi +] +) +AC_MSG_RESULT($LIBS) + dnl ldap checking withval='' @@ -421,32 +461,80 @@ else AC_MSG_RESULT([Looking for ldap in system ]) fi -AC_CHECK_LIB(ldap, ldap_init, +AC_CHECK_LIB(ldap, ldap_simple_bind_s, [ +LIBS="-lldap $LIBS" AC_CHECK_HEADERS(ldap.h, [ AC_DEFINE(WITH_LDAP, 1, [Define if LDAP libs are linked]) ldap_message="LDAP library: enabled" ], [ -if "x$withval" != "x"; then +if test "x$withval" != "x"; then AC_MSG_ERROR([ldap.h not found]) fi ]) ], [ -if "x$withval" != "x"; then +if test "x$withval" != "x"; then AC_MSG_ERROR([libldap not found or not valid]) fi ] ) +dnl ********************************************************************* +dnl ** PYTHON *********************************************************** +dnl ********************************************************************* + +if test "$python" = yes; then + AC_PATH_PROG(pythonpath, python2) + if test "_$pythonpath" = _ ; then + AC_PATH_PROG(pythonpath, python) + fi + if test "_$pythonpath" = _ ; then + python=no + else + AC_MSG_CHECKING(Python version) + changequote(<<, >>)dnl + PY_VER=`$pythonpath -c 'import distutils.sysconfig; print distutils.sysconfig.get_config_vars("VERSION")[0];'` + PY_LIB=`$pythonpath -c 'import distutils.sysconfig; print distutils.sysconfig.get_python_lib(standard_lib=1);'` + PY_INC=`$pythonpath -c 'import distutils.sysconfig; print distutils.sysconfig.get_config_vars("INCLUDEPY")[0];'` + $pythonpath -c "import sys; map(int,sys.version[:3].split('.')) >= [2,2] or sys.exit(1)" + changequote([, ])dnl + AC_MSG_RESULT($PY_VER) + if test "$?" != "1"; then + AC_MSG_CHECKING(Python compile flags) + PY_PREFIX=`$pythonpath -c 'import sys; print sys.prefix'` + PY_EXEC_PREFIX=`$pythonpath -c 'import sys; print sys.exec_prefix'` + if test -f $PY_INC/Python.h; then + AC_DEFINE(WITH_PYTHON, 1, [Define if using python]) + PY_LIBS="-L$PY_LIB/config -lpython$PY_VER -lpthread -lutil" + PY_CFLAGS="-I$PY_INC" + AC_MSG_RESULT(ok) + else + python=no + AC_MSG_RESULT([Can't find Python.h]) + fi + else + echo "Python too old. Only 2.2 or above is supported." + python=no + fi + fi +fi + +AM_CONDITIONAL(DO_PYTHON, test "x$python" = "xyes") + +AC_MSG_RESULT($LIBS) + AC_DEFINE_UNQUOTED(CODENAME, "${CODENAME}", [Code name for this release]) AC_SUBST(MODULE_OBJS) AC_SUBST(MY_SUBDIRS) AC_SUBST(RX_INCLUDES) AC_SUBST(RX_LIBS) AC_SUBST(TRACK) +AC_SUBST(PY_CFLAGS) +AC_SUBST(PY_LIBS) + AC_CONFIG_FILES(Makefile rx/Makefile src/Makefile) AC_OUTPUT @@ -479,6 +567,7 @@ X3 is now configured as follows: Regexp Library TRE $tre_version Coredumper Library Coredumper $core_version $ldap_message + python: $python Install to: $prefix