Version 1.3.50.
[idzebra-moved-to-github.git] / configure.in
index 34f28e9..87559f1 100644 (file)
@@ -1,11 +1,21 @@
-dnl Zebra, Index Data Aps, 1995-2002
-dnl $Id: configure.in,v 1.48 2002-09-13 09:24:16 adam Exp $
+dnl Zebra, Index Data Aps, 1995-2007
+dnl $Id: configure.in,v 1.91.2.36 2007-10-16 10:10:37 adam Exp $
 dnl
 AC_INIT(include/zebraver.h)
-AM_INIT_AUTOMAKE(idzebra,1.3.2)
+AM_INIT_AUTOMAKE(idzebra,1.3.50)
+PACKAGE_SUFFIX="-1.3"
+AC_SUBST(PACKAGE_SUFFIX)
 dnl ------ Substitutions
 AC_SUBST(TCL_INCLUDE)
 AC_SUBST(TCL_LIB)
+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
@@ -13,63 +23,16 @@ AC_PROG_CPP
 AC_PROG_INSTALL
 AC_PROG_RANLIB
 dnl
-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.64 \
-            /usr/share/sgml/docbook/dsssl-stylesheets-1.59 \
-            /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
-AC_ARG_ENABLE(threads, [  --disable-threads       disable threads],[enable_threads=$enableval],[enable_threads=yes])
+dnl ------ threads
+AC_ARG_ENABLE(threads, [  --disable-threads       disable threads],[enable_threa
+ds=$enableval],[enable_threads=yes])
 if test "$enable_threads" = "yes"; then
        yazflag=threads
 else
        yazflag=""
 fi
-YAZ_INIT($yazflag)
-
+YAZ_INIT($yazflag,2.0.18)
+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
@@ -105,35 +68,93 @@ if test -r ${tclconfig}/tclConfig.sh; then
                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)
-       AC_DEFINE(HAVE_TCL_H,1)
+
+       old_CPPFLAGS=$CPPFLAGS
+       CPPFLAGS="${TCL_INCLUDE} $CPPFLAGS"
+       AC_CHECK_HEADERS(tcl.h)
+       CPPFLAGS=${old_CPPFLAGS}
 else
         AC_MSG_RESULT(Not found)
        AC_DEFINE(HAVE_TCL_H,0)
 fi
 dnl
 dnl ------ times
-AC_CHECK_HEADERS(sys/times.h)
+AC_CHECK_HEADERS(sys/times.h sys/time.h)
+dnl
+dnl ------ crypt
+AC_CHECK_LIB(crypt, crypt)
+if test "$ac_cv_lib_crypt_crypt" = "yes"; then
+       AC_CHECK_HEADERS(crypt.h)
+fi
 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 <stdio.h>
+        #include <readline/readline.h>
+        ],[ 
+               rl_attempted_completion_over = 0;
+        ],AC_DEFINE(HAVE_READLINE_COMPLETION_OVER))
+        AC_TRY_LINK([
+        #include <stdio.h>
+        #include <readline/readline.h>
+        ],[
+                rl_completion_matches (0, 0);
+        ],AC_DEFINE(HAVE_READLINE_RL_COMPLETION_MATCHES))
+        LIBS=$xLIBS
+fi
+dnl
 dnl ------ iconv
-AC_CHECK_FUNCS(iconv_open)
-if test "$ac_cv_func_iconv_open" = "no"; then
-       oldLibs=$LIBS
-       LIBS="$LIBS -liconv"
-       AC_CHECK_FUNCS(iconv_open)
-       if test "$ac_cv_func_iconv_open" = "no"; then
-               LIBS=$oldLibs
+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
-fi
-if test "$ac_cv_func_iconv_open" = "yes"; then
-        AC_CHECK_HEADERS(iconv.h)
+       AC_TRY_LINK([
+               #include <iconv.h>
+       ],[
+               iconv_t t = iconv_open("", "");
+       ],[
+               AC_DEFINE(HAVE_ICONV_H)
+               AC_MSG_RESULT(yes)
+       ],[
+               LIBS="$LIBS -liconv"
+               AC_TRY_LINK([
+                       #include <iconv.h>
+               ],[
+                       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
@@ -147,9 +168,12 @@ else
        fi
 fi
 dnl
+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])
+AC_ARG_WITH(expat,   [  --with-expat[=DIR]        EXPAT library in DIR],[expat=$withval])
 if test "$expat" != "no"; then
        xLIBS="$LIBS";
        xCFLAGS="$CFLAGS";
@@ -167,6 +191,91 @@ if test "$expat" != "no"; then
                CFLAGS="$xCFLAGS"
        fi
 fi
+dnl
+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 <stdio.h>
+             ],[
+            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
@@ -185,9 +294,8 @@ int main(int argc, char **argv)
        if (sizeof(off_t) != 8) 
                exit (1);
        o = 2000000000;
-       sprintf (tmp_str, "%Ld", o+o+o);
-       if (strcmp (tmp_str, "6000000000"))
-               exit (1);
+       if ((o+o+o) / 3 != o)
+               exit(1);
        fd = creat ("config.tmp", 0644);
        if (fd < 0)
                exit (1);
@@ -225,7 +333,9 @@ AC_OUTPUT([
   isamc/Makefile
   isam/Makefile
   rset/Makefile
+  data1/Makefile
   recctrl/Makefile
+  recctrl/perlread.h
   index/Makefile
   include/Makefile
   tab/Makefile
@@ -234,6 +344,22 @@ AC_OUTPUT([
   doc/zebrahtml.dsl
   doc/zebraprint.dsl
   doc/zebraphp.dsl
+  doc/tkl.xsl
   test/Makefile test/gils/Makefile test/usmarc/Makefile test/api/Makefile
-  test/dmoz/Makefile
+  test/rusmarc/Makefile test/cddb/Makefile test/malxml/Makefile 
+  test/config/Makefile test/sort2/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
+  examples/mail/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-yaz=DIR to specify location."
+       test -f /etc/debian_version && echo "Debian package libyaz-dev is required."
+fi
+