-dnl Zebra, Index Data Aps, 1995-2002
-dnl $Id: configure.in,v 1.61 2002-12-30 10:25:24 adam Exp $
+dnl Zebra, Index Data Aps, 1995-2004
+dnl $Id: configure.in,v 1.102 2004-09-28 08:44:48 adam Exp $
dnl
-AC_INIT(include/zebraver.h)
-AM_INIT_AUTOMAKE(idzebra,1.3.4)
+AC_INIT(include/idzebra/version.h)
+AM_INIT_AUTOMAKE(idzebra,1.4.0)
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)
dnl ------ Checking programs
AC_PROG_CC
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.* \
- /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
-])
+AM_DISABLE_SHARED
+AM_PROG_LIBTOOL
dnl
AC_ARG_ENABLE(threads, [ --disable-threads disable threads],[enable_threads=$enableval],[enable_threads=yes])
if test "$enable_threads" = "yes"; then
yazflag=""
fi
YAZ_INIT($yazflag)
-
+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
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
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_ARG_WITH(iconv, [ --with-iconv[=DIR] iconv library in DIR])
+AC_ARG_WITH(iconv, [ --with-iconv[=DIR] iconv library in DIR])
if test "$with_iconv" != "no"; then
AC_MSG_CHECKING(for iconv)
oldLIBS="$LIBS"
AC_TRY_LINK([
#include <iconv.h>
],[
- static void f() {iconv_t t = iconv_open("", ""); }
+ iconv_t t = iconv_open("", "");
],[
AC_DEFINE(HAVE_ICONV_H)
AC_MSG_RESULT(yes)
AC_TRY_LINK([
#include <iconv.h>
],[
- static void f() {iconv_t t = iconv_open("", ""); }
+ iconv_t t = iconv_open("", "");
],[
AC_DEFINE(HAVE_ICONV_H)
AC_MSG_RESULT(yes)
fi
fi
dnl
+dnl ------ -lm
+AC_CHECK_LIB(m,sqrt)
+dnl ------ -ldl
+AC_CHECK_LIB(dl,dlopen)
+dnl
dnl ------ EXPAT
expat=yes
-AC_ARG_WITH(expat, [ --with-expat[=DIR] EXPAT library in DIR],[expat=$withval])
+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";
CFLAGS="$EXPAT_CFLAGS $CFLAGS"
LIBS="$EXPAT_LIBS $LIBS"
fi
- AC_CHECK_LIB(expat,XML_ParserCreate,[LIBS="$LIBS -lexpat"])
+ 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)
- else
- LIBS="$xLIBS"
- CFLAGS="$xCFLAGS"
fi
+ LIBS="$xLIBS"
+ CFLAGS="$xCFLAGS"
fi
dnl
dnl ------ PERL
-AM_CONDITIONAL(perl,false)
-perl=no
+AC_ARG_WITH(perl, [ --with-perl[=FILE] perl binary location],[perl=$withval],[perl=yes])
+
+dnl ------- 64 bit files
+AC_MSG_CHECKING(for LFS)
+AC_TRY_RUN([#define _FILE_OFFSET_BITS 64
+#include <sys/types.h>
+#include <unistd.h>
+#include <string.h>
+#include <stdio.h>
+#include <fcntl.h>
+#include <errno.h>
+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
+ AC_MSG_RESULT(no)
+fi
+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 a-z- A-Z_`
+ 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)])
+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)])
+ZEBRA_MODULE(grs-perl,no, [ --enable-mod-grs-perl Perl filter])
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
+if test "$myen" != "no"; then
AC_MSG_CHECKING(for perl binary)
if test "$perl" = "yes"; then
perlbin=`which perl`
AC_MSG_CHECKING(perl core directory)
archdir=`$perlbin -MConfig -e 'print $Config{archlib}'`;
perlcore="$archdir/CORE";
- if test "$perlcore"; then
+ if test -d "$perlcore"; then
PERL_BINARY="$perlbin"
AC_MSG_RESULT($perlcore)
- AC_DEFINE(HAVE_PERL,1)
else
AC_MSG_RESULT(Failed)
- AC_DEFINE(HAVE_PERL,0)
fi
AC_MSG_CHECKING("for ExtUtils::Embed to determine ccopts")
AC_MSG_RESULT(XS libraries are not going to be available)
fi
- ZPERL_LIBS="$LIBS"
+ xLIBS="$LIBS"
+ xCFLAGS="$CFLAGS"
CFLAGS="$PERL_CFLAGS $CFLAGS"
LIBS="$PERL_LIBS $LIBS"
- AM_CONDITIONAL(perl,true)
+
+ AC_MSG_CHECKING(for perl library)
+ AC_TRY_LINK([
+ #include <stdio.h>
+ ],[
+ ;
+ ],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 <sys/types.h>
-#include <unistd.h>
-#include <string.h>
-#include <stdio.h>
-#include <fcntl.h>
-#include <errno.h>
-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
- 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
+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
isamb/Makefile
isams/Makefile
isamc/Makefile
- isam/Makefile
rset/Makefile
data1/Makefile
recctrl/Makefile
recctrl/perlread.h
index/Makefile
- include/Makefile
+ include/Makefile include/idzebra/Makefile
tab/Makefile
doc/Makefile
doc/zebra.xml
doc/zebraphp.dsl
doc/tkl.xsl
test/Makefile test/gils/Makefile test/usmarc/Makefile test/api/Makefile
- perl/Makefile.PL
- test/dmoz/Makefile test/xpath/Makefile test/sort/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
-])
-
+ idzebra.spec
+ idzebra-config
+],[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 -x "$perlbin"; then
- res=`cd perl ; $perlbin Makefile.PL ; cd .. ;`;
+ 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
+