X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=configure.in;h=16c7a515f668e93379f626745ca7b50ce10acb43;hp=bde016ac60e5cc7e1390ee6378e959bd6bf10cd7;hb=33a6eab614ca84eef817f675843e6de820d13708;hpb=8d363b42a1805306b5df26aac694a4491d5c9119 diff --git a/configure.in b/configure.in index bde016a..16c7a51 100644 --- a/configure.in +++ b/configure.in @@ -1,24 +1,45 @@ -dnl YAZ Toolkit -dnl (c) Index Data 1994-1999 +dnl YAZ Toolkit, Index Data 1994-2000 dnl See the file LICENSE for details. -dnl $Id: configure.in,v 1.10 1999-06-08 13:11:55 adam Exp $ -AC_INIT(include/yaz-version.h) +dnl $Id: configure.in,v 1.37 2000-10-11 10:40:56 adam Exp $ +AC_INIT(include/yaz/yaz-version.h) +AM_INIT_AUTOMAKE(yaz, 1.7) dnl +AC_SUBST(READLINE_LIBS) dnl ------ Checking programs AC_PROG_CC AC_PROG_CPP AC_PROG_INSTALL -AC_PROG_RANLIB -dnl -dnl ----- YC: The Yaz Compiler +AM_DISABLE_SHARED +AM_PROG_LIBTOOL +dnl +dnl ----- yaz-comp: The Yaz Compiler AC_SUBST(ASNMODULE) -AC_ARG_WITH(yc,[ --with-yc compile using YC: The Yaz Compiler], [YCDIR=$withval],[YCDIR=""]) -if test "$YCDIR" = "yes"; then +AC_SUBST(ILLMODULE) +AC_SUBST(ILLLIB) +AC_ARG_ENABLE(comp,[ --disable-comp use old encoders, i.e. disable the YAZ ASN.1 Compiler], , enable_comp=yes) +if test "$enable_comp" = "yes"; then ASNMODULE="z39.50" - cp -f include/z-proto.h include/proto.h + ILLMODULE="ill" + ILLLIB=../ill/libill.la + ASN_MAKEFILES="z39.50/Makefile ill/Makefile" + HFILE=${srcdir}/include/yaz/z-proto.h else + ILLMODULE="" ASNMODULE=asn - cp -f include/prt-proto.h include/proto.h + ILLLIB="" + ASN_MAKEFILES="asn/Makefile" + HFILE=${srcdir}/asn/prt-proto.h +fi +AC_MSG_CHECKING(whether proto.h needs to be generated) +yaz_include=${srcdir}/include/yaz +if test -r ${yaz_include}/proto.h && cmp -s $HFILE ${yaz_include}/proto.h; then + AC_MSG_RESULT(no) +else + AC_MSG_RESULT(yes) + cp -f $HFILE ${yaz_include}/proto.h + if test "$enable_comp" != "yes"; then + cp ${srcdir}/asn/*.h ${yaz_include} + fi fi dnl dnl ----- Sockets @@ -35,28 +56,44 @@ fi AC_CHECK_FUNC(gethostbyname, , AC_CHECK_LIB(nsl, main, [LIBS="$LIBS -lnsl"])) dnl dnl ------ GNU Readline -AC_CHECK_LIB(readline, readline, [LIBS="$LIBS -lreadline"]) -AC_CHECK_LIB(history, add_history, [LIBS="$LIBS -lhistory"]) +READLINE_LIBS="" +AC_CHECK_LIB(readline, readline, [READLINE_LIBS="$READLINE_LIBS -lreadline"]) +if test "$ac_cv_lib_readline_readline" = "no"; then + AC_CHECK_LIB(readline, readline, [READLINE_LIBS="$READLINE_LIBS -lreadline -ltermcap"]) +fi +AC_CHECK_LIB(history, add_history, [READLINE_LIBS="$READLINE_LIBS -lhistory"]) if test "$ac_cv_lib_readline_readline" = "yes"; then AC_CHECK_HEADERS(readline/readline.h readline/history.h) fi +dnl ------ snprintf +AC_CHECK_FUNCS(vsnprintf gettimeofday) dnl dnl ------ tcpd -AC_MSG_CHECKING(for working tcpd.h) -oldLibs=$LIBS -LIBS="$LIBS -lwrap" -AC_TRY_LINK([#include +AC_ARG_ENABLE(tcpd,[ --enable-tcpd[=PREFIX] enable TCP wrapper for server if available]) +if test "$enable_tcpd" != ""; then + oldLibs=$LIBS + oldCPPFLAGS=$CPPFLAGS + if test "$enable_tcpd" != "yes"; then + LIBS="$LIBS -L$enable_tcpd/lib" + CPPFLAGS="$CPPFLAGS -I$enable_tcpd/include" + fi + AC_MSG_CHECKING(for working tcpd.h) + LIBS="$LIBS -lwrap -lnsl" + AC_TRY_LINK([#include #include -int allow_severity = LOG_INFO; -int deny_severity = LOG_WARNING;], -[struct request_info request_info; int i; -i = hosts_access(&request_info);],tcpd_ok=1, tcpd_ok=0) -if test "$tcpd_ok" = "0"; then - AC_MSG_RESULT(no) - LIBS=$oldLibs -else - AC_MSG_RESULT(yes) - AC_DEFINE(HAVE_TCPD_H) + int allow_severity = LOG_INFO; + int deny_severity = LOG_WARNING;], + [struct request_info request_info; int i; + i = hosts_access(&request_info);], + tcpd_ok=1, tcpd_ok=0) + if test "$tcpd_ok" = "0"; then + AC_MSG_RESULT(no) + LIBS=$oldLibs + CPPFLAGS=$oldCPPFLAGS + else + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_TCPD_H) + fi fi dnl dnl ------ Headers @@ -66,16 +103,56 @@ if test "$ac_cv_header_stdc" = "no"; then fi dnl dnl ------ Threads -AC_ARG_ENABLE(threads, [ --enable-threads enable threads if available], - [threads_ok=$enableval], [threads_ok=no]) -if test "$threads_ok" = "yes"; then - AC_CHECK_HEADERS(pthread.h threads.h) - AC_CHECK_FUNC(pthread_mutex_lock) - if test "$ac_cv_func_pthread_mutex_lock" = "no"; then - AC_CHECK_LIB(pthread, main) +AC_ARG_ENABLE(threads, [ --enable-threads enable POSIX threads],[enable_threads=$enableval],[enable_threads=no]) +if test "$enable_threads" = "yes"; then + AC_CHECK_LIB(pthread,main) + AC_MSG_CHECKING(for working POSIX Threads) + AC_TRY_LINK([#include + int func(void *p) { return 0; } + ],[ + pthread_t pthread_id; + int r = pthread_create (&pthread_id, 0, func, 0);], + thread_ok=yes,thread_ok=no) + if test "$thread_ok" = "yes"; then + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_PTHREAD_H) + AC_DEFINE(_REENTRANT) + else + AC_MSG_RESULT(no) fi - AC_DEFINE(_REENTRANT) fi +dnl ------ Using this for "in-source" yaz-config +AC_SUBST(YAZ_SRC_ROOT) +YAZ_SRC_ROOT=`pwd` +dnl +SUBDIRS_VAR="util odr $ASNMODULE $ILLMODULE zutil comstack ccl tab retrieval server include lib client ztest" +AC_SUBST(SUBDIRS_VAR) +if test -f lib/yaz-config.in; then + rm lib/yaz-config.in +fi +sed s%yaz_echo_source=yes%yaz_echo_source=no%g < yaz-config.in >lib/yaz-config.in dnl dnl ------ Makefiles -AC_OUTPUT(Makefile util/Makefile odr/Makefile z39.50/Makefile asn/Makefile zutil/Makefile comstack/Makefile client/Makefile server/Makefile ztest/Makefile retrieval/Makefile ccl/Makefile lib/Makefile rfc1006/Makefile) +dnl +AC_OUTPUT([ +Makefile +util/Makefile +odr/Makefile +z39.50/Makefile +asn/Makefile +ill/Makefile +zutil/Makefile +comstack/Makefile +ccl/Makefile +tab/Makefile +retrieval/Makefile +server/Makefile +include/Makefile +include/yaz/Makefile +lib/Makefile +client/Makefile +ztest/Makefile +doc/Makefile +yaz-config +lib/yaz-config +],[chmod +x yaz-config lib/yaz-config])