X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/23475fc6e820f19c3fcdf8a6ba38ebbcb6275ee8..5f1600ab20e3f14e3330552b83976280c1049907:/configure.in diff --git a/configure.in b/configure.in index 76144b3..3579039 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.57) -AC_INIT(X3, 1.4, x2serv-general@lists.sourceforge.net) +AC_PREREQ(2.59) +AC_INIT([X3],[1.5],[evilnet-devel@lists.sourceforge.net]) CODENAME=X3 AC_CONFIG_HEADERS(src/config.h) AC_CONFIG_SRCDIR(src/opserv.c) @@ -20,11 +20,12 @@ AC_C_INLINE dnl Checks for programs. AC_PROG_AWK AC_PROG_CC -AC_PROG_RANLIB AC_PROG_INSTALL +AC_PROG_LIBTOOL AC_PROG_LN_S AC_PROG_MAKE_SET AC_PROG_GCC_TRADITIONAL +AC_CHECK_PROG(MAKER, gmake, gmake, make) dnl nice that unixes can all follow a standard. case $target in @@ -33,8 +34,6 @@ case $target in ;; *-freebsd3* | *-freebsdelf3* | *-freebsd*out3*) ANSI_SRC="" - AC_DEFINE(BROKEN_REGEX, 1, [Define if the system regex library is unreliable.]) - BROKEN_REGEX=yes ;; *-solaris*) EXTRA_DEFINE="-D__SOLARIS__" @@ -67,23 +66,28 @@ AC_HEADER_TIME AC_STRUCT_TM dnl Would rather not bail on headers, BSD has alot of the functions elsewhere. -Jedi -AC_CHECK_HEADERS(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 regex.h arpa/inet.h sys/mman.h sys/stat.h dirent.h,,) - -dnl Cygwin does not have d_type in struct dirent. We use stat() as a fallback. -AC_CHECK_MEMBER([struct dirent.d_type], - [AC_DEFINE(HAVE_DIRENT_D_TYPE, 1, [Define if struct dirent exists and includes the d_type element.])],,[#include ]) +AC_CHECK_HEADERS(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,,) dnl portability stuff, hurray! -Jedi +AC_CHECK_MEMBER([struct sockaddr.sa_len], + [AC_DEFINE([HAVE_SOCKADDR_SA_LEN],,[Define if struct sockaddr has sa_len field])], + [],[#include +#include ]) +AC_CHECK_MEMBER([struct addrinfo.ai_flags], + [AC_DEFINE([HAVE_STRUCT_ADDRINFO],,[Define if struct addrinfo declared])], + [],[#include +#include +#include ]) AC_CHECK_FUNCS(gettimeofday) if test $ac_cv_func_gettimeofday = no; then - AC_CHECK_FUNCS(ftime,,AC_MSG_ERROR([ftime or gettimeofday required. X3 build will fail.])) + AC_CHECK_FUNCS(ftime,,AC_MSG_ERROR([ftime or gettimeofday required. X3 build will fail.])) fi dnl We have fallbacks in case these are missing, so just check for them. -AC_CHECK_FUNCS(bcopy getpagesize memcpy memset strdup strerror strsignal localtime_r setrlimit inet_ntoa getopt getopt_long regcomp regexec regfree sysconf,,) - +AC_CHECK_FUNCS(freeaddrinfo getaddrinfo getnameinfo getpagesize memcpy memset strdup strerror strsignal localtime_r setrlimit getopt getopt_long sysconf,,) + dnl Check for absolutely required library functions. -AC_CHECK_FUNCS(select socket strcspn strspn strtod strtoul,,AC_MSG_ERROR([a required function was not found. X3 build will fail.])) +AC_CHECK_FUNCS(select socket strcspn strspn strtod strtoul,,AC_MSG_ERROR([a required function was not found. X3 build will fail.])) dnl Check for functions (and how to get them). AC_FUNC_ALLOCA @@ -97,6 +101,32 @@ if test $ac_cv_sin_len = yes ; then AC_DEFINE(HAVE_SIN_LEN, 1, [Define if struct sockaddr_in contains a sin_len field]) fi +dnl Check for socklen_t. In traditional BSD this is an int, but some +dnl OSes use a different type. Test until we find something that will +dnl work properly. Test borrowed from a patch submitted for Python. +AC_CHECK_TYPE([socklen_t], ,[ + AC_MSG_CHECKING([for socklen_t equivalent]) + AC_CACHE_VAL([curl_cv_socklen_t_equiv], + [ +dnl Systems have either "struct sockaddr*" or "void*" as second +dnl arg to getpeername. + curl_cv_socklen_t_equiv= + for arg2 in "struct sockaddr" void ; do + for t in int size_t unsigned long "unsigned long" ; do + AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include +#include +int getpeername (int $arg2 *, $t *);]], [[$t len; + getpeername(0, 0, &len);]])],[curl_cv_socklen_t_equiv="$t" + break],[]) + done + done + ]) + AC_MSG_RESULT($curl_cv_socklen_t_equiv) + AC_DEFINE_UNQUOTED(socklen_t, $curl_cv_socklen_t_equiv, + [type to use in place of socklen_t if not defined])], + [#include +#include]) + dnl Can only check with -Werror, but the rest of configure doesn't like -Werror OLD_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -W -Wall -Werror" @@ -159,11 +189,13 @@ AC_ARG_WITH(malloc, if test "x$withval" = "xsystem" ; then AC_MSG_RESULT(system) AC_DEFINE(WITH_MALLOC_SYSTEM, 1, [Define if using the system's malloc]) + x3_malloc="System" elif test "x$withval" = "xdmalloc" ; then AC_MSG_RESULT(dmalloc) AC_CHECK_HEADERS(dmalloc.h,,AC_MSG_ERROR([dmalloc header file missing. dmalloc build will fail.])) AC_CHECK_LIB(dmalloc,malloc,,AC_MSG_ERROR([dmalloc library is missing. dmalloc build will fail.])) AC_DEFINE(WITH_MALLOC_DMALLOC, 1, [Define if using the dmalloc debugging malloc package]) + x3_malloc="DMalloc" elif test "x$withval" = "xmpatrol" ; then AC_MSG_RESULT(mpatrol) AC_CHECK_HEADERS(mpatrol.h,,AC_MSG_ERROR([mpatrol header file missing. mpatrol build will fail.])) @@ -171,20 +203,24 @@ elif test "x$withval" = "xmpatrol" ; then AC_CHECK_LIB(elf, elf_begin) AC_CHECK_LIB(mpatrol,__mp_atexit,,AC_MSG_ERROR([mpatrol library is missing completely. mpatrol build will fail.])) AC_DEFINE(WITH_MALLOC_MPATROL, 1, [Define if using the mpatrol malloc debugging package]) + x3_malloc="MPatrol" elif test "x$withval" = "xboehm-gc" ; then AC_MSG_RESULT(boehm-gc) AC_CHECK_HEADERS(gc/gc.h,,AC_MSG_ERROR([Boehm GC header file missing. boehm-gc build will fail.])) AC_CHECK_LIB(dl, dlopen, , AC_MSG_ERROR([libdl library is missing. boehm-gc build will fail.])) AC_CHECK_LIB(gc, GC_gcollect, , AC_MSG_ERROR([Boehm GC library is missing. boehm-gc build will fail.])) AC_DEFINE(WITH_MALLOC_BOEHM_GC, 1, [Define if using the Boehm GC to garbage collect and check memory leaks]) + x3_malloc="Boehm" elif test "x$withval" = "xx3" ; then AC_MSG_RESULT(x3) - AC_DEFINE(WITH_MALLOC_X3, 1, [Define if using the x3 internal debug allocator]) + AC_DEFINE(WITH_MALLOC_X3, 1, [Define if using the X3 internal debug allocator]) MODULE_OBJS="$MODULE_OBJS alloc-x3.\$(OBJEXT)" + x3_malloc="X3" elif test "x$withval" = "xslab" ; then AC_MSG_RESULT(slab) AC_DEFINE(WITH_MALLOC_SLAB, 1, [Define if using the slab internal debug allocator]) MODULE_OBJS="$MODULE_OBJS alloc-slab.\$(OBJEXT)" + x3_malloc="Slab" else AC_MSG_ERROR([Unknown malloc type $withval]) fi @@ -198,12 +234,14 @@ AC_ARG_WITH(protocol, if test "x$withval" = "xp10" ; then AC_MSG_RESULT(P10) AC_DEFINE(WITH_PROTOCOL_P10, 1, [Define if using the P10 dialect of IRC]) - MODULE_OBJS="$MODULE_OBJS proto-p10.o" + MODULE_OBJS="$MODULE_OBJS proto-p10.\$(OBJEXT)" PROTO_FILES=proto-p10.c + x3_ircd="P10" elif test "x$withval" = "xbahamut" ; then AC_MSG_RESULT(Bahamut) AC_DEFINE(WITH_PROTOCOL_BAHAMUT, 1, [Define if using the Bahamut dialect of IRC]) - MODULE_OBJS="$MODULE_OBJS proto-bahamut.o" + MODULE_OBJS="$MODULE_OBJS proto-bahamut.\$(OBJEXT)" + x3_ircd="Bahamut" else AC_MSG_ERROR([Unknown IRC dialect $withval]) fi @@ -232,10 +270,12 @@ AC_ARG_ENABLE(debug, [ CPPFLAGS="$CPPFLAGS" AC_MSG_RESULT(yes) + x3_debug="Enabled" ], [ CPPFLAGS="$CPPFLAGS -DNDEBUG" AC_MSG_RESULT(no) + x3_debug="Disabled" ]) if test -e src ; then @@ -259,9 +299,12 @@ AC_ARG_ENABLE(modules, dnl Must use a separate file because autoconf can't stand newlines in an AC_SUBSTed variable. for module in $enableval ; do module=`echo $module | sed -e s/^mod-// -e s/\.c\$//` - EXTRA_MODULE_OBJS="$EXTRA_MODULE_OBJS mod-$module.o" + EXTRA_MODULE_OBJS="$EXTRA_MODULE_OBJS mod-$module.\$(OBJEXT)" module_list="$module_list $module" echo "WITH_MODULE($module)" >> $MODULE_DEFINES + if test "x$module" = "xtrack" ; then + TRACK="-D HAVE_TRACK" + fi done IFS="$OIFS" MODULE_OBJS="$MODULE_OBJS $EXTRA_MODULE_OBJS" @@ -285,10 +328,76 @@ if test "z$USE_MAINTAINER_MODE" = zyes ; then CFLAGS="$CFLAGS -Werror" fi +dnl REMEMBER TO CHANGE WITH A NEW TRE RELEASE! +tre_version="0.7.4" +AC_MSG_RESULT(extracting TRE regex library) +cur_dir=`pwd` +cd tools +dnl remove old tre directory to force a recompile... +rm -rf tre-$tre_version +if test "x$ac_cv_path_GUNZIP" = "x" ; then + tar xfz tre.tar.gz +else + cp tre.tar.gz tre.tar.gz.bak + gunzip -f tre.tar.gz + cp tre.tar.gz.bak tre.tar.gz + tar xf tre.tar +fi +AC_MSG_RESULT(configuring TRE regex library) +cd tre-$tre_version +./configure --disable-agrep --disable-shared --disable-system-abi --disable-wchar --disable-multibyte --prefix=$prefix || exit 1 +AC_MSG_RESULT(compiling TRE regex library) +$ac_cv_prog_MAKER || exit 1 +AC_MSG_RESULT(installing TRE regex library) +$ac_cv_prog_MAKER install || exit 1 +TREINCDIR="$prefix/include" +AC_SUBST(TREINCDIR) +if test "x$ac_cv_path_PKGCONFIG" = "x" ; then + TRELIBS="-L$prefix/lib -ltre" +else + TRELIBS=`$ac_cv_path_PKGCONFIG --libs tre.pc` +fi +AC_SUBST(TRELIBS) +cd $cur_dir + 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_CONFIG_FILES(Makefile rx/Makefile src/Makefile) AC_OUTPUT + + +dnl Print configuration summary + +cat <