X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=configure.in;h=8492077a863f9e56ae6fcf25f2e56b1fcc4cc57d;hp=62cd8ec2ca0a8cd1431d422119c05f94c524556b;hb=174ad2c7bbf2b7312ac080de2fd85d0509a55404;hpb=a0da17360613c183107d78449bda31fcb97911fa diff --git a/configure.in b/configure.in index 62cd8ec..8492077 100644 --- a/configure.in +++ b/configure.in @@ -1,105 +1,27 @@ -dnl Zebra, Index Data Aps, 1994-2000 -dnl $Id: configure.in,v 1.21 2000-05-15 15:32:50 adam Exp $ +dnl Zebra, Index Data ApS, 1995-2005 +dnl $Id: configure.in,v 1.114 2005-01-15 21:43:40 adam Exp $ dnl -AC_INIT(include/zebraver.h) -AC_MSG_CHECKING(for package) -if test -r ${srcdir}/LICENSE.zmbol; then - AC_MSG_RESULT([Z'mbol]) - PROGPREFIX=zmbol - AC_DEFINE(ZMBOL,1) - AM_INIT_AUTOMAKE(zmbol,1.1) - SUBLIBS="../rset/librset.a \ - ../dict/libdict.a \ - ../isams/libisams.a \ - ../isam/libisam.a \ - ../isamc/libisamc.a \ - ../recctrl/librecctrl.a \ - ../bfile/libbfile.a \ - ../dfa/libdfa.a \ - ../util/libutil.a" -else - AC_MSG_RESULT([Zebra]) - PROGPREFIX=zebra - AC_DEFINE(ZMBOL,0) - AM_INIT_AUTOMAKE(zebra,1.1) - SUBLIBS="../rset/librset.a ../dict/libdict.a ../isams/libisams.a \ - ../recctrl/librecctrl.a \ - ../bfile/libbfile.a ../dfa/libdfa.a \ - ../util/libutil.a" - if test ! -r ${srcdir}/isam; then - mkdir ${srcdir}/isam - touch ${srcdir}/isam/Makefile.in - fi - if test ! -r ${srcdir}/isamc; then - mkdir ${srcdir}/isamc - touch ${srcdir}/isamc/Makefile.in - fi -fi -AM_CONDITIONAL(ISZMBOL,test $PACKAGE = zmbol) +AC_INIT(include/idzebra/version.h) +AM_INIT_AUTOMAKE(idzebra,1.4.0) dnl ------ Substitutions -AC_SUBST(SUBLIBS) -AC_SUBST(DEFS) AC_SUBST(TCL_INCLUDE) AC_SUBST(TCL_LIB) -AC_SUBST(YAZLIB) -AC_SUBST(YAZINC) -AC_SUBST(PROGPREFIX) +AC_SUBST(READLINE_LIBS) dnl dnl ------ Checking programs AC_PROG_CC AC_PROG_CPP -AC_PROG_INSTALL -AC_PROG_RANLIB -dnl -dnl ------ Look for Yaz -dnl See if user specified location of yaz-config; otherwise -dnl use ../yaz if is a directory (internal development); otherwise -dnl use yaz-config found in PATH. -yazconfig=NONE -yazpath=NONE -AC_ARG_WITH(yazconfig, [ --with-yazconfig=DIR yaz-config in DIR (example /home/yaz-1.5)], [yazpath=$withval]) -if test "x$yazpath" != "xNONE"; then - yazconfig=$yazpath/yaz-config -else - for i in ../yaz* ../yaz; do - if test -d $i; then - if test -r $i/yaz-config; then - yazconfig=$i/yaz-config - fi - fi - done - if test "x$yazconfig" = "xNONE"; then - AC_PATH_PROG(yazconfig, yaz-config, NONE) - fi -fi -AC_MSG_CHECKING(for YAZ) -if test -r $yazconfig; then - . $yazconfig - AC_MSG_RESULT($yazconfig) -else - AC_MSG_RESULT(Not found) -fi +AM_DISABLE_SHARED +AM_PROG_LIBTOOL dnl -dnl ------ Threads AC_ARG_ENABLE(threads, [ --disable-threads disable threads],[enable_threads=$enableval],[enable_threads=yes]) 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 + yazflag=threads +else + yazflag="" fi -dnl +YAZ_INIT($yazflag,2.0.29) +YAZ_DOC dnl ------ Look for Tcl dnl See if user has specified location of tclConfig.sh; otherwise dnl see if tclConfig.sh exists in same prefix lcoation as tclsh; otherwise @@ -113,6 +35,14 @@ if test "x$tclconfig" = xNONE; then AC_PREFIX_PROGRAM(tclsh) tclconfig=${prefix}/lib prefix=${saveprefix} + if test ! -r ${tclconfig}/tclConfig.sh; then + # Not found, try search for Tcl on Debian systems. + for d in /usr/lib/tcl*; do + if test -f $d/tclConfig.sh; then + tclconfig=$d + fi + done + fi fi AC_MSG_CHECKING(for Tcl) if test -r ${tclconfig}/tclConfig.sh; then @@ -120,10 +50,14 @@ if test -r ${tclconfig}/tclConfig.sh; then if test -r ${tclconfig}/../generic/tcl.h; then TCL_INCLUDE=-I${tclconfig}/../generic TCL_LIB="$TCL_BUILD_LIB_SPEC $TCL_LIBS" - else + elif test -d ${TCL_PREFIX}/include/tcl${TCL_VERSION}; then + TCL_INCLUDE=-I${TCL_PREFIX}/include/tcl${TCL_VERSION} + TCL_LIB="$TCL_LIB_SPEC $TCL_LIBS" + else TCL_INCLUDE=-I${TCL_PREFIX}/include TCL_LIB="$TCL_LIB_SPEC $TCL_LIBS" fi + TCL_LIB=`echo $TCL_LIB|sed 's%-L/usr/lib%%g'` SHLIB_CFLAGS=$TCL_SHLIB_CFLAGS SHLIB_LD=$TCL_SHLIB_LD SHLIB_SUFFIX=$TCL_SHLIB_SUFFIX @@ -138,28 +72,139 @@ dnl dnl ------ times AC_CHECK_HEADERS(sys/times.h) dnl +dnl ------ mkstemp +AC_CHECK_FUNCS(mkstemp) +dnl +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) + xLIBS=$LIBS + LIBS="$LIBS $READLINE_LIBS" + AC_TRY_LINK([ + #include + #include + ],[ + rl_attempted_completion_over = 0; + ],AC_DEFINE(HAVE_READLINE_COMPLETION_OVER)) + AC_TRY_LINK([ + #include + #include + ],[ + rl_completion_matches (0, 0); + ],AC_DEFINE(HAVE_READLINE_RL_COMPLETION_MATCHES)) + LIBS=$xLIBS +fi +dnl +dnl ------ iconv +AC_ARG_WITH(iconv, [ --with-iconv[=DIR] iconv library in DIR]) +if test "$with_iconv" != "no"; then + AC_MSG_CHECKING(for iconv) + oldLIBS="$LIBS" + oldCPPFLAGS="${CPPFLAGS}" + if test "$with_iconv" != "yes" -a "$with_iconv" != ""; then + LIBS="$LIBS -L${with_iconv}/lib" + CPPFLAGS="${CPPFLAGS} -I${with_iconv}/include" + fi + AC_TRY_LINK([ + #include + ],[ + iconv_t t = iconv_open("", ""); + ],[ + AC_DEFINE(HAVE_ICONV_H) + AC_MSG_RESULT(yes) + ],[ + LIBS="$LIBS -liconv" + AC_TRY_LINK([ + #include + ],[ + iconv_t t = iconv_open("", ""); + ],[ + AC_DEFINE(HAVE_ICONV_H) + AC_MSG_RESULT(yes) + ],[ + LIBS="$oldLIBS" + CPPFLAGS="$oldCPPFLAGS" + AC_MSG_RESULT(no) + ]) + ]) +fi +dnl dnl ------- BZIP2 AC_CHECK_LIB(bz2,bzCompressInit) if test "$ac_cv_lib_bz2_bzCompressInit" = "yes"; then AC_CHECK_HEADERS(bzlib.h) +else + AC_CHECK_LIB(bz2,BZ2_bzCompressInit) + if test "$ac_cv_lib_bz2_BZ2_bzCompressInit" = "yes"; then + AC_CHECK_HEADERS(bzlib.h) + fi +fi +dnl +dnl ------ -lm +AC_CHECK_LIB(m,sqrt) +dnl ------ -ldl +AC_CHECK_LIB(dl,dlopen) +dnl +dnl ------ EXPAT +expat=yes +AC_SUBST(EXPAT_LIBS) +AC_ARG_WITH(expat, [ --with-expat[=DIR] EXPAT library in DIR],[expat=$withval]) +if test "$expat" != "no"; then + xLIBS="$LIBS"; + xCFLAGS="$CFLAGS"; + if test "$expat" != "yes"; then + EXPAT_CFLAGS="-I$expat/include" + EXPAT_LIBS="-L$expat/lib" + CFLAGS="$EXPAT_CFLAGS $CFLAGS" + LIBS="$EXPAT_LIBS $LIBS" + fi + AC_CHECK_LIB(expat,XML_ParserCreate,[EXPAT_LIBS="$EXPAT_LIBS -lexpat"]) + if test "$ac_cv_lib_expat_XML_ParserCreate" = "yes"; then + AC_CHECK_HEADERS(expat.h) + fi + LIBS="$xLIBS" + CFLAGS="$xCFLAGS" fi +dnl dnl ------- 64 bit files -AC_MSG_CHECKING(for large files) +AC_MSG_CHECKING(for LFS) AC_TRY_RUN([#define _FILE_OFFSET_BITS 64 +#include #include #include #include +#include +#include int main(int argc, char **argv) { off_t o; char tmp_str[32]; - if (sizeof(off_t) == 8) { - o = 2000000000; - sprintf (tmp_str, "%Ld", o+o+o); - if (!strcmp (tmp_str, "6000000000")) - exit (0); - } - exit (1); + int fd; + struct flock area; + if (sizeof(off_t) != 8) + exit (1); + o = 2000000000; + sprintf (tmp_str, "%Ld", o+o+o); + if (strcmp (tmp_str, "6000000000")) + exit (1); + fd = creat ("config.tmp", 0644); + if (fd < 0) + exit (1); + area.l_type = F_WRLCK; + area.l_whence = SEEK_SET; + area.l_len = area.l_start = 0L; + if (fcntl(fd, F_SETLKW, &area)) + exit (1); + close (fd); + unlink ("config.tmp"); + exit (0); } ],bits=64,bits=32,bits=32) if test "$bits" = "64"; then @@ -168,12 +213,62 @@ if test "$bits" = "64"; then else AC_MSG_RESULT(no) fi -dnl +dnl ------ Modules +AC_SUBST(SHARED_MODULE_LA) +SHARED_MODULE_LA="" +AC_SUBST(STATIC_MODULE_OBJ) +STATIC_MODULE_OBJ="" +AC_SUBST(STATIC_MODULE_LADD) +STATIC_MODULE_LADD="" +AC_DEFUN([ZEBRA_MODULE],[ + AC_ARG_ENABLE(mod-$1,[$3],[myen=$enableval],[myen=$2]) + AC_MSG_CHECKING([for module $1]) + if test "$myen" = "yes"; then + myen="shared" + fi + if test "$enable_shared" != "yes"; then + if test "$myen" = "shared"; then + myen="static" + fi + fi + m=`echo $1|tr .- __` + if test "$myen" = "shared"; then + AC_MSG_RESULT([shared]) + SHARED_MODULE_LA="${SHARED_MODULE_LA} mod-$1.la" + elif test "$myen" = "static" -o "$myen" = "yes"; then + AC_MSG_RESULT([static]) + STATIC_MODULE_OBJ="${STATIC_MODULE_OBJ} \$(mod_${m}_la_OBJECTS)" + STATIC_MODULE_LADD="${STATIC_MODULE_LADD} \$(mod_${m}_la_LADD)" + modcpp=`echo $1|tr abcdefghijklmnopqrstuvwxyz- ABCDEFGHIJKLMNOPQRSTUVWXYZ_` + AC_DEFINE_UNQUOTED([IDZEBRA_STATIC_$modcpp]) + elif test "$myen" = "no"; then + AC_MSG_RESULT([disabled]) + else + AC_MSG_RESULT([bad value. Assuming disabled]) + fi +]) + +ZEBRA_MODULE(text,static, [ --enable-mod-text Text filter]) +ZEBRA_MODULE(grs-sgml,static,[ --enable-mod-grs-sgml Simple SGML/XML filter]) +ZEBRA_MODULE(grs-regx,shared,[ --enable-mod-grs-regx REGX/TCL filter]) +ZEBRA_MODULE(grs-marc,shared,[ --enable-mod-grs-marc MARC filter]) +ZEBRA_MODULE(grs-danbib,shared,[ --enable-mod-grs-danbib DanBib filter (DBC)]) +ZEBRA_MODULE(safari,shared,[ --enable-mod-safari Safari filter (DBC)]) +if test "$ac_cv_header_expat_h" = "yes"; then + def="shared" +else + def="no" +fi +ZEBRA_MODULE(grs-xml,[$def], [ --enable-mod-grs-xml XML filter (Expat based)]) dnl ------ ANSI C Header files AC_STDC_HEADERS if test "$ac_cv_header_stdc" = "no"; then AC_MSG_WARN(Your system doesn't seem to support ANSI C) fi +AC_SUBST(IDZEBRA_SRC_ROOT) +AC_SUBST(IDZEBRA_BUILD_ROOT) +IDZEBRA_SRC_ROOT=`cd ${srcdir}; pwd` +IDZEBRA_BUILD_ROOT=`pwd` dnl ------ Create Makefiles AC_OUTPUT([ Makefile @@ -181,14 +276,38 @@ AC_OUTPUT([ bfile/Makefile dfa/Makefile dict/Makefile + isamb/Makefile isams/Makefile isamc/Makefile - isam/Makefile rset/Makefile + data1/Makefile recctrl/Makefile index/Makefile - include/Makefile + include/Makefile include/idzebra/Makefile tab/Makefile doc/Makefile - test/Makefile test/gils/Makefile test/usmarc/Makefile -]) + doc/zebra.xml + doc/zebrahtml.dsl + doc/zebraprint.dsl + doc/zebraphp.dsl + doc/tkl.xsl + test/Makefile test/gils/Makefile test/usmarc/Makefile test/api/Makefile + test/xpath/Makefile + test/rusmarc/Makefile test/cddb/Makefile test/malxml/Makefile + test/mbox/Makefile + test/config/Makefile test/sort2/Makefile + test/xelm/Makefile + test/dmoz/Makefile test/sort/Makefile test/zsh/Makefile + test/marcxml/Makefile test/charmap/Makefile test/codec/Makefile + test/espec/Makefile + examples/Makefile examples/gils/Makefile examples/zthes/Makefile + examples/marc21/Makefile + idzebra.spec + idzebra-config + Doxyfile +],[sed s%idzebra_echo_source=yes%idzebra_echo_source=no%g < idzebra-config > util/idzebra-config && chmod +x idzebra-config util/idzebra-config]) +if test -z "$YAZLIB"; then + echo "YAZ was not found. Use --with-yaz=DIR to specify location." + test -f /etc/debian_version && echo "Debian package libyaz-dev is required." +fi +