X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=configure.in;h=cd227755797b0ef3b2b75155d749d12a33ce3a93;hp=ae77ec47aa71535ef08568231dfb47e2b7e8ef38;hb=7057699040b614f56be178f3672b4a2b95301d5f;hpb=7acd51b7cdffca5ad92a777d2c6e8e9bae1f9fd3 diff --git a/configure.in b/configure.in index ae77ec4..cd22775 100644 --- a/configure.in +++ b/configure.in @@ -1,10 +1,10 @@ -dnl YAZ Toolkit -dnl (c) Index Data 1994-2000 +dnl YAZ Toolkit, Index Data 1994-2001 dnl See the file LICENSE for details. -dnl $Id: configure.in,v 1.25 2000-04-05 07:39:54 adam Exp $ +dnl $Id: configure.in,v 1.44 2001-04-06 12:26:46 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 @@ -13,30 +13,43 @@ AM_DISABLE_SHARED AM_PROG_LIBTOOL dnl dnl ----- yaz-comp: The Yaz Compiler -AC_SUBST(ASNMODULE) -AC_SUBST(ILLMODULE) -AC_SUBST(ILLLIB) +AC_SUBST(EXTRAMODULE) +AC_SUBST(EXTRALIB) 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" - ILLMODULE="ill" - ILLLIB=../ill/libill.la - ASN_MAKEFILES="z39.50/Makefile ill/Makefile" - HFILE=z-proto.h + EXTRAMODULE="z39.50" + HFILE=${srcdir}/include/yaz/z-proto.h else - ILLMODULE="" - ASNMODULE=asn - ILLLIB="" - ASN_MAKEFILES="asn/Makefile" - HFILE=prt-proto.h + EXTRAMODULE=asn + HFILE=${srcdir}/asn/prt-proto.h fi +AC_ARG_ENABLE(modules,[ --enable-modules=\"mod ..\" ill],[ +if test "$enable_modules" != "no"; then + EXTRAMODULE="$EXTRAMODULE $enable_modules" +fi +],[ +EXTRAMODULE="$EXTRAMODULE ill ccl" +]) +EXTRALIB="" +echo $EXTRAMODULE +for module in $EXTRAMODULE; do + EXTRALIB="$EXTRALIB ../$module/lib${module}.la" + if test $module = "z39.50"; then + module=z3950 + fi + AC_DEFINE_UNQUOTED(YAZ_MODULE_${module}) +done + AC_MSG_CHECKING(whether proto.h needs to be generated) yaz_include=${srcdir}/include/yaz -if test -e ${yaz_include}/proto.h && cmp -s ${yaz_include}/$HFILE ${yaz_include}/proto.h; then +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 ${yaz_include}/$HFILE ${yaz_include}/proto.h + cp -f $HFILE ${yaz_include}/proto.h + if test "$enable_comp" != "yes"; then + cp ${srcdir}/asn/*.h ${yaz_include} + fi fi dnl dnl ----- Sockets @@ -52,33 +65,52 @@ if test "$checkBoth" = "1"; then 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"]) -if test "$ac_cv_lib_readline_readline" = "no"; then - AC_CHECK_LIB(readline, readline, [LIBS="$LIBS -lreadline -ltermcap"]) +dnl ------ Open SSL +openssl=no +AC_ARG_WITH(openssl, [ --with-openssl[=DIR] OpenSSL library in DIR], [openssl=$withval]) +if test "$openssl" = "yes"; then + AC_CHECK_LIB(crypto, main) + AC_CHECK_LIB(ssl, SSL_new) + if test "$ac_cv_lib_ssl_SSL_new" = "yes"; then + AC_CHECK_HEADERS(openssl/ssl.h) + fi fi -AC_CHECK_LIB(history, add_history, [LIBS="$LIBS -lhistory"]) +dnl ------ GNU Readline +READLINE_SHARED_LIBADD="" +AC_CHECK_LIB(ncurses, tgetent, [READLINE_SHARED_LIBADD="-lncurses"], + AC_CHECK_LIB(termcap, tgetent, [READLINE_SHARED_LIBADD="-ltermcap"]) +) +READLINE_LIBS="" +AC_CHECK_LIB(readline, readline, [READLINE_LIBS="$READLINE_LIBS -lreadline $READLINE_SHARED_LIBADD"],,$READLINE_SHARED_LIBADD) +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) +AC_CHECK_FUNCS(vsnprintf gettimeofday) dnl dnl ------ tcpd -AC_ARG_ENABLE(tcpd,[ --enable-tcpd enable TCP wrapper for server if available]) -if test "$enable_tcpd" = "yes"; then - AC_MSG_CHECKING(for working tcpd.h) +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 +#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) + 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) @@ -92,28 +124,64 @@ if test "$ac_cv_header_stdc" = "no"; then fi dnl dnl ------ Threads -AC_ARG_ENABLE(threads, [ --disable-threads disable threads],[enable_threads=$enableval],[enable_threads=yes]) +AC_ARG_ENABLE(threads, [ --disable-threads disable POSIX threads],[enable_threads=$enableval],[enable_threads=yes]) +AC_SUBST(LIBTHREAD) if test "$enable_threads" = "yes"; then + OLIBS=$LIBS AC_CHECK_LIB(pthread,main) AC_MSG_CHECKING(for working POSIX Threads) AC_TRY_LINK([#include - int func(void *p) { return 0; } + void *func(void *p) { return 0; } ],[ pthread_t pthread_id; - int r = pthread_create (&pthread_id, 0, func, 0);], + pthread_create (&pthread_id, 0, func, 0);], thread_ok=yes,thread_ok=no) if test "$thread_ok" = "yes"; then + LIBTHREAD=-lpthread AC_MSG_RESULT(yes) - AC_DEFINE(HAVE_PTHREAD_H) - AC_DEFINE(_REENTRANT) + HAVETHREADS=1 else + LIBTHREAD="" AC_MSG_RESULT(no) + HAVETHREADS=0 fi + LIBS=$OLIBS fi +AM_CONDITIONAL(ISTHR, test $HAVETHREADS = "1") +dnl ------ Using this for "in-source" yaz-config +AC_SUBST(YAZ_SRC_ROOT) +AC_SUBST(YAZ_BUILD_ROOT) +YAZ_SRC_ROOT=`cd ${srcdir}; pwd` +YAZ_BUILD_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 ${srcdir}/lib/yaz-config.in; then + rm ${srcdir}/lib/yaz-config.in +fi +sed s%yaz_echo_source=yes%yaz_echo_source=no%g < ${srcdir}/yaz-config.in >${srcdir}/lib/yaz-config.in dnl +SUBDIRS_VAR="util odr $EXTRAMODULE zutil comstack tab retrieval server include lib client ztest" +AC_SUBST(SUBDIRS_VAR) dnl ------ Makefiles 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) +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])