X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=configure.in;h=23b9844f6054acc87487a05425bca7401e9fde01;hp=7d7d07446a7b30597e1c4f7e6ae5c8f196326429;hb=cb007c6145b0dbb3fcbe9826f081650becf9a05c;hpb=a1cb24becf02389d1a084d513bb57f6cdf6e82f0 diff --git a/configure.in b/configure.in index 7d7d074..23b9844 100644 --- a/configure.in +++ b/configure.in @@ -1,18 +1,20 @@ -dnl Zebra, Index Data Aps, 1994-1999 -dnl $Id: configure.in,v 1.16 2000-03-01 10:02:04 adam Exp $ -dnl See the file LICENSE.2 for details. +dnl Zebra, Index Data Aps, 1995-2004 +dnl $Id: configure.in,v 1.94 2004-08-24 10:37:18 adam Exp $ dnl AC_INIT(include/zebraver.h) +AM_INIT_AUTOMAKE(idzebra,1.4.0) +AM_PROG_LIBTOOL dnl ------ Substitutions -AC_SUBST(ODEFS) -AC_SUBST(DEFS) AC_SUBST(TCL_INCLUDE) AC_SUBST(TCL_LIB) -AC_SUBST(YAZLIB) -AC_SUBST(YAZINC) -AC_SUBST(SUBDIR) -AC_SUBST(SUBLIBS) -AC_SUBST(PROGPREFIX) +AC_SUBST(READLINE_LIBS) +dnl ------ Perl substitutions +AC_SUBST(PERL_BINARY) +AC_SUBST(PERL_XS_INIT) +AC_SUBST(PERL_XS_INIT_INCLUDE) +AC_SUBST(PERL_LIBS) +AC_SUBST(PERL_CFLAGS) +AC_SUBST(ZPERL_LIBS) dnl dnl ------ Checking programs AC_PROG_CC @@ -20,46 +22,61 @@ AC_PROG_CPP AC_PROG_INSTALL AC_PROG_RANLIB dnl -dnl ------ Create sub directory lib/bin -if test ! -d lib; then - mkdir lib -fi -if test ! -d bin; then - mkdir bin -fi -dnl ------ Build root -AC_SUBST(build_root) -AC_ARG_WITH(build-root, [ --with-buildroot RPM Build root],[build_root=$withval],[build_root=""]) +dnl ----- DOCBOOK DTD +AC_SUBST(DTD_DIR) +AC_ARG_WITH(dtd, [ --with-dtd[=DIR] Use docbookx.dtd in DIR], +[ + if test -f "$withval/docbookx.dtd"; then + DTD_DIR=$withval + fi +],[ + AC_MSG_CHECKING(for docbookx.dtd) + for d in /usr/share/sgml/docbook/dtd/xml/4.1.2 \ + /usr/share/sgml/docbook/xml-dtd-4.1.2* \ + /usr/share/sgml/docbook/xml-dtd-4.1 \ + /usr/share/sgml/docbook/dtd/xml/4.0 \ + /usr/lib/sgml/dtd/docbook-xml + do + if test -f $d/docbookx.dtd; then + AC_MSG_RESULT($d) + DTD_DIR=$d + break + fi + done + if test -z "$DTD_DIR"; then + AC_MSG_RESULT(Not found) + fi +]) +AC_SUBST(DSSSL_DIR) +AC_ARG_WITH(dsssl,[ --with-dsssl[=DIR] Use DSSSL in DIR/{html,print}/docbook.dsl], +[ + if test -f "$withval/html/docbook.dsl"; then + DSSSL_DIR=$withval + fi +],[ + AC_MSG_CHECKING(for docbook.dsl) + for d in /usr/share/sgml/docbook/stylesheet/dsssl/modular \ + /usr/share/sgml/docbook/dsssl-stylesheets-1.* \ + /usr/lib/sgml/stylesheet/dsssl/docbook/nwalsh + do + if test -f $d/html/docbook.dsl; then + AC_MSG_RESULT($d) + DSSSL_DIR=$d + break + fi + done + if test -z "$DSSSL_DIR"; then + AC_MSG_RESULT(Not found) + fi +]) 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 +AC_ARG_ENABLE(threads, [ --disable-threads disable threads],[enable_threads=$enableval],[enable_threads=yes]) +if test "$enable_threads" = "yes"; then + yazflag=threads 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 + yazflag="" fi -AC_MSG_CHECKING(for YAZ) -if test -r $yazconfig; then - . $yazconfig - AC_MSG_RESULT($yazconfig) -else - AC_MSG_RESULT(Not found) -fi -dnl +YAZ_INIT($yazflag) 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 @@ -73,6 +90,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 @@ -80,54 +105,300 @@ 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 SHLIB_VERSION=$TCL_SHLIB_VERSION AC_MSG_RESULT($TCL_VERSION) - ODEFS="-DHAVE_TCL_H=1" + AC_DEFINE(HAVE_TCL_H,1) else AC_MSG_RESULT(Not found) - ODEFS="-DHAVE_TCL_H=0" + AC_DEFINE(HAVE_TCL_H,0) fi 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 + ],[ + static void f() + { + rl_attempted_completion_over = 0; + } + ],AC_DEFINE(HAVE_READLINE_COMPLETION_OVER)) + AC_TRY_LINK([ + #include + #include + ],[ + static void f() + { + 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 + ],[ + static void f() {iconv_t t = iconv_open("", ""); } + ],[ + AC_DEFINE(HAVE_ICONV_H) + AC_MSG_RESULT(yes) + ],[ + LIBS="$LIBS -liconv" + AC_TRY_LINK([ + #include + ],[ + static void f() {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 ------ 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) +dnl ------ -lm +AC_CHECK_LIB(m,sqrt) +dnl +dnl ------ EXPAT +expat=yes +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,[LIBS="$LIBS -lexpat"]) + if test "$ac_cv_lib_expat_XML_ParserCreate" = "yes"; then + AC_CHECK_HEADERS(expat.h) + else + LIBS="$xLIBS" + CFLAGS="$xCFLAGS" + fi fi dnl -dnl ------ Is it Zebra or Z'mbol -if test -r LICENSE.zmbol; then - AC_DEFINE(ZMBOL,1) - PROGPREFIX=zmbol - SUBDIR="util bfile dfa dict isams isamc isam rset recctrl index" - SUBMAKE="Makefile util/Makefile bfile/Makefile dfa/Makefile dict/Makefile isams/Makefile isamc/Makefile isam/Makefile rset/Makefile recctrl/Makefile index/Makefile" - SUBLIBS="../lib/rset.a ../lib/dict.a ../lib/isams.a ../lib/isam.a\ - ../lib/recctrl.a ../lib/isamc.a ../lib/bfile.a ../lib/dfa.a\ - ../lib/zebrautl.a" +dnl ------ PERL +AM_CONDITIONAL(perl,false) +perl=no +PERL_XS_INIT="NULL" +PERL_XS_INIT_INCLUDE='' +PERL_BINARY="" +AC_ARG_WITH(perl, [ --with-perl[=FILE] perl binary location],[perl=$withval]) +if test "$perl" != "no"; then + AC_MSG_CHECKING(for perl binary) + if test "$perl" = "yes"; then + perlbin=`which perl` + else + perlbin="$perl" + fi + if test -x "$perlbin"; then + AC_MSG_RESULT($perlbin) + AC_MSG_CHECKING(perl core directory) + archdir=`$perlbin -MConfig -e 'print $Config{archlib}'`; + perlcore="$archdir/CORE"; + if test -d "$perlcore"; then + PERL_BINARY="$perlbin" + AC_MSG_RESULT($perlcore) + else + AC_MSG_RESULT(Failed) + fi + + AC_MSG_CHECKING("for ExtUtils::Embed to determine ccopts") + PERL_CFLAGS=`$perlbin -MExtUtils::Embed -e ccopts 2>/dev/null` + if test "$PERL_CFLAGS"; then + AC_MSG_RESULT(OK) + else + PERL_CFLAGS="-I$perlcore" + AC_MSG_RESULT(Using defaults) + fi + + AC_MSG_CHECKING("for ExtUtils::Embed to determine ldflags") + PERL_LIBS=`$perlbin -MExtUtils::Embed -e ldopts 2>/dev/null` + if test "$PERL_LIBS"; then + AC_MSG_RESULT(OK) + else + PERL_LIBS="-L$perlcore -lperl -lm" + AC_MSG_RESULT(Using defaults) + fi + + AC_MSG_CHECKING("for ExtUtils::Embed to create xs_init") + xsf="recctrl/xsinit.h" + `rm $xsf 2>/dev/null`; + + `$perlbin -MExtUtils::Embed -e xsinit -- -o $xsf 2>/dev/null` + if test -r "$xsf"; then + AC_MSG_RESULT(OK) + PERL_XS_INIT="xs_init" + PERL_XS_INIT_INCLUDE='#include "xsinit.h"' + else + AC_MSG_RESULT(XS libraries are not going to be available) + fi + + xLIBS="$LIBS" + xCFLAGS="$CFLAGS" + CFLAGS="$PERL_CFLAGS $CFLAGS" + LIBS="$PERL_LIBS $LIBS" + + AC_MSG_CHECKING(for perl library) + AC_TRY_LINK([ + #include + ],[ + static void f() + { + ; + } + ],AM_CONDITIONAL(perl,true) + AC_DEFINE(HAVE_PERL,1) + AC_MSG_RESULT(found) + ZPERL_LIBS="$xLIBS" + , + AC_MSG_RESULT(not found) + AC_DEFINE(HAVE_PERL,0) + LIBS="$xLIBS" + CFLAGS="$xCFLAGS") + else + AC_DEFINE(HAVE_PERL,0) + AC_MSG_RESULT(Not found) + fi +fi +dnl ------- 64 bit 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]; + 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 + AC_DEFINE(_FILE_OFFSET_BITS,64) + AC_MSG_RESULT(yes) else - PROGPREFIX=zebra - SUBDIR="util bfile dfa dict isams rset recctrl index" - SUBMAKE="Makefile util/Makefile bfile/Makefile dfa/Makefile dict/Makefile isams/Makefile rset/Makefile recctrl/Makefile index/Makefile" - SUBLIBS="../lib/rset.a ../lib/dict.a ../lib/isams.a\ - ../lib/recctrl.a ../lib/bfile.a ../lib/dfa.a\ - ../lib/zebrautl.a" - AC_DEFINE(ZMBOL,0) + AC_MSG_RESULT(no) fi dnl +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 dnl ------ Create Makefiles -AC_OUTPUT($SUBMAKE) +AC_OUTPUT([ + Makefile + util/Makefile + bfile/Makefile + dfa/Makefile + dict/Makefile + isamb/Makefile + isams/Makefile + isamc/Makefile + rset/Makefile + data1/Makefile + recctrl/Makefile + recctrl/perlread.h + index/Makefile + include/Makefile + tab/Makefile + doc/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/rusmarc/Makefile test/cddb/Makefile test/malxml/Makefile + test/config/Makefile + perl/Makefile.PL test/xelm/Makefile + test/dmoz/Makefile test/xpath/Makefile test/sort/Makefile test/zsh/Makefile + test/marcxml/Makefile test/charmap/Makefile test/codec/Makefile + examples/Makefile examples/gils/Makefile examples/zthes/Makefile + idzebra.spec +]) +if test -x "$perlbin"; then + res=`cd perl ; $perlbin Makefile.PL ; cd .. ;`; +fi +if test -z "$YAZLIB"; then + echo "YAZ was not found. Use --with-yazconfig=DIR to specify location." + test -f /etc/debian_version && echo "Debian package libyaz-dev is required." +fi +