X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=configure.in;h=8b4439f8ed56d62607cd418cd5c3db36bbc4db9f;hb=0fa6f1df1e36d0cbc991c8dc40a7d883e219948a;hp=859bf63f19dd5abc00cff67b2e5dc09a6e37e17a;hpb=da40e0e3505cca8e2075d3f84e2789cb6a93c286;p=openldap diff --git a/configure.in b/configure.in index 859bf63f19..8b4439f8ed 100644 --- a/configure.in +++ b/configure.in @@ -1,3 +1,4 @@ +dnl $OpenLDAP$ dnl dnl Copyright 1998,1999 The OpenLDAP Foundation. All Rights Reserved. dnl @@ -6,20 +7,58 @@ dnl as authorized by the OpenLDAP Public License. A copy of this dnl license is available at http://www.OpenLDAP.org/license.html or dnl in file LICENSE in the top-level directory of the distribution. dnl - +dnl ---------------------------------------------------------------- +dnl Redefine AC_INIT_BINSH to provide RCS IDs and copyright notice +dnl at top of generated configure script. Prints simple copyright. +define([AC_INIT_BINSH], +[[#! /bin/sh +# $]OpenLDAP[$ +# from] translit([$OpenLDAP$], $")] [ + +# Copyright 1998,1999 The OpenLDAP Foundation. All Rights Reserved. +# +# Redistribution and use in source and binary forms are permitted only +# as authorized by the OpenLDAP Public License. A copy of this +# license is available at http://www.OpenLDAP.org/license.html or +# in file LICENSE in the top-level directory of the distribution. + +echo "Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved." +echo "Copying restrictions apply, see COPYRIGHT file." +])dnl +dnl ---------------------------------------------------------------- +dnl Disable config.cache! +define([AC_CACHE_LOAD], )dnl +define([AC_CACHE_SAVE], )dnl +dnl ================================================================ dnl Configure.in for OpenLDAP -AC_INIT(include/ldap.h)dnl +AC_INIT(build/version)dnl AC_CONFIG_AUX_DIR(build)dnl -AM_INIT_AUTOMAKE(OpenLDAP,[2.0-devel], [no ac_define])dnl -dnl Do not use AutoConf 2.12; it produces a configuration script -dnl that causes an "internal 2K buffer" error on HPUX when run -dnl with /bin/sh. Autoconf 2.10 seems to be okay. +OL_VERSION=`cat $ac_aux_dir/version` +if test -z "$OL_VERSION"; then + AC_MSG_ERROR([could not determine version]) +fi + +echo "Configuring OpenLDAP $OL_VERSION ..." + +dnl Determine host platform +dnl we try not to use this for much +AC_CANONICAL_SYSTEM + +AM_INIT_AUTOMAKE(OpenLDAP,[$OL_VERSION], [no defines])dnl +AC_SUBST(PACKAGE) +AC_SUBST(VERSION) +AC_DEFINE_UNQUOTED(OPENLDAP_PACKAGE,"$PACKAGE",Package) +AC_DEFINE_UNQUOTED(OPENLDAP_VERSION,"$VERSION",Version) + +dnl We use autoconf features new to 2.13. +dnl aclocal.m4 should be built using aclocal from automake 1.4 +dnl libtool 1.3.3 should be installed. AC_PREREQ(2.13)dnl Required Autoconf version -AC_CONFIG_HEADER(include/portable.h include/ldap_features.h)dnl +AC_CONFIG_HEADER(include/portable.h include/ldap_features.h include/lber_types.h)dnl -dnl +dnl ================================================================ dnl Start Args AC_MSG_CHECKING(configure arguments) AC_PREFIX_DEFAULT(/usr/local) @@ -27,76 +66,122 @@ AC_PREFIX_DEFAULT(/usr/local) top_builddir=`pwd` AC_SUBST(top_builddir)dnl -ldap_subdir="openldap" - -AC_ARG_WITH(subdir, [ --with-subdir=DIR change default subdirectory used for installs], [ - if test "$withval" = "no"; then - ldap_subdir="" - elif test "$withval" != "yes"; then +dnl ---------------------------------------------------------------- +dnl --with-subdir +ldap_subdir="/openldap" + +AC_ARG_WITH(subdir, +[ --with-subdir=DIR change default subdirectory used for installs], +[case "$withval" in + no) ldap_subdir="" + ;; + yes) + ;; + /*|\\*) ldap_subdir="$withval" - fi + ;; + *) + ldap_subdir="/$withval" + ;; +esac ])dnl AC_SUBST(ldap_subdir)dnl +dnl ---------------------------------------------------------------- +dnl General "enable" options OL_ARG_ENABLE(debug,[ --enable-debug enable debugging], yes)dnl -ol_enable_syslog=no -dnl OL_ARG_ENABLE(syslog,[ --enable-syslog enable syslog support], auto)dnl +OL_ARG_ENABLE(syslog,[ --enable-syslog enable syslog support], auto)dnl OL_ARG_ENABLE(proctitle,[ --enable-proctitle enable proctitle support], yes)dnl OL_ARG_ENABLE(cache,[ --enable-cache enable caching], yes)dnl -OL_ARG_ENABLE(dns,[ --enable-dns enable V2 DNS extension], no)dnl +OL_ARG_ENABLE(dns,[ --enable-dns enable V2 DX Referrals extension], no)dnl OL_ARG_ENABLE(referrals,[ --enable-referrals enable V2 Referrals extension], yes)dnl OL_ARG_ENABLE(cldap,[ --enable-cldap enable connectionless ldap], no)dnl OL_ARG_ENABLE(x_compile,[ --enable-x-compile enable cross compiling], no, [yes no])dnl - +dnl ---------------------------------------------------------------- dnl General "with" options OL_ARG_ENABLE(dmalloc,[ --enable-dmalloc enable debug malloc support], no)dnl -OL_ARG_WITH(kerberos,[ --with-kerberos use Kerberos], - auto, [auto k5 k4 afs yes no]) +OL_ARG_WITH(cyrus_sasl,[ --with-cyrus-sasl with Cyrus SASL support], + auto, [auto yes no] ) +OL_ARG_WITH(fetch,[ --with-fetch with fetch URL support], + auto, [auto yes no] ) +OL_ARG_WITH(kerberos,[ --with-kerberos with Kerberos support], + auto, [auto k5 kth k4 afs yes no]) +OL_ARG_WITH(readline,[ --with-readline with readline support], + auto, [auto yes no] ) OL_ARG_WITH(threads,[ --with-threads use threads], - auto, [auto posix mach lwp yes no manual] ) + auto, [auto nt posix mach pth lwp yes no manual] ) +OL_ARG_WITH(tls,[ --with-tls with TLS/SSL support], + auto, [auto ssleay openssl yes no] ) OL_ARG_WITH(yielding_select,[ --with-yielding-select with implicitly yielding select], auto, [auto yes no manual] ) +dnl ---------------------------------------------------------------- dnl Server options - +dnl ---------------------------------------------------------------- dnl LDAPD OPTIONS -AC_ARG_WITH(xxldapdoptions,[LDAPD Options:]) +AC_ARG_WITH(xxldapdoptions,[LDAPD (X.500-to-LDAP Gateway) Options:]) OL_ARG_ENABLE(ldapd,[ --enable-ldapd enable building ldapd], no)dnl +dnl ---------------------------------------------------------------- dnl SLAPD OPTIONS -AC_ARG_WITH(xxslapdoptions,[SLAPD Options:]) +AC_ARG_WITH(xxslapdoptions,[SLAPD (Standalone LDAP Daemon) Options:]) OL_ARG_ENABLE(slapd,[ --enable-slapd enable building slapd], yes)dnl -OL_ARG_ENABLE(aclgroups,[ --enable-aclgroups enable ACL group support], auto)dnl OL_ARG_ENABLE(cleartext,[ --enable-cleartext enable cleartext passwords], yes)dnl OL_ARG_ENABLE(crypt,[ --enable-crypt enable crypt(3) passwords], auto)dnl -OL_ARG_ENABLE(wrappers,[ --enable-wrappers enable tcp wrapper support], no)dnl +OL_ARG_ENABLE(modules,[ --enable-modules enable dynamic module support], no)dnl +OL_ARG_ENABLE(multimaster,[ --enable-multimaster enable multimaster replication], no)dnl OL_ARG_ENABLE(phonetic,[ --enable-phonetic enable phonetic/soundex], no)dnl +OL_ARG_ENABLE(quipu,[ --enable-quipu build quipu migration tools], no)dnl OL_ARG_ENABLE(rlookups,[ --enable-rlookups enable reverse lookups], auto)dnl +OL_ARG_ENABLE(aci,[ --enable-aci enable per-object ACIs], no)dnl +OL_ARG_ENABLE(discreteaci,[ --enable-discreteaci enable discrete rights in ACIs], no)dnl +OL_ARG_ENABLE(wrappers,[ --enable-wrappers enable tcp wrapper support], no)dnl +OL_ARG_ENABLE(dynamic,[ --enable-dynamic enable linking built binaries with dynamic libs], no)dnl dnl SLAPD Backend options OL_ARG_ENABLE(bdb2,[ --enable-bdb2 enable bdb2 backend], no)dnl +OL_ARG_WITH(bdb2_module,[ --with-bdb2-module module type], static, + [static dynamic]) +OL_ARG_ENABLE(ldap,[ --enable-ldap enable ldap backend], no)dnl +OL_ARG_WITH(ldap_module,[ --with-ldap-module module type], static, + [static dynamic]) OL_ARG_ENABLE(ldbm,[ --enable-ldbm enable ldbm backend], yes)dnl OL_ARG_WITH(ldbm_api,[ --with-ldbm-api use LDBM API], auto, - [auto db2 db gdbm ndbm manual]) + [auto db2 db mdbm gdbm ndbm manual]) +OL_ARG_WITH(ldbm_module,[ --with-ldbm-module module type], static, + [static dynamic]) OL_ARG_WITH(ldbm_type,[ --with-ldbm-type use LDBM type], auto, [auto btree hash]) OL_ARG_ENABLE(passwd,[ --enable-passwd enable passwd backend], no)dnl +OL_ARG_WITH(passwd_module,[ --with-passwd-module module type], static, + [static dynamic]) OL_ARG_ENABLE(perl,[ --enable-perl enable perl backend], no)dnl +OL_ARG_WITH(perl_module,[ --with-perl-module module type], static, + [static dynamic]) OL_ARG_ENABLE(shell,[ --enable-shell enable shell backend], no)dnl +OL_ARG_WITH(shell_module,[ --with-shell-module module type], static, + [static dynamic]) +OL_ARG_ENABLE(tcl,[ --enable-tcl enable tcl backend], no)dnl +OL_ARG_WITH(tcl_module,[ --with-tcl-module module type], static, + [static dynamic]) +dnl ---------------------------------------------------------------- dnl SLURPD OPTIONS -AC_ARG_WITH(xxslurpdoptions,[SLURPD Options:]) +AC_ARG_WITH(xxslurpdoptions,[SLURPD (Replication Daemon) Options:]) OL_ARG_ENABLE(slurpd,[ --enable-slurpd enable building slurpd], auto)dnl +dnl ---------------------------------------------------------------- AC_ARG_WITH(xxliboptions,[Library Generation & Linking Options]) -AM_ENABLE_STATIC -dnl AM_DISABLE_SHARED -AM_ENABLE_SHARED +AC_ENABLE_STATIC +dnl AC_DISABLE_SHARED +AC_ENABLE_SHARED + +dnl ---------------------------------------------------------------- dnl General "enable" options # validate options @@ -113,37 +198,76 @@ fi if test $ol_enable_slapd = no ; then dnl SLAPD was specificallly disabled if test $ol_enable_bdb2 = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_bdb2 argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-bdb2 argument]) + fi + if test $ol_enable_ldap = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-ldap argument]) fi if test $ol_enable_ldbm = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_ldbm argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-ldbm argument]) fi if test $ol_enable_passwd = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_passwd argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-passwd argument]) fi if test $ol_enable_perl = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_perl argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-perl argument]) fi if test $ol_enable_shell = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_shell argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-shell argument]) + fi + if test $ol_enable_tcl = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-tcl argument]) + fi + if test $ol_enable_modules = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-modules argument]) fi - if test $ol_enable_aclgroups = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_aclgroups argument]) + if test $ol_enable_multimaster = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-multimaster argument]) fi if test $ol_enable_wrappers = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_wrappers argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-wrappers argument]) fi if test $ol_enable_phonetic = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_phonetic argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-phonetic argument]) + fi + if test $ol_enable_quipu = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-quipu argument]) fi if test $ol_enable_rlookups = yes ; then - AC_MSG_WARN([slapd disabled, ignoring --enable_rlookups argument]) + AC_MSG_WARN([slapd disabled, ignoring --enable-rlookups argument]) + fi + if test $ol_enable_aci = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-aci argument]) + fi + if test $ol_enable_discreteaci = yes ; then + AC_MSG_WARN([slapd disabled, ignoring --enable-discreteaci argument]) fi if test $ol_with_ldbm_api != auto ; then - AC_MSG_WARN([slapd disabled, ignoring --with_ldbm_api argument]) + AC_MSG_WARN([slapd disabled, ignoring --with-ldbm-api argument]) fi if test $ol_with_ldbm_type != auto ; then - AC_MSG_WARN([slapd disabled, ignoring --with_ldbm_type argument]) + AC_MSG_WARN([slapd disabled, ignoring --with-ldbm-type argument]) + fi + if test $ol_with_bdb2_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-bdb2-module argument]) + fi + if test $ol_with_ldap_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-ldap-module argument]) + fi + if test $ol_with_ldbm_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-ldbm-module argument]) + fi + if test $ol_with_passwd_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-passwd-module argument]) + fi + if test $ol_with_perl_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-perl-module argument]) + fi + if test $ol_with_shell_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-shell-module argument]) + fi + if test $ol_with_tcl_module != static ; then + AC_MSG_WARN([slapd disabled, ignoring --with-tcl-module argument]) fi if test $ol_enable_slurpd = yes ; then AC_MSG_ERROR([slurpd requires slapd]) @@ -151,41 +275,67 @@ if test $ol_enable_slapd = no ; then # force settings to no ol_enable_bdb2=no + ol_enable_ldap=no ol_enable_ldbm=no ol_enable_passwd=no ol_enable_perl=no ol_enable_shell=no - ol_enable_aclgroups=no - ol_enable_wrappers=no + ol_enable_tcl=no + + ol_enable_modules=no + ol_enable_multimaster=no ol_enable_phonetic=no + ol_enable_quipu=no ol_enable_rlookups=no + ol_enable_aci=no + ol_enable_discreteaci=no + ol_enable_wrappers=no + ol_enable_dynamic=no + ol_with_ldbm_api=no ol_with_ldbm_type=no + + ol_with_bdb2_module=static + ol_with_ldap_module=static + ol_with_ldbm_module=static + ol_with_passwd_module=static + ol_with_perl_module=static + ol_with_shell_module=static + ol_with_tcl_module=static + ol_enable_slurpd=no elif test $ol_enable_ldbm = no ; then dnl SLAPD without LDBM if test $ol_with_ldbm_api != auto ; then - AC_MSG_WARN([LDBM disabled, ignoring --with_ldbm_api argument]) + AC_MSG_WARN([LDBM disabled, ignoring --with-ldbm-api argument]) fi if test $ol_with_ldbm_type != auto ; then - AC_MSG_WARN([LDBM disabled, ignoring --with_ldbm_type argument]) + AC_MSG_WARN([LDBM disabled, ignoring --with-ldbm-type argument]) fi - if test $ol_enable_ldbm = yes ; then + if test $ol_with_ldbm_module != static ; then + AC_MSG_WARN([LDBM disabled, ignoring --with-ldbm-module argument]) + fi + + if test $ol_enable_bdb2 = yes ; then AC_MSG_ERROR([BDB2 requires --enable-ldbm]) fi - if test $ol_enable_passwd = no -a \ - $ol_enable_perl = no -a - $ol_enable_shell = no ; then + if test $ol_enable_modules != yes -a \ + $ol_enable_ldap = no -a \ + $ol_enable_passwd = no -a \ + $ol_enable_perl = no -a \ + $ol_enable_shell = no -a \ + $ol_enable_tcl = no ; then AC_MSG_ERROR([slapd requires a backend]) fi ol_with_ldbm_api=no ol_with_ldbm_type=no + ol_with_ldbm_module=static elif test $ol_enable_bdb2 = yes ; then dnl SLAPD with BDB2 @@ -212,6 +362,10 @@ else $ol_with_ldbm_type = btree ; then AC_MSG_ERROR([GDBM only supports LDBM type hash]) fi + if test $ol_with_ldbm_api = mdbm -a \ + $ol_with_ldbm_type = btree ; then + AC_MSG_ERROR([MDBM only supports LDBM type hash]) + fi if test $ol_with_ldbm_api = ndbm -a \ $ol_with_ldbm_type = btree ; then AC_MSG_ERROR([NDBM only supports LDBM type hash]) @@ -227,10 +381,10 @@ fi AC_MSG_RESULT(done) -AC_CANONICAL_HOST - -## Initialize vars +dnl ---------------------------------------------------------------- +dnl Initialize vars LDAP_LIBS= +LDIF_LIBS= LDBM_LIBS= LTHREAD_LIBS= LUTIL_LIBS= @@ -244,46 +398,144 @@ BUILD_SLAPD=no BUILD_SLURPD=no BUILD_BDB2=no +BUILD_LDAP=no BUILD_LDBM=no BUILD_PASSWD=no BUILD_PERL=no +BUILD_QUIPU=no BUILD_SHELL=no +BUILD_TCL=no BUILD_THREAD=no +BUILD_BDB2_DYNAMIC=static +BUILD_LDAP_DYNAMIC=static +BUILD_LDBM_DYNAMIC=static +BUILD_PASSWD_DYNAMIC=static +BUILD_PERL_DYNAMIC=static +BUILD_SHELL_DYNAMIC=static +BUILD_TCL_DYNAMIC=static + +SLAPD_MODULES_LDFLAGS= +SLAPD_MODULES_CPPFLAGS= +SLAPD_MODULES_LIST= + SLAPD_PERL_LDFLAGS= -SLAPD_PERL_CPPFLAGS= +MOD_PERL_LDFLAGS= +PERL_CPPFLAGS= +MOD_TCL_LIB= KRB_LIBS= +READLINE_LIBS= +SASL_LIBS= TERMCAP_LIBS= +TLS_LIBS= +MODULES_LIBS= -dnl ---------------------------------------------------------------- +dnl ================================================================ dnl Checks for programs -AC_PROG_INSTALL -AM_PROG_LIBTOOL -dnl AC_PROG_MAKE_SET +dnl AC_PROG_INSTALL + +AC_DEFINE(HAVE_MKVERSION, 1, [define this if you have mkversion]) + +dnl ---------------------------------------------------------------- +dnl +dnl Determine which C translator to use +dnl + +dnl AIX Thread requires we use cc_r or xlc_r. +dnl But only do this IF AIX and CC is not set +dnl and threads are auto|yes|posix. +dnl +dnl If we find cc_r|xlc_r, force pthreads and assume +dnl pthread_create is in $LIBS (ie: don't bring in +dnl any additional thread libraries) +dnl If we do not find cc_r|xlc_r, disable threads + +ol_aix_threads=no +case "$target" in +*-*-aix*) dnl all AIX is not a good idea. + if test -z "$CC" ; then + case "$ol_with_threads" in + auto | yes | posix) ol_aix_threads=yes ;; + esac + fi +;; +esac + +if test $ol_aix_threads = yes ; then + if test -z "${CC}" ; then + AC_CHECK_PROGS(CC,cc_r xlc_r cc) + + if test "$CC" = cc ; then + dnl no CC! don't allow --with-threads + if test $ol_with_threads != auto ; then + AC_MSG_ERROR([--with-threads requires cc_r (or other suitable compiler) on AIX]) + else + AC_MSG_WARN([disabling threads, no cc_r on AIX]) + fi + ol_with_threads=no + fi + fi + + if test "${CC}" = "cc_r" -o "${CC}" = "xlc_r" ; then + ol_with_threads=posix + ol_cv_pthread_create=yes + fi +fi + +if test -z "${CC}"; then + AC_CHECK_PROGS(CC,cc) +fi + +dnl The default CFLAGS is empty NOT whatever AC_PROG_CC sets. +dnl (for now, let autoconf sort this out) +dnl CFLAGS=${CFLAGS-""} + +AC_LIBTOOL_WIN32_DLL +AC_LIBTOOL_DLOPEN +AC_PROG_LIBTOOL AC_PROG_AWK +OL_PROG_LN_H AC_PROG_LN_S +if test "$LN_H" = "cp" -a "$LN_S" = "ln"; then + LN_S="$LN_H" +fi + AC_PATH_PROG(SENDMAIL, sendmail, /usr/lib/sendmail, $PATH:/usr/libexec:/usr/lib:/usr/sbin:/usr/etc:/etc) AC_PATH_PROG(EDITOR, vi, /usr/ucb/vi, $PATH:/usr/ucb) AC_PATH_PROG(FINGER, finger, /usr/ucb/finger, $PATH:/usr/ucb) -if test $ol_enable_perl = yes ; then +dnl ---------------------------------------------------------------- +dnl Perl +ol_link_perl=no +if test $ol_enable_perl != no ; then AC_PATH_PROG(PERLBIN, perl, /usr/bin/perl) if test "no$PERLBIN" = "no" ; then - ol_enable_perl=no - fi + if test $ol_enable_perl = yes ; then + AC_MSG_ERROR([could not locate perl]) + fi - SLAPD_PERL_LDFLAGS="`$PERLBIN -MExtUtils::Embed -e ldopts|sed -e s/-lc//`" - SLAPD_PERL_CPPFLAGS="`$PERLBIN -MExtUtils::Embed -e perl_inc`" + else + PERL_CPPFLAGS="`$PERLBIN -MExtUtils::Embed -e ccopts`" + if test x"$ol_with_perl_module" = "xstatic" ; then + SLAPD_PERL_LDFLAGS="`$PERLBIN -MExtUtils::Embed -e ldopts|sed -e s/-lc//`" + else + MOD_PERL_LDFLAGS="`$PERLBIN -MExtUtils::Embed -e ldopts|sed -e s/-lc//`" + fi + dnl should check perl version + ol_link_perl=yes + fi fi AC_PROG_CPP +dnl ---------------------------------------------------------------- +dnl Cross compiling checks if test $cross_compiling = yes -a $ol_enable_x_compile = yes; then AC_MSG_WARN([cross compiling.... some functionality will be removed.]) @@ -296,36 +548,164 @@ elif test $cross_compiling = yes -a $ol_enable_x_compile = no; then AC_MSG_ERROR([ if cross compiling, add --enable-x-compile.]) fi +dnl ---------------------------------------------------------------- dnl Checks for UNIX Variants AC_AIX AC_ISC_POSIX AC_MINIX +dnl ---------------------------------------------------------------- dnl Checks for system services AC_CYGWIN AC_MINGW32 AC_EXEEXT AC_OBJEXT +AC_DEFINE_UNQUOTED( EXEEXT, "${EXEEXT}", [defined to be the EXE extension]) + +dnl ---------------------------------------------------------------- +dnl BeOS requires -lbe -lroot -lnet +AC_CHECK_LIB(be, be_app, [LIBS="$LIBS -lbe -lroot -lnet"], :, [-lroot -lnet]) + +dnl ---------------------------------------------------------------- dnl OpenLDAP requires STDC features AM_PROG_CC_STDC if test "X${am_cv_prog_cc_stdc}" = "Xno" ; then - AC_MSG_ERROR([OpenLDAP requires compiler to support STDC prototypes.]) + AC_MSG_ERROR([OpenLDAP requires compiler to support STDC constructs.]) +fi + +dnl ---------------------------------------------------------------- +dnl Check cc depend flags +OL_MKDEPEND +if test "${ol_cv_mkdep}" = no ; then + # this will soon become an error + AC_MSG_WARN([do not know how to generate dependencies]) +fi + +dnl ---------------------------------------------------------------- +dnl Check for module support +ol_link_modules=no +if test $ol_enable_modules != no ; then + AC_CHECK_HEADERS(ltdl.h) + + if test $ac_cv_header_ltdl_h = no ; then + AC_MSG_ERROR([could not locate libtool ltdl.h]) + fi + + AC_CHECK_LIB(ltdl, lt_dlinit, [ + MODULES_LIBS=-lltdl + AC_DEFINE(HAVE_LIBLTDL,1,[define if you have libtool -ltdl]) + ]) + + if test "$ac_cv_lib_ltdl_lt_dlinit" = no ; then + AC_MSG_ERROR([could not locate libtool -lltdl]) + fi + ol_link_modules=yes +else + ol_with_bdb2_module=static + ol_with_ldap_module=static + ol_with_ldbm_module=static + ol_with_passwd_module=static + ol_with_perl_module=static + ol_with_shell_module=static + ol_with_tcl_module=static +fi + +dnl ---------------------------------------------------------------- +dnl Checks for header files. +OL_HEADER_STDC + +if test $ol_cv_header_stdc != yes; then + AC_MSG_WARN([could not locate Standard C compliant headers]) fi -dnl AM_C_PROTOTYPES +AC_HEADER_DIRENT +AC_HEADER_SYS_WAIT +AM_HEADER_TIOCGWINSZ_NEEDS_SYS_IOCTL +if test $am_cv_sys_posix_termios = yes ; then + AC_DEFINE(HAVE_POSIX_TERMIOS,1, + [define if you have POSIX termios]) +fi + +AC_CHECK_HEADERS( \ + arpa/inet.h \ + arpa/nameser.h \ + assert.h \ + conio.h \ + crypt.h \ + direct.h \ + errno.h \ + fcntl.h \ + filio.h \ + getopt.h \ + grp.h \ + io.h \ + libutil.h \ + limits.h \ + locale.h \ + netinet/tcp.h \ + malloc.h \ + memory.h \ + psap.h \ + pwd.h \ + process.h \ + resolv.h \ + sgtty.h \ + shadow.h \ + stddef.h \ + string.h \ + strings.h \ + sysexits.h \ + sys/file.h \ + sys/filio.h \ + sys/errno.h \ + sys/ioctl.h \ + sys/param.h \ + sys/resource.h \ + sys/select.h \ + sys/socket.h \ + sys/syslog.h \ + sys/time.h \ + sys/types.h \ + syslog.h \ + termios.h \ + unistd.h \ + winsock.h \ +) + +dnl ---------------------------------------------------------------- dnl Checks for libraries +dnl HP-UX requires -lV3 +AC_CHECK_LIB(V3, sigset) + +dnl Gotta check for winsock manually +if test $ac_cv_header_winsock_h = yes; then + AC_CACHE_CHECK([for winsock], [ol_cv_winsock], + AC_TRY_LINK([#include ],[ + socket(0,0,0); + select(0,NULL,NULL,NULL,NULL); + closesocket(0); + gethostname(NULL,0); + ],[ol_cv_winsock=yes],[ol_cv_winsock=no])]) + + if test $ol_cv_winsock = yes ; then + AC_DEFINE(HAVE_WINSOCK,1,[define if you have winsock]) + ac_cv_func_socket=yes + ac_cv_func_select=yes + ac_cv_func_closesocket=yes + ac_cv_func_gethostname=yes + fi +fi + dnl Find socket() dnl Likely combinations: dnl -lsocket [ -lnsl_s | -lnsl ] dnl -linet -AC_CHECK_FUNC(socket, [have_socket=yes], [ -dnl +AC_CHECK_FUNC(socket, :, [ dnl hopefully we won't include too many libraries -dnl AC_CHECK_LIB(socket, main) AC_CHECK_LIB(net, main) AC_CHECK_LIB(nsl_s, main) @@ -334,56 +714,109 @@ dnl AC_CHECK_LIB(gen, main) ]) +dnl require select +AC_CHECK_FUNC(select, :, AC_MSG_ERROR([select() required.])) + +if test "${ac_cv_header_winsock_h}" != yes; then + dnl Select arg types + dnl (if this detection becomes permenent, it and the select() detection + dnl should be done before the yielding select test) + AC_FUNC_SELECT_ARGTYPES +fi + +dnl check to see if system call automatically restart +dnl AC_SYS_RESTARTABLE_SYSCALLS + +dnl ---------------------------------------------------------------- +dnl require POSIX regex +AC_CHECK_HEADERS( regex.h ) +if test "$ac_cv_header_regex_h" != yes ; then + AC_MSG_ERROR([POSIX regex.h required.]) +fi +AC_CHECK_FUNC(regfree, :, AC_MSG_ERROR([POSIX regex required.])) + +OL_POSIX_REGEX +if test "$ol_cv_c_posix_regex" = no ; then + AC_MSG_ERROR([broken POSIX regex!]) +fi + +dnl ---------------------------------------------------------------- dnl Check for resolver routines -AC_CHECK_FUNCS(res_search) -if test $ac_cv_func_res_search = "no" ; then +AC_CHECK_FUNC(res_search,:) +if test $ac_cv_func_res_search = no ; then AC_CHECK_LIB(bind, res_search) - if test "$ac_cv_lib_bind_res_search" = "yes" ; then - AC_DEFINE(HAVE_RES_SEARCH,1) - else - AC_CHECK_LIB(resolv, res_search) - if test "$ac_cv_lib_resolv_res_search" = "yes" ; then - AC_DEFINE(HAVE_RES_SEARCH,1) - fi - fi + ac_cv_func_res_search=$ac_cv_lib_bind_res_search fi -dnl HP-UX requires -lV3 -AC_CHECK_LIB(V3, sigset) +if test $ac_cv_func_res_search = no ; then + AC_CHECK_LIB(bind, __res_search) + ac_cv_func_res_search=$ac_cv_lib_bind___res_search +fi -# ISODE tests +if test $ac_cv_func_res_search = no ; then + AC_CHECK_LIB(resolv, res_search) + ac_cv_func_res_search=$ac_cv_lib_resolv_res_search +fi + +if test "$ac_cv_func_res_search" = yes ; then + AC_DEFINE(HAVE_RES_SEARCH,1, + [define if you have res_search()]) +elif test $ol_enable_dns = yes ; then + AC_MSG_ERROR([--enable-dns requires res_search]) +elif test $ol_enable_dns != no ; then + AC_MSG_WARN([no res_search, disabling DNS support]) +fi + + +dnl ---------------------------------------------------------------- +dnl ISODE tests ol_link_isode=no if test $ol_enable_ldapd != no ; then + AC_MSG_WARN([ldapd is not supported and may suffer from bit rot.]) + dnl look for ISODE libraries AC_CHECK_LIB(xtpp, main, [ ol_link_isode=yes - AC_DEFINE(HAVE_XTPP,1) + AC_DEFINE(HAVE_XTPP,1, [define if you have -lxttp]) LDAPD_LIBS="$LDAPD_LIBS -lxtpp -lxtdsap -lxtisode -losi" ],:,[-lxtdsap -lxtisode -losi]) AC_CHECK_LIB(dsap, main, [ ol_link_isode=yes - AC_DEFINE(HAVE_DSAP,1) + AC_DEFINE(HAVE_DSAP,1, [define if you have -ldsap]) LDAPD_LIBS="$LDAPD_LIBS -ldsap" ],:,[-lisode]) AC_CHECK_LIB(isode, main, [ ol_link_isode=yes - AC_DEFINE(HAVE_ISODE,1) + AC_DEFINE(HAVE_ISODE,1, [define if you have -lisode]) LDAPD_LIBS="$LDAPD_LIBS -lisode" ],:) fi if test $ol_link_isode != no; then AC_CHECK_LIB(pp, main, [ - AC_DEFINE(HAVE_PP,1) + AC_DEFINE(HAVE_PP,1, [define if you have -lpp]) LDAPD_LIBS="-lpp $LDAPD_LIBS" ],:) AC_PATH_PROG(PEPSY, pepsy) fi -dnl -dnl check for kerberos -dnl +dnl ---------------------------------------------------------------- +dnl QUIPU +if test $ol_enable_quipu != no ; then + AC_CHECK_HEADERS(quipu/commonarg.h) + + if test $ac_cv_header_quipu_commonarg_h = yes ; then + BUILD_QUIPU=yes + elif test $ol_enable_quipu = auto ; then + AC_MSG_WARN([no quipu for --enable-quipu=auto, disabling]) + else + AC_MSG_ERROR(no quipu for --enable-quipu=$ol_enable_quipu) + fi +fi + +dnl ---------------------------------------------------------------- +dnl Kerberos ol_link_kerberos=no if test $ol_with_kerberos = auto -o $ol_with_kerberos = k5 ; then @@ -391,20 +824,46 @@ if test $ol_with_kerberos = auto -o $ol_with_kerberos = k5 ; then if test $ac_cv_header_kerberosIV_krb_h = yes ; then AC_CHECK_LIB(krb4, main, [have_k5=yes], [have_k5=no], - [-lkrb5 -ldes425]) + [-lkrb5 -ldes425 -lcrypto -lcom_err]) if test $have_k5 = yes ; then ol_with_kerberos=found ol_link_kerberos=yes - AC_DEFINE(HAVE_KERBEROS) - KRB_LIBS="-lkrb4 -lkrb5 -ldes425" + KRB_LIBS="-lkrb4 -lkrb5 -ldes425 -lcrypto -lcom_err" + + LIBS="$KRB_LIBS $LIBS" + + AC_CACHE_CHECK([for des_debug in Kerberos libraries], + [ol_cv_var_des_debug], [ + dnl save the flags + save_LIBS="$LIBS" + LIBS="$KRB_LIBS $LIBS" + AC_TRY_LINK([ +#include +#include +extern int des_debug; +],[ +des_debug = 1; +], ol_cv_var_des_debug=yes, ol_cv_var_des_debug=no) + dnl restore the LIBS + LIBS="$save_LIBS" + ]) + + if test $ol_cv_var_des_debug = yes ; then + AC_DEFINE(HAVE_DES_DEBUG,1, + [define if you have Kerberos des_debug]) + fi + + LIBS="$save_LIBS" fi fi fi -if test $ol_with_kerberos = auto -o $ol_with_kerberos = k4 ; then - AC_CHECK_HEADERS(krb.h des.h) +if test $ol_with_kerberos = auto -o $ol_with_kerberos = k4 \ + -o $ol_with_kerberos = kth ; then + + AC_CHECK_HEADERS(krb.h des.h krb-archaeology.h ) if test $ac_cv_header_krb_h = yes ; then AC_CHECK_LIB(krb, main, [have_k4=yes], [have_k4=no], [-ldes]) @@ -413,328 +872,250 @@ if test $ol_with_kerberos = auto -o $ol_with_kerberos = k4 ; then ol_with_kerberos=found ol_link_kerberos=yes - AC_DEFINE(HAVE_KERBEROS) KRB_LIBS="-lkrb -ldes" + + if test $ac_cv_header_krb_archaeology_h = yes ; then + AC_DEFINE(HAVE_KTH_KERBEROS, 1, + [define if you have Kth Kerberos]) + fi fi fi fi -dnl if test $ol_link_kerberos = yes ; then -dnl save_LIBS=$LIBS -dnl LIBS="$KRB_LIBS $LIBS" -dnl AC_CHECK_FUNCS(des_string_to_key) -dnl LIBS=$save_LIBS -dnl fi - -ol_link_threads=no -if test $ol_with_threads = auto -o $ol_with_threads = yes \ - -o $ol_with_threads = posix ; then - - AC_CHECK_HEADERS(pthread.h sched.h) +if test $ol_link_kerberos = yes ; then + AC_DEFINE(HAVE_KERBEROS, 1, [define if you have Kerberos]) - if test $ac_cv_header_pthread_h = yes ; then - OL_POSIX_THREAD_VERSION +elif test $ol_with_kerberos != auto -a $ol_with_kerberos != no ; then + AC_ERROR([Kerberos detection failed.]) +fi - if test $ol_cv_pthread_version = final ; then - AC_DEFINE(HAVE_PTHREADS_FINAL) - elif test $ol_cv_pthread_version = draft4 ; then - AC_DEFINE(HAVE_PTHREADS_D4) - else - AC_MSG_ERROR([unknown pthread version]) +dnl ---------------------------------------------------------------- +dnl TLS/SSL +ol_link_tls=no +if test $ol_with_tls != no ; then + + AC_CHECK_HEADERS(openssl/ssl.h ssl.h) + + if test $ac_cv_header_openssl_ssl_h = yes -o $ac_cv_header_ssl_h = yes ; then + AC_CHECK_LIB(ssl, SSLeay_add_ssl_algorithms, + [have_ssleay=yes + need_rsaref=no], + [have_ssleay=no], + [-lcrypto]) + + if test $have_ssleay = no ; then + AC_CHECK_LIB(ssl, SSL_library_init, + [have_ssleay=yes + need_rsaref=no], [have_ssleay=no], + [-lcrypto]) fi - # consider threads found - ol_with_threads=found - - OL_LINUX_THREADS - - if test $ol_cv_linux_threads = yes ; then - AC_DEFINE(HAVE_LINUX_THREADS,1) + if test $have_ssleay = no ; then + AC_CHECK_LIB(ssl, ssl3_accept, + [have_ssleay=yes + need_rsaref=yes], [have_ssleay=no], + [-lcrypto -lRSAglue -lrsaref]) fi - dnl Now the hard part, how to link? - dnl - dnl currently supported checks: - dnl - dnl 0) pthread_create() in $LIBS - dnl - dnl Check special pthread (final) flags - dnl 1) pthread_create() with -kthread (FreeBSD) - dnl 2) pthread_create() with -pthread (FreeBSD) - dnl 3) pthread_create() with -pthreads (OSF/1) - dnl 4) pthread_create() with -thread (?) - dnl - dnl Check pthread (final) libraries - dnl 5) pthread_mutex_unlock() in -lpthread -lmach -lexc -lc_r (OSF/1) - dnl 6) pthread_mutex_lock() in -lpthread -lmach -lexc (OSF/1) - dnl 7) pthread_mutex_trylock() in -lpthread -lexc (OSF/1) - dnl 8) pthread_create() in -lpthread (many) - dnl 9) pthread_create() in -lc_r (FreeBSD) - dnl 10) pthread_create() in -lpthreads (many) - dnl 11) pthread_join() -Wl,-woff,85 -lpthreads (IRIX) - dnl 12) pthread_create() in HP-UX -lpthread (HP-UX 11) - dnl - dnl Check pthread (draft4) flags (to be depreciated) - dnl 13) pthread_create() with -threads (OSF/1) - dnl - dnl Check pthread (final) libraries (to be depreciated) - dnl 14) pthread_mutex_unlock() in -lpthreads -lmach -lexc -lc_r (OSF/1) - dnl 14) pthread_mutex_lock() in -lpthreads -lmach -lexc (OSF/1) - dnl 14) pthread_mutex_trylock() in -lpthreads -lexc (OSF/1) - dnl - - dnl pthread_create in $LIBS - AC_CHECK_FUNC(pthread_create,[ol_link_threads=yes]) + if test $have_ssleay = yes ; then + ol_with_tls=found + ol_link_tls=yes - if test $ol_link_threads = no ; then - dnl try -kthread - AC_CACHE_CHECK([for pthread_create with -kthread], - [ol_cv_kthread_flag], [ - dnl save the flags - save_LIBS="$LIBS" - LIBS="-kthread $LIBS" - AC_TRY_LINK([char pthread();],[ - pthread_create(); - ], ol_cv_kthread_flag=yes, ol_cv_kthread_flag=no) - dnl restore the LIBS - LIBS="$save_LIBS" - ]) + AC_DEFINE(HAVE_SSLEAY, 1, + [define if you have SSLeay or OpenSSL]) - if test $ol_cv_kthread_flag = yes ; then - LTHREAD_LIBS="$LTHREAD_LIBS -kthread" - ol_link_threads=posix - fi - fi + if test $need_rsaref = yes; then + AC_DEFINE(HAVE_RSAREF, 1, + [define if you have RSAref]) - if test $ol_link_threads = no ; then - dnl try -pthread - AC_CACHE_CHECK([for pthread_create with -pthread], - [ol_cv_pthread_flag], [ - dnl save the flags - save_LIBS="$LIBS" - LIBS="-pthread $LIBS" - AC_TRY_LINK([char pthread();],[ - pthread_create(); - ], ol_cv_pthread_flag=yes, ol_cv_pthread_flag=no) - dnl restore the LIBS - LIBS="$save_LIBS" - ]) - - if test $ol_cv_pthread_flag = yes ; then - LTHREAD_LIBS="$LTHREAD_LIBS -pthread" - ol_link_threads=posix + TLS_LIBS="-lssl -lcrypto -lRSAglue -lrsaref" + else + TLS_LIBS="-lssl -lcrypto" fi fi + fi +fi - if test $ol_link_threads = no ; then - dnl try -pthreads - AC_CACHE_CHECK([for pthread_create with -pthreads], - [ol_cv_pthreads_flag], [ - dnl save the flags - save_LIBS="$LIBS" - LIBS="-pthreads $LIBS" - AC_TRY_LINK([char pthread();],[ - pthread_create(); - ], ol_cv_pthreads_flag=yes, ol_cv_pthreads_flag=no) - dnl restore the LIBS - LIBS="$save_LIBS" - ]) +if test $ol_link_tls = yes ; then + AC_DEFINE(HAVE_TLS, 1, [define if you have TLS]) +fi - if test $ol_cv_pthreads_flag = yes ; then - LTHREAD_LIBS="$LTHREAD_LIBS -pthreads" - ol_link_threads=posix - fi - fi +dnl ---------------------------------------------------------------- +dnl Tests for reentrant functions necessary to build a +dnl thread_safe -lldap. +AC_CHECK_FUNCS( \ + ctime_r \ + gethostbyname_r gethostbyaddr_r \ +) - if test $ol_link_threads = no ; then - dnl try -thread - AC_CACHE_CHECK([for pthread_create with -thread], - [ol_cv_thread_flag], [ - dnl save the flags - save_LIBS="$LIBS" - LIBS="-thread $LIBS" - AC_TRY_LINK([char pthread();],[ - pthread_create(); - ], ol_cv_thread_flag=yes, ol_cv_thread_flag=no) - dnl restore the LIBS - LIBS="$save_LIBS" - ]) +if test "$ac_cv_func_ctime_r" = no ; then + ol_cv_func_ctime_r_nargs=0 +else + OL_FUNC_CTIME_R_NARGS +dnl OL_FUNC_CTIME_R_TYPE +fi - if test $ol_cv_thread_flag = yes ; then - LTHREAD_LIBS="$LTHREAD_LIBS -thread" - ol_link_threads=posix - fi - fi +if test "$ac_cv_func_gethostbyname_r" = yes ; then + OL_FUNC_GETHOSTBYNAME_R_NARGS +else + ol_cv_func_gethostbyname_r_nargs=0 +fi + +if test "$ac_cv_func_gethostbyaddr_r" = yes ; then + OL_FUNC_GETHOSTBYADDR_R_NARGS +else + ol_cv_func_gethostbyaddr_r_nargs=0 +fi - if test $ol_link_threads = no ; then - dnl try DEC Threads -lpthread -lmach -lexc -lc_r - save_LIBS="$LIBS" - AC_CHECK_LIB(pthread, pthread_mutex_unlock, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthread -lmach -lexc -lc_r" - if test $ol_with_yielding_select = auto ; then - ol_with_yielding_select=yes - fi - ],:,[-lmach -lexc -lc_r]) - LIBS="$save_LIBS" - fi +if test "$ac_cv_func_ctime_r" = yes \ + -a "$ol_cv_func_ctime_r_nargs" -ge 2 \ + -a "$ol_cv_func_ctime_r_nargs" -le 3 \ + -a "$ac_cv_func_gethostbyname_r" = yes \ + -a "$ol_cv_func_gethostbyname_r_nargs" -ge 5 \ + -a "$ol_cv_func_gethostbyname_r_nargs" -le 6 \ + -a "$ac_cv_func_gethostbyaddr_r" = yes \ + -a "$ol_cv_func_gethostbyaddr_r_nargs" -ge 5 \ + -a "$ol_cv_func_gethostbyaddr_r_nargs" -le 6 \ + ; then + + AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_REENTRANT,1) +fi - if test $ol_link_threads = no ; then - dnl try DEC Threads -lpthread -lmach -lexc - save_LIBS="$LIBS" - AC_CHECK_LIB(pthread, pthread_mutex_lock, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthread -lmach -lexc" - if test $ol_with_yielding_select = auto ; then - ol_with_yielding_select=yes - fi - ],:,[-lmach -lexc]) - LIBS="$save_LIBS" - fi +dnl ---------------------------------------------------------------- +dnl Threads? +ol_link_threads=no - if test $ol_link_threads = no ; then - dnl try DEC Threads -lpthread -lexc - save_LIBS="$LIBS" - AC_CHECK_LIB(pthread, pthread_mutex_trylock, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthread -lexc" - if test $ol_with_yielding_select = auto ; then - ol_with_yielding_select=yes - fi - ],:,[-lexc]) - LIBS="$save_LIBS" - fi +if test $ol_with_threads = auto -o $ol_with_threads = yes \ + -o $ol_with_threads = nt ; then - if test $ol_link_threads = no ; then - dnl try -lpthread - save_LIBS="$LIBS" - AC_CHECK_LIB(pthread, pthread_create, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthread"],:) - LIBS="$save_LIBS" - fi + OL_NT_THREADS - if test $ol_link_threads = no ; then - dnl try -lc_r - save_LIBS="$LIBS" - AC_CHECK_LIB(c_r, pthread_create, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lc_r"],:) - LIBS="$save_LIBS" - fi + if test "$ol_cv_nt_threads" = yes ; then + ol_link_threads=nt + ol_with_threads=found + ol_with_yielding_select=yes - if test $ol_link_threads = no ; then - dnl try -lpthreads - save_LIBS="$LIBS" - AC_CHECK_LIB(pthreads, pthread_create, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthreads"],:) - LIBS="$save_LIBS" - fi + AC_DEFINE(HAVE_NT_SERVICE_MANAGER,1,[if you have NT Service Manager]) + AC_DEFINE(HAVE_NT_EVENT_LOG,1,[if you have NT Event Log]) + fi - dnl IRIX Pthread check - if test $ol_link_threads = no ; then - dnl try IRIX Pthreads -Wl,-woff,85 -lpthreads - save_LIBS="$LIBS" - AC_CHECK_LIB(pthreads, pthread_join, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthreads" - ],:,[-Wl,-woff,85]) - LIBS="$save_LIBS" - fi + if test $ol_with_threads = nt ; then + AC_MSG_ERROR([could not locate NT Threads]) + fi +fi - dnl HP-UX 11 Pthread check - if test $ol_link_threads = no; then - save_LIBS="$LIBS" - LIBS="$LIBS -lpthread" - AC_MSG_CHECKING([for pthread_create() in HP-UX -lpthread]) - ol_try_pthread_hpux_11=no - AC_CACHE_VAL(ol_cv_pthread_hpux_11,[ - AC_TRY_LINK([ -#include -#include -#ifndef ELFABI_HPUX_REL11 - die horribly -#endif - ], [pthread_create(NULL, NULL, NULL, NULL);], - ol_try_pthread_hpux_11=yes - ol_cv_pthread_hpux_11=yes, - ol_cv_pthread_hpux_11=no)]) - AC_MSG_RESULT(yes) - LIBS="$save_LIBS" +if test $ol_with_threads = auto -o $ol_with_threads = yes \ + -o $ol_with_threads = posix ; then - if test $ol_cv_pthread_hpux_11=yes ; then - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthread" - if test $ol_try_pthread_hpux_11=yes ; then - dnl Some tests below may fail, cause we aint including - dnl pthread.h. Force appropriate ones to yes - ac_cv_func_pthread_attr_init=yes - fi - fi - fi + AC_CHECK_HEADERS(pthread.h) - if test $ol_link_threads = no ; then - dnl try -threads - AC_CACHE_CHECK([for pthread_create with -threads], - [ol_cv_thread_flag], [ - dnl save the flags - save_LIBS="$LIBS" - LIBS="-threads $LIBS" - AC_TRY_LINK([char pthread();],[ - pthread_create(); - ], ol_cv_thread_flag=yes, ol_cv_thread_flag=no) - dnl restore the LIBS - LIBS="$save_LIBS" - ]) + if test $ac_cv_header_pthread_h = yes ; then + OL_POSIX_THREAD_VERSION - if test $ol_cv_thread_flag = yes ; then - LTHREAD_LIBS="$LTHREAD_LIBS -threads" - ol_link_threads=posix - fi + if test $ol_cv_pthread_version = final ; then + AC_DEFINE(HAVE_PTHREADS_FINAL,1, + [define if pthreads API compatible with final spec]) + elif test $ol_cv_pthread_version = draft4 ; then + AC_DEFINE(HAVE_PTHREADS_D4,1, + [define if pthreads API compatible with draft4 spec]) + else + AC_MSG_ERROR([unknown pthread version]) fi - if test $ol_link_threads = no ; then - dnl try DEC Threads -lpthreads -lmach -lexc -lc_r - save_LIBS="$LIBS" - AC_CHECK_LIB(pthreads, pthread_mutex_unlock, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthreads -lmach -lexc -lc_r" - if test $ol_with_yielding_select = auto ; then - ol_with_yielding_select=yes - fi - ],:,[-lmach -lexc -lc_r]) - LIBS="$save_LIBS" - fi + # consider threads found + ol_with_threads=found - if test $ol_link_threads = no ; then - dnl try DEC Threads -lpthreads -lmach -lexc - save_LIBS="$LIBS" - AC_CHECK_LIB(pthreads, pthread_mutex_lock, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthreads -lmach -lexc" - if test $ol_with_yielding_select = auto ; then - ol_with_yielding_select=yes - fi - ],:,[-lmach -lexc]) - LIBS="$save_LIBS" + OL_HEADER_LINUX_THREADS + OL_HEADER_GNU_PTH_PTHREAD_H + + if test $ol_cv_header_gnu_pth_pthread_h = no ; then + AC_CHECK_HEADERS(sched.h) fi - if test $ol_link_threads = no ; then - dnl try DEC Threads -lpthreads -lexc - save_LIBS="$LIBS" - AC_CHECK_LIB(pthreads, pthread_mutex_trylock, [ - ol_link_threads=posix - LTHREAD_LIBS="$LTHREAD_LIBS -lpthreads -lexc" - if test $ol_with_yielding_select = auto ; then - ol_with_yielding_select=yes - fi - ],:,[-lexc]) - LIBS="$save_LIBS" + dnl Now the hard part, how to link? + dnl + dnl currently supported checks: + dnl + dnl Check for no flags + dnl pthread_create() in $LIBS + dnl + dnl Check special pthread (final) flags + dnl [skipped] pthread_create() with -mt (Solaris) [disabled] + dnl pthread_create() with -kthread (FreeBSD) + dnl pthread_create() with -pthread (FreeBSD/Digital Unix) + dnl pthread_create() with -pthreads (?) + dnl pthread_create() with -mthreads (AIX) + dnl pthread_create() with -thread (?) + dnl + dnl Check pthread (final) libraries + dnl pthread_mutex_unlock() in -lpthread -lmach -lexc -lc_r (OSF/1) + dnl pthread_mutex_lock() in -lpthread -lmach -lexc (OSF/1) + dnl [skipped] pthread_mutex_trylock() in -lpthread -lexc (OSF/1) + dnl pthread_join() -Wl,-woff,85 -lpthread (IRIX) + dnl pthread_create() in -lpthread (many) + dnl pthread_create() in -lc_r (FreeBSD) + dnl + dnl Check pthread (draft4) flags (depreciated) + dnl pthread_create() with -threads (OSF/1) + dnl + dnl Check pthread (draft4) libraries (depreciated) + dnl pthread_mutex_unlock() in -lpthreads -lmach -lexc -lc_r (OSF/1) + dnl pthread_mutex_lock() in -lpthreads -lmach -lexc (OSF/1) + dnl pthread_mutex_trylock() in -lpthreads -lexc (OSF/1) + dnl pthread_create() in -lpthreads (many) + dnl + + dnl pthread_create in $LIBS + AC_CACHE_CHECK([for pthread_create in default libraries], + ol_cv_pthread_create,[ + AC_TRY_RUN(OL_PTHREAD_TEST_PROGRAM, + [ol_cv_pthread_create=yes], + [ol_cv_pthread_create=no], + [AC_TRY_LINK(OL_PTHREAD_TEST_INCLUDES,OL_PTHREAD_TEST_FUNCTION, + [ol_cv_pthread_create=yes], + [ol_cv_pthread_create=no])])]) + + if test $ol_cv_pthread_create != no ; then + ol_link_threads=posix + ol_link_pthreads="" fi + +dnl OL_PTHREAD_TRY([-mt], [ol_cv_pthread_mt]) + OL_PTHREAD_TRY([-kthread], [ol_cv_pthread_kthread]) + OL_PTHREAD_TRY([-pthread], [ol_cv_pthread_pthread]) + OL_PTHREAD_TRY([-pthreads], [ol_cv_pthread_pthreads]) + OL_PTHREAD_TRY([-mthreads], [ol_cv_pthread_mthreads]) + OL_PTHREAD_TRY([-thread], [ol_cv_pthread_thread]) + + OL_PTHREAD_TRY([-lpthread -lmach -lexc -lc_r], + [ol_cv_pthread_lpthread_lmach_lexc_lc_r]) + OL_PTHREAD_TRY([-lpthread -lmach -lexc], + [ol_cv_pthread_lpthread_lmach_lexc]) +dnl OL_PTHREAD_TRY([-lpthread -lexc], +dnl [ol_cv_pthread_lpthread_lexc]) + + OL_PTHREAD_TRY([-lpthread -Wl,-woff,85], + [ol_cv_pthread_lib_lpthread_woff]) + + OL_PTHREAD_TRY([-lpthread], [ol_cv_pthread_lpthread]) + OL_PTHREAD_TRY([-lc_r], [ol_cv_pthread_lc_r]) + + OL_PTHREAD_TRY([-threads], [ol_cv_pthread_threads]) + + OL_PTHREAD_TRY([-lpthreads -lmach -lexc -lc_r], + [ol_cv_pthread_lpthreads_lmach_lexc_lc_r]) + OL_PTHREAD_TRY([-lpthreads -lmach -lexc], + [ol_cv_pthread_lpthreads_lmach_lexc]) + OL_PTHREAD_TRY([-lpthreads -lexc], + [ol_cv_pthread_lpthreads_lexc]) + + OL_PTHREAD_TRY([-lpthreads],[ol_cv_pthread_lib_lpthreads]) if test $ol_link_threads != no ; then - AC_DEFINE(HAVE_PTHREADS) + AC_DEFINE(HAVE_PTHREADS,1, + [define if you have POSIX Threads]) + + LTHREAD_LIBS="$LTHREAD_LIBS $ol_link_pthreads" dnl save flags save_CPPFLAGS="$CPPFLAGS" @@ -751,13 +1132,14 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ dnl Digital UNIX has sched_yield() in -lrt AC_CHECK_LIB(rt, sched_yield, [LTHREAD_LIBS="$LTHREAD_LIBS -lrt" - AC_DEFINE(HAVE_SCHED_YIELD,1) + AC_DEFINE(HAVE_SCHED_YIELD,1, + [Define if you have the sched_yield function.]) ac_cv_func_sched_yield=yes], [ac_cv_func_sched_yield=no]) fi if test $ac_cv_func_sched_yield = no -a \ $ac_cv_func_pthread_yield = no ; then - dnl Solaris has sched_yield() in -lposix4 + dnl Solaris has sched_yield() stub in -lposix4 dnl but we'll use thr_yield instead. AC_CHECK_FUNCS(thr_yield) fi @@ -768,12 +1150,31 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ fi dnl Check functions for compatibility - AC_CHECK_FUNCS(pthread_kill pthread_detach) + AC_CHECK_FUNCS(pthread_kill) + + dnl Check for pthread_detach with inclusion + dnl as it's symbol may have been mangled. + AC_CACHE_CHECK([for pthread_detach with ], + [ol_cv_func_pthread_detach], [ + dnl save the flags + AC_TRY_LINK([ +#include +#ifndef NULL +#define NULL (void*)0 +#endif +], + [pthread_detach(NULL);], + [ol_cv_func_pthread_detach=yes], + [ol_cv_func_pthread_detach=no]) + ]) - if test $ac_cv_func_pthread_detach = no ; then + if test $ol_cv_func_pthread_detach = no ; then AC_MSG_ERROR([could not locate pthread_detach()]) fi + AC_DEFINE(HAVE_PTHREAD_DETACH,1, + [define if you have pthread_detach function]) + dnl Check for setconcurreny functions AC_CHECK_FUNCS( \ pthread_setconcurrency \ @@ -782,42 +1183,29 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ thr_getconcurrency \ ) - AC_MSG_CHECKING([if pthread_create() works]) - AC_CACHE_VAL(ol_cv_pthread_create_works,[ - AC_TRY_RUN([ -#include -#ifndef NULL -#define NULL (void*)0 -#endif + OL_SYS_LINUX_THREADS + OL_LINUX_THREADS -static void *task(p) - void *p; -{ - return (void *) (p == NULL); -} + if test $ol_cv_linux_threads = error; then + AC_MSG_ERROR([LinuxThreads header/library mismatch]); + fi -int main(argc, argv) - int argc; - char **argv; -{ - pthread_t t; - exit(pthread_create(&t, NULL, task, NULL)); -} -], + AC_CACHE_CHECK([if pthread_create() works], + ol_cv_pthread_create_works,[ + AC_TRY_RUN(OL_PTHREAD_TEST_PROGRAM, [ol_cv_pthread_create_works=yes], [ol_cv_pthread_create_works=no], [dnl assume yes ol_cv_pthread_create_works=yes])]) - AC_MSG_RESULT($ol_cv_pthread_create_works) if test $ol_cv_pthread_create_works = no ; then - AC_MSG_ERROR([pthread.h and pthread_create are not compatible]) + AC_MSG_ERROR([pthread_create is not usable, check environment settings]) fi dnl Check if select causes an yield if test $ol_with_yielding_select = auto ; then - AC_MSG_CHECKING([if select yields when using pthreads]) - AC_CACHE_VAL(ol_cv_pthread_select_yields,[ + AC_CACHE_CHECK([if select yields when using pthreads], + ol_cv_pthread_select_yields,[ AC_TRY_RUN([ #include #include @@ -875,7 +1263,11 @@ int main(argc, argv) #endif #endif +#if HAVE_PTHREADS_D4 + pthread_create(&t, pthread_attr_default, task, NULL); +#else pthread_create(&t, NULL, task, NULL); +#endif #if HAVE_SCHED_YIELD sched_yield(); /* make sure task runs first */ @@ -888,9 +1280,12 @@ int main(argc, argv) exit(2); }], [ol_cv_pthread_select_yields=no], - [ol_cv_pthread_select_yields=yes], [ - AC_MSG_ERROR([crossing compiling: use --with-yielding_select=yes|no|manual])])]) - AC_MSG_RESULT($ol_cv_pthread_select_yields) + [ol_cv_pthread_select_yields=yes], + [ol_cv_pthread_select_yields=cross])]) + + if test $ol_cv_pthread_select_yields = cross ; then + AC_MSG_ERROR([crossing compiling: use --with-yielding_select=yes|no|manual]) + fi if test $ol_cv_pthread_select_yields = yes ; then ol_with_yielding_select=yes @@ -944,7 +1339,8 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ if test $ol_link_threads != no ; then : check for cthread specific functionality here - AC_DEFINE(HAVE_MACH_CTHREADS,1) + AC_DEFINE(HAVE_MACH_CTHREADS,1, + [define if you have Mach Cthreads]) else AC_MSG_ERROR([could not link with Mach CThreads]) fi @@ -955,6 +1351,26 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ fi fi +if test $ol_with_threads = auto -o $ol_with_threads = yes \ + -o $ol_with_threads = pth ; then + + AC_CHECK_HEADERS(pth.h) + + if test $ac_cv_header_pth_h = yes ; then + AC_CHECK_LIB(pth, pth_version, [have_pth=yes], [have_pth=no]) + + if test $have_pth = yes ; then + AC_DEFINE(HAVE_GNU_PTH,1,[if you have GNU Pth]) + LTHREAD_LIBS="$LTHREAD_LIBS -lpth" + ol_link_threads=pth + + if test $ol_with_yielding_select = auto ; then + ol_with_yielding_select=yes + fi + fi + fi +fi + if test $ol_with_threads = auto -o $ol_with_threads = yes \ -o $ol_with_threads = lwp ; then @@ -964,7 +1380,8 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ AC_CHECK_LIB(thread, thr_create, [have_thr=yes], [have_thr=no]) if test $have_thr = yes ; then - AC_DEFINE(HAVE_THR) + AC_DEFINE(HAVE_THR,1, + [if you have Solaris LWP (thr) package]) LTHREAD_LIBS="$LTHREAD_LIBS -lthread" ol_link_threads=thr @@ -986,7 +1403,8 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ AC_CHECK_LIB(lwp, lwp_create, [have_lwp=yes], [have_lwp=no]) if test $have_lwp = yes ; then - AC_DEFINE(HAVE_LWP) + AC_DEFINE(HAVE_LWP,1, + [if you have SunOS LWP package]) LTHREAD_LIBS="$LTHREAD_LIBS -llwp" ol_link_threads=lwp @@ -998,7 +1416,8 @@ if test $ol_with_threads = auto -o $ol_with_threads = yes \ fi if test $ol_with_yielding_select = yes ; then - AC_DEFINE(HAVE_YIELDING_SELECT,1) + AC_DEFINE(HAVE_YIELDING_SELECT,1, + [define if select implicitly yields]) fi if test $ol_with_threads = manual ; then @@ -1009,14 +1428,14 @@ if test $ol_with_threads = manual ; then AC_CHECK_HEADERS(pthread.h sched.h) AC_CHECK_FUNCS(sched_yield pthread_yield) - OL_LINUX_THREADS + OL_HEADER_LINUX_THREADS AC_CHECK_HEADERS(mach/cthreads.h) AC_CHECK_HEADERS(lwp/lwp.h) AC_CHECK_HEADERS(thread.h synch.h) fi -if test $ol_link_threads != no ; then +if test $ol_link_threads != no -a $ol_link_threads != nt ; then dnl needed to get reentrant/threadsafe versions dnl AC_DEFINE(REENTRANT,1) @@ -1025,23 +1444,28 @@ if test $ol_link_threads != no ; then AC_DEFINE(_THREAD_SAFE,1) AC_DEFINE(THREADSAFE,1) AC_DEFINE(_THREADSAFE,1) + AC_DEFINE(_SGI_MP_SOURCE,1) - dnl this might cause the errno symbol to be - dnl replaced with a function to get a thread specific errno. - dnl check to see if everything needs to be compiled - dnl with the thread libraries + dnl The errno declaration may dependent upon _REENTRANT. + dnl If it does, we must link with thread support. AC_CACHE_CHECK([for thread specific errno], [ol_cv_errno_thread_specific], [ - AC_TRY_LINK([ -#include - ], [ -int x = errno; - ], + AC_TRY_LINK([#include ], [errno = 0;], [ol_cv_errno_thread_specific=yes], [ol_cv_errno_thread_specific=no]) ]) - if test $ol_cv_errno_thread_specific != yes ; then + dnl The h_errno declaration may dependent upon _REENTRANT. + dnl If it does, we must link with thread support. + AC_CACHE_CHECK([for thread specific h_errno], + [ol_cv_h_errno_thread_specific], [ + AC_TRY_LINK([#include ], [h_errno = 0;], + [ol_cv_h_errno_thread_specific=yes], + [ol_cv_h_errno_thread_specific=no]) + ]) + + if test $ol_cv_errno_thread_specific != yes \ + -o $ol_cv_h_errno_thread_specific != yes ; then LIBS="$LTHREAD_LIBS $LIBS" LTHREAD_LIBS="" fi @@ -1075,7 +1499,7 @@ dnl #ifdef LDAP_R_COMPILE dnl # include LDAP_R_COMPILE dnl #endif dnl -dnl LDAP_R_COMIPLE is defined by libldap_r/Makefile.in +dnl LDAP_R_COMPILE is defined by libldap_r/Makefile.in dnl specifically for compiling the threadsafe version of dnl the ldap library (-lldap_r). dnl @@ -1088,7 +1512,6 @@ dnl save_CPPFLAGS="$CPPFLAGS" dnl save_LIBS="$LIBS" dnl LIBS="$LTHREAD_LIBS $LIBS" dnl AC_CHECK_FUNCS( \ -dnl strtok_r \ dnl gmtime_r \ dnl gethostbyaddr_r gethostbyname_r \ dnl feof_unlocked unlocked_feof \ @@ -1099,8 +1522,6 @@ dnl CPPFLAGS="$save_CPPFLAGS" dnl LIBS="$save_LIBS" fi -dnl ---------------------------------------------------------------- - if test $ol_link_threads = no ; then if test $ol_with_threads = yes ; then AC_MSG_ERROR([no suitable thread support]) @@ -1111,10 +1532,17 @@ if test $ol_link_threads = no ; then ol_with_threads=no fi - AC_DEFINE(NO_THREADS,1) + AC_DEFINE(NO_THREADS,1, + [define if you have (or want) no threads]) LTHREAD_LIBS="" fi +if test $ol_link_threads != no ; then + AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_THREAD_SAFE,1) +fi + +dnl ---------------------------------------------------------------- + ol_link_ldbm=no if test $ol_with_ldbm_api = auto -o $ol_with_ldbm_api = db2 ; then OL_BERKELEY_DB2 @@ -1124,11 +1552,15 @@ if test $ol_with_ldbm_api = auto -o $ol_with_ldbm_api = db2 ; then ol_with_ldbm_api=db2 if test $ol_with_ldbm_type = hash ; then - AC_DEFINE(LDBM_USE_DBHASH,1) + AC_DEFINE(LDBM_USE_DBHASH,1, + [define this to use DBHASH w/ LDBM backend]) else - AC_DEFINE(LDBM_USE_DBBTREE,1) + AC_DEFINE(LDBM_USE_DBBTREE,1, + [define this to use DBBTREE w/ LDBM backend]) fi + OL_BERKELEY_DB2_DB_THREAD + dnl $ol_cv_lib_db2 should be yes or -ldb dnl (it could be no, but that would be an error if test $ol_cv_lib_db2 != yes ; then @@ -1139,7 +1571,11 @@ fi ol_link_bdb2=no if test $ol_link_ldbm = db2 -a $ol_enable_bdb2 != no ; then - ol_link_bdb2=yes + if test $ol_cv_berkeley_db2_db_thread != no ; then + ol_link_bdb2=yes + else + AC_MSG_WARN([Installed BerkeleyDB does not provide DB_THREAD support.]) + fi fi if test $ol_with_ldbm_api = auto -o $ol_with_ldbm_api = db ; then @@ -1150,9 +1586,11 @@ if test $ol_with_ldbm_api = auto -o $ol_with_ldbm_api = db ; then ol_with_ldbm_api=db if test $ol_with_ldbm_type = hash ; then - AC_DEFINE(LDBM_USE_DBHASH,1) + AC_DEFINE(LDBM_USE_DBHASH,1, + [define this to use DBHASH w/ LDBM backend]) else - AC_DEFINE(LDBM_USE_DBBTREE,1) + AC_DEFINE(LDBM_USE_DBBTREE,1, + [define this to use DBBTREE w/ LDBM backend]) fi dnl $ol_cv_lib_db should be yes or -ldb @@ -1177,6 +1615,18 @@ if test $ol_link_ldbm = no -a $ol_with_ldbm_type = btree ; then ol_with_ldbm_api=none fi +if test $ol_with_ldbm_api = auto -o $ol_with_ldbm_api = mdbm ; then + OL_MDBM + + if test $ol_cv_mdbm = yes ; then + ol_link_ldbm=mdbm + ol_with_ldbm_api=mdbm + if test $ol_cv_lib_mdbm != yes ; then + LDBM_LIBS="$LDBM_LIBS $ol_cv_lib_mdbm" + fi + fi +fi + if test $ol_with_ldbm_api = auto -o $ol_with_ldbm_api = gdbm ; then OL_GDBM @@ -1215,19 +1665,33 @@ if test $ol_link_ldbm = no -a $ol_enable_ldbm != no ; then ol_enable_ldbm=no fi +dnl ---------------------------------------------------------------- +if test $ol_enable_dynamic = yes -a $enable_shared = yes ; then + LINK_BINS_DYNAMIC="yes" +else + LINK_BINS_DYNAMIC="no" +fi + +dnl ---------------------------------------------------------------- if test $ol_enable_wrappers != no ; then AC_CHECK_HEADERS(tcpd.h) if test $ac_cv_header_tcpd_h != yes ; then have_wrappers=no else - AC_CHECK_LIB(wrap, main, - [have_wrappers=yes], [have_wrappers=no]) + AC_TRY_COMPILE([ +int allow_severity = 0; +int deny_severity = 0; + ],[hosts_access()],[have_wrappers=yes],[have_wrappers=no]) fi if test $have_wrappers = yes ; then - AC_DEFINE(HAVE_TCPD) - SLAPD_LIBS="$SLAPD_LIBS -lwrap" + AC_DEFINE(HAVE_TCPD,1, [define if you have -lwrap]) + WRAP_LIBS="-lwrap" + + dnl We add another check for -lnsl since some libwrap's + dnl need it, but it isn't always included from above + AC_CHECK_LIB(nsl, main) else AC_MSG_WARN(could not find -lwrap) if test $ol_enable_wrappers = yes ; then @@ -1236,9 +1700,11 @@ if test $ol_enable_wrappers != no ; then AC_MSG_WARN(disabling wrappers support) ol_enable_wrappers=no + WRAP_LIBS="" fi fi +dnl ---------------------------------------------------------------- if test $ol_enable_syslog != no ; then AC_CHECK_FUNC(openlog) if test $ac_cv_func_openlog = no -a $ol_enable_syslog = yes; then @@ -1247,19 +1713,50 @@ if test $ol_enable_syslog != no ; then ol_enable_syslog=$ac_cv_func_openlog fi +dnl ---------------------------------------------------------------- if test $ol_enable_dmalloc != no ; then AC_CHECK_HEADERS(dmalloc.h) AC_CHECK_LIB(dmalloc, dmalloc_shutdown) fi -# ud needs termcap (should insert check here) +dnl ---------------------------------------------------------------- +dnl TCL +if test $ol_enable_tcl != no ; then + AC_CHECK_HEADERS(tcl.h) + + if test $ac_cv_header_tcl_h != yes ; then + have_tcl=no + else + for lib in tcl tcl7.6 tcl8.0 tcl8.2 ; do + AC_CHECK_LIB($lib,main, + [have_tcl=yes + if test x"$ol_with_tcl_module" = "xstatic" ; then + SLAPD_LIBS="$SLAPD_LIBS -l${lib}" + else + MOD_TCL_LIB="-l${lib}" + fi;break],[have_tcl=no]) + done + fi + + if test $have_tcl != yes ; then + AC_MSG_WARN([could not find -ltcl]) + if test $ol_enable_tcl = yes ; then + AC_MSG_ERROR([could not find tcl, select appropriate options or disable]) + fi + + ol_enable_tcl=no + fi +fi + +dnl ---------------------------------------------------------------- +dnl ud needs termcap (should insert check here) ol_link_termcap=no AC_CHECK_HEADERS(termcap.h ncurses.h) if test $ol_link_termcap = no ; then AC_CHECK_LIB(termcap, tputs, [have_termcap=yes], [have_termcap=no]) if test $have_termcap = yes ; then - AC_DEFINE(HAVE_TERMCAP) + AC_DEFINE(HAVE_TERMCAP, 1, [define if you have -ltermcap]) ol_link_termcap=yes TERMCAP_LIBS=-ltermcap fi @@ -1268,25 +1765,118 @@ fi if test $ol_link_termcap = no ; then AC_CHECK_LIB(ncurses, initscr, [have_ncurses=yes], [have_ncurses=no]) if test $have_ncurses = yes ; then - AC_DEFINE(HAVE_NCURSES) + AC_DEFINE(HAVE_NCURSES, 1, [define if you have -lncurses]) ol_link_termcap=yes TERMCAP_LIBS=-lncurses fi fi if test $ol_link_termcap = no ; then - AC_DEFINE(NO_TERMCAP,1) + AC_DEFINE(NO_TERMCAP,1, [define if you have no termcap support]) TERMCAP_LIBS= fi -# FreeBSD (and others) have crypt(3) in -lcrypt +dnl ---------------------------------------------------------------- +dnl +dnl Check for Cyrus SASL +dnl +ol_link_sasl=no +if test $ol_with_cyrus_sasl != no ; then + AC_CHECK_HEADER(sasl.h) + + if test $ac_cv_header_sasl_h = yes ; then + AC_CHECK_LIB(sasl, sasl_client_init, + [have_cyrus_sasl=yes], [have_cyrus_sasl=no]) + + if test $have_cyrus_sasl != no ; then + SASL_LIBS="-lsasl" + AC_DEFINE(HAVE_CYRUS_SASL,1,[define if you have Cyrus SASL]) + ol_link_sasl=yes + fi + fi + + if test $ol_link_sasl = no -a $ol_with_cyrus_sasl = yes ; then + AC_MSG_ERROR(no suitable API for --with-cyrus-sasl=$ol_with_cyrus_sasl) + fi +fi + +dnl ---------------------------------------------------------------- +dnl Check for entropy sources +if test $cross_compiling != yes ; then + dev=no + if test -r /dev/urandom ; then + dev="/dev/urandom"; + elif test -r /idev/urandom ; then + dev="/idev/urandom"; + elif test -r /dev/srandom ; then + dev="/dev/srandom"; + elif test -r /dev/random ; then + dev="/dev/random"; + elif test -r /idev/random ; then + dev="/idev/random"; + fi + + if test $dev != no ; then + AC_DEFINE_UNQUOTED(URANDOM_DEVICE,"$dev",[set to urandom device]) + fi +fi + +dnl ---------------------------------------------------------------- +dnl +dnl Check for fetch URL support +dnl should be extended to support other fetch URL APIs +dnl +ol_link_fetch=no +if test $ol_with_fetch != no ; then + OL_LIB_FETCH + + if test $ol_cv_lib_fetch != no ; then + LDIF_LIBS="$LDIF_LIBS $ol_link_fetch" + ol_link_fetch=freebsd + + elif test $ol_with_fetch != auto ; then + AC_MSG_ERROR(no suitable API for --with-fetch=$ol_with_fetch) + fi +fi + +dnl ---------------------------------------------------------------- +dnl +dnl Check for GNU readline +dnl +ol_link_readline=no +if test $ol_with_readline != no ; then + AC_CHECK_HEADERS(readline/readline.h readline/history.h) + + if test $ac_cv_header_readline_readline_h = yes ; then + save_LIBS="$LIBS" + LIBS="$TERMCAP_LIBS $LIBS" + AC_CHECK_LIB(readline, readline, + [have_readline=yes], [have_readline=no]) + LIBS="$save_LIBS" + + if test $have_readline = yes ; then + ol_with_readline=found + ol_link_readline=yes + + READLINE_LIBS="-lreadline" + fi + fi +fi + +if test $ol_link_readline = yes ; then + AC_DEFINE(HAVE_READLINE, 1, [define if you have -lreadline]) +fi + + +dnl ---------------------------------------------------------------- +dnl FreeBSD (and others) have crypt(3) in -lcrypt if test $ol_enable_crypt != no ; then AC_CHECK_FUNC(crypt, [have_crypt=yes], [ AC_CHECK_LIB(crypt, crypt, [LUTIL_LIBS="$LUTIL_LIBS -lcrypt" have_crypt=yes], [have_crypt=no])]) if test $have_crypt = yes ; then - AC_DEFINE(HAVE_CRYPT,1) + AC_DEFINE(HAVE_CRYPT,1, [define if crypt(3) is available]) else AC_MSG_WARN(could not find crypt) if test $ol_enable_crypt = yes ; then @@ -1298,102 +1888,93 @@ if test $ol_enable_crypt != no ; then fi fi -# FreeBSD (and others) have setproctitle(3) in -lutil +dnl ---------------------------------------------------------------- +dnl FreeBSD (and others) have setproctitle(3) in -lutil if test $ol_enable_proctitle != no ; then AC_CHECK_FUNC(setproctitle, [have_setproctitle=yes], [ AC_CHECK_LIB(util, setproctitle, [have_setproctitle=yes LUTIL_LIBS="$LUTIL_LIBS -lutil"], [have_setproctitle=no - LIBOBJS="$LIBOBJS setproctitle.o"])]) + LIBOBJS="$LIBOBJS setproctitle.o" + LIBSRCS="$LIBSRCS setproctitle.c"])]) if test $have_setproctitle = yes ; then - AC_DEFINE(HAVE_SETPROCTITLE,1) + AC_DEFINE(HAVE_SETPROCTITLE,1, + [define if setproctitle(3) is available]) fi fi -dnl ---------------------------------------------------------------- -dnl Checks for header files. -AC_HEADER_STDC - -if test $ac_cv_header_stdc != yes; then - AC_MSG_WARN([could not Standard C compliant headers]) -fi - -AC_HEADER_DIRENT -AC_HEADER_SYS_WAIT -AM_HEADER_TIOCGWINSZ_NEEDS_SYS_IOCTL -if test $am_cv_sys_posix_termios = yes ; then - AC_DEFINE(HAVE_POSIX_TERMIOS,1) -fi - -AC_CHECK_HEADERS( \ - crypt.h \ - errno.h \ - fcntl.h \ - filio.h \ - getopt.h \ - libutil.h \ - limits.h \ - malloc.h \ - memory.h \ - regex.h \ - psap.h \ - pwd.h \ - sgtty.h \ - stdarg.h \ - stddef.h \ - string.h \ - strings.h \ - sysexits.h \ - sys/file.h \ - sys/filio.h \ - sys/errno.h \ - sys/ioctl.h \ - sys/param.h \ - sys/resource.h \ - sys/socket.h \ - sys/syslog.h \ - sys/time.h \ - sys/types.h \ - syslog.h \ - termios.h \ - unistd.h \ -) - dnl ---------------------------------------------------------------- dnl Checks for typedefs, structures, and compiler characteristics. -AC_TYPE_GETGROUPS dnl requires AC_TYPE_UID_T AC_TYPE_MODE_T AC_TYPE_OFF_T AC_TYPE_PID_T AM_TYPE_PTRDIFF_T AC_TYPE_SIGNAL -OL_TYPE_SIG_ATOMIC_T AC_TYPE_SIZE_T + +AC_CHECK_TYPE(ssize_t, [signed int]) +AC_CHECK_TYPE(caddr_t, [char *]) + +OL_TYPE_SOCKLEN_T AC_STRUCT_ST_BLKSIZE AC_HEADER_TIME AC_STRUCT_TM +AC_TYPE_UID_T +OL_TYPE_SIG_ATOMIC_T + +dnl AC_TYPE_GETGROUPS + +OL_STRUCT_PASSWD_PW_GECOS +OL_STRUCT_PASSWD_PW_PASSWD OL_C_UPPER_LOWER AC_C_CONST OL_C_VOLATILE if test $cross_compiling = yes ; then - AC_DEFINE(CROSS_COMPILING, 1) + AC_DEFINE(CROSS_COMPILING, 1, [define if cross compiling]) else AC_C_BIGENDIAN - AC_CHECK_SIZEOF(short) - AC_CHECK_SIZEOF(int) - AC_CHECK_SIZEOF(long) fi +AC_COMPILE_CHECK_SIZEOF(short) +AC_COMPILE_CHECK_SIZEOF(int) +AC_COMPILE_CHECK_SIZEOF(long) + +if test "$ac_cv_sizeof_int" -lt 4 ; then + AC_MSG_WARN([OpenLDAP requires 'int' to be 32 bits or greater.]) + + AC_DEFINE(LBER_INT_T,long) +else + AC_DEFINE(LBER_INT_T,int) +fi + +AC_DEFINE(LBER_LEN_T,long) +AC_DEFINE(LBER_SOCKET_T,int) +AC_DEFINE(LBER_TAG_T,long) + dnl ---------------------------------------------------------------- dnl Checks for library functions. AC_FUNC_MEMCMP dnl AM_FUNC_MKTIME dnl checks for sys/time.h and unistd.h AC_FUNC_STRFTIME dnl AM_FUNC_STRTOD + +OL_FUNC_INET_ATON + +dnl Check for NT specific routines +AC_CHECK_FUNC(_spawnlp, AC_DEFINE(HAVE_SPAWNLP,1,[if you have spawnlp()])) + +AC_CHECK_FUNC(_snprintf, [ac_cv_func_snprintf=yes + AC_DEFINE(snprintf, _snprintf, [define to snprintf routine]) +]) + +AC_CHECK_FUNC(_vsnprintf, [ac_cv_func_vsnprintf=yes + AC_DEFINE(vsnprintf, _vsnprintf, [define to vsnprintf routine]) +]) + AC_FUNC_VPRINTF if test $ac_cv_func_vprintf = yes ; then @@ -1403,67 +1984,65 @@ fi AC_CHECK_FUNCS( \ bcopy \ + closesocket \ + endgrent \ + endpwent \ flock \ getdtablesize \ + getgrgid \ gethostname \ + getpass \ getpwuid \ + getpwnam \ + getspnam \ gettimeofday \ + initgroups \ lockf \ memcpy \ memmove \ mkstemp \ - select \ + pipe \ + read \ + recv \ + recvfrom \ setpwfile \ + setgid \ + setegid \ setsid \ + setuid \ + seteuid \ + sigaction \ signal \ sigset \ snprintf \ - socket \ strdup \ strerror \ strpbrk \ strrchr \ strsep \ strstr \ - strtok \ strtol \ strtoul \ strspn \ sysconf \ waitpid \ + wait4 \ + write \ + send \ + sendto \ ) -# these functions are required to build a thread_safe -lldap -AC_CHECK_FUNCS( \ - strtok_r \ - ctime_r \ - gethostbyaddr_r \ - gethostbyname_r \ -) - -if test "$ac_cv_func_ctime_r" = yes ; then - OL_FUNC_CTIME_R_NARGS -else - ol_cv_func_ctime_r=0 -fi - -if test "$ac_cv_func_strtok_r" = yes \ - -a "$ac_cv_func_ctime_r" = yes \ - -a "$ol_cv_func_ctime_r_nargs" -ge 2 -a "$ol_cv_func_ctime_r_nargs" -le 3 \ - -a "$ac_cv_func_gethostbyaddr_r" = yes \ - -a "$ac_cv_func_gethostbyname_r" = yes \ - ; then +dnl We actually may need to replace more than this. +AC_REPLACE_FUNCS(getopt tempnam) - AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_REENTRANT, 1) +if test "$ac_cv_func_getopt" != yes; then + LIBSRCS="$LIBSRCS getopt.c" fi -if test $ol_link_threads != no ; then - AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_THREAD_SAFE, 1) +if test "$ac_cv_func_tempnam" != yes; then + LIBSRCS="$LIBSRCS tempnam.c" fi -dnl We actually may need to replace more than this. -AC_REPLACE_FUNCS(getopt tempnam) - dnl ---------------------------------------------------------------- # Check Configuration OL_SYS_ERRLIST @@ -1472,74 +2051,152 @@ dnl ---------------------------------------------------------------- dnl Sort out defines if test "$ol_enable_debug" != no ; then - AC_DEFINE(LDAP_DEBUG,1) + AC_DEFINE(LDAP_DEBUG,1, + [define this to add debugging code]) fi if test "$ol_enable_syslog" = yes ; then - AC_DEFINE(LDAP_SYSLOG,1) + AC_DEFINE(LDAP_SYSLOG,1, + [define this to add syslog code]) fi if test "$ol_enable_libui" = yes ; then - AC_DEFINE(LDAP_LIBUI,1) + AC_DEFINE(LDAP_LIBUI,1, + [define this for LDAP User Interface support]) fi if test "$ol_enable_cache" = no ; then - AC_DEFINE(LDAP_NOCACHE,1) + AC_DEFINE(LDAP_NOCACHE,1, + [define this to remove -lldap cache support]) fi if test "$ol_enable_dns" != no ; then - AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_V2_DNS,LDAP_VENDOR_VERSION,1) + AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_V2_DNS,LDAP_VENDOR_VERSION) fi if test "$ol_enable_proctitle" != no ; then - AC_DEFINE(LDAP_PROCTITLE,1) + AC_DEFINE(LDAP_PROCTITLE,1, + [define this for LDAP process title support]) fi if test "$ol_enable_referrals" != no ; then - AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_V2_REFERRALS,LDAP_VENDOR_VERSION,1) + AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_V2_REFERRALS,LDAP_VENDOR_VERSION) fi if test "$ol_enable_cldap" != no ; then - AC_DEFINE(LDAP_CONNECTIONLESS,1) + AC_DEFINE(LDAP_CONNECTIONLESS,1,[define to support CLDAP]) fi -if test "$ol_enable_aclgroups" != no ; then - AC_DEFINE(SLAPD_ACLGROUPS,1) -fi if test "$ol_enable_crypt" != no ; then - AC_DEFINE(SLAPD_CRYPT,1) + AC_DEFINE(SLAPD_CRYPT,1,[define to support crypt(3) passwords]) fi if test "$ol_enable_cleartext" != no ; then - AC_DEFINE(SLAPD_CLEARTEXT,1) + AC_DEFINE(SLAPD_CLEARTEXT,1,[define to support cleartext passwords]) +fi +if test "$ol_enable_multimaster" != no ; then + AC_DEFINE(SLAPD_MULTIMASTER,1,[define to support multimaster replication]) fi if test "$ol_enable_phonetic" != no ; then - AC_DEFINE(SLAPD_PHONETIC,1) + AC_DEFINE(SLAPD_PHONETIC,1,[define to support phonetic]) fi if test "$ol_enable_rlookups" != no ; then - AC_DEFINE(SLAPD_RLOOKUPS,1) + AC_DEFINE(SLAPD_RLOOKUPS,1,[define to support reverse lookups]) +fi +if test "$ol_enable_aci" != no ; then + AC_DEFINE(SLAPD_ACI_ENABLED,1,[define to support per-object ACIs]) +fi +if test "$ol_enable_discreteaci" != no ; then + AC_DEFINE(SLAPD_ACI_DISCRETE_RIGHTS,1,[define to support discrete rights in ACIs]) +fi + +if test "$ol_link_modules" != no ; then + AC_DEFINE(SLAPD_MODULES,1,[define to support modules]) + BUILD_SLAPD=yes + SLAPD_MODULES_LDFLAGS="-dlopen self" fi if test "$ol_link_bdb2" != no ; then - AC_DEFINE(SLAPD_BDB2,1) + AC_DEFINE(SLAPD_BDB2,1,[define to support BDB2 backend]) BUILD_SLAPD=yes BUILD_BDB2=yes + if test "$ol_with_bdb2_module" != static ; then + AC_DEFINE(SLAPD_BDB2_DYNAMIC,1, + [define to support dynamic BDB2 backend]) + BUILD_BDB2=mod + BUILD_BDB2_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-bdb2/back_bdb2.la" + fi +fi + +if test "$ol_enable_ldap" != no ; then + AC_DEFINE(SLAPD_LDAP,1,[define to support LDAP backend]) + BUILD_SLAPD=yes + BUILD_LDAP=yes + if test "$ol_with_ldap_module" != static ; then + AC_DEFINE(SLAPD_LDAP_DYNAMIC,1, + [define to support dynamic LDAP backend]) + BUILD_LDAP=mod + BUILD_LDAP_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-ldap/back_ldap.la" + fi fi if test "$ol_link_ldbm" != no ; then - AC_DEFINE(SLAPD_LDBM,1) + AC_DEFINE(SLAPD_LDBM,1,[define to support LDBM backend]) BUILD_SLAPD=yes BUILD_LDBM=yes + if test "$ol_with_ldbm_module" != static ; then + AC_DEFINE(SLAPD_LDBM_DYNAMIC,1, + [define to support dynamic LDBM backend]) + BUILD_LDBM=mod + BUILD_LDBM_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-ldbm/back_ldbm.la" + fi fi if test "$ol_enable_passwd" != no ; then - AC_DEFINE(SLAPD_PASSWD,1) + AC_DEFINE(SLAPD_PASSWD,1,[define to support PASSWD backend]) BUILD_SLAPD=yes BUILD_PASSWD=yes + if test "$ol_with_passwd_module" != static ; then + AC_DEFINE(SLAPD_PASSWD_DYNAMIC,1, + [define to support dynamic PASSWD backend]) + BUILD_PASSWD=mod + BUILD_PASSWD_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-passwd/back_passwd.la" + fi fi -if test "$ol_enable_perl" != no ; then - AC_DEFINE(SLAPD_PERL,1) +if test "$ol_link_perl" != no ; then + AC_DEFINE(SLAPD_PERL,1,[define to support PERL backend]) BUILD_SLAPD=yes BUILD_PERL=yes + if test "$ol_with_perl_module" != static ; then + AC_DEFINE(SLAPD_PERL_DYNAMIC,1, + [define to support dynamic PERL backend]) + BUILD_PERL=mod + BUILD_PERL_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-perl/back_perl.la" + fi fi if test "$ol_enable_shell" != no ; then - AC_DEFINE(SLAPD_SHELL,1) + AC_DEFINE(SLAPD_SHELL,1,[define to support SHELL backend]) BUILD_SLAPD=yes BUILD_SHELL=yes + if test "$ol_with_shell_module" != static ; then + AC_DEFINE(SLAPD_SHELL_DYNAMIC,1, + [define to support dynamic SHELL backend]) + BUILD_SHELL=mod + BUILD_SHELL_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-shell/back_shell.la" + fi +fi + +if test "$ol_enable_tcl" != no ; then + AC_DEFINE(SLAPD_TCL,1,[define to support TCL backend]) + BUILD_SLAPD=yes + BUILD_TCL=yes + if test "$ol_with_tcl_module" != static; then + AC_DEFINE(SLAPD_TCL_DYNAMIC,1, + [define to support dynamic TCL backend]) + BUILD_TCL=mod + BUILD_TCL_DYNAMIC=shared + SLAPD_MODULES_LIST="$SLAPD_MODULES_LIST -dlopen \$(SLAP_DIR)back-tcl/back_tcl.la" + fi fi if test "$ol_enable_slurpd" != no -a "$ol_link_threads" != no -a \ @@ -1553,28 +2210,74 @@ fi dnl ---------------------------------------------------------------- +if test "$LINK_BINS_DYNAMIC" = yes; then + LIB_LINKAGE=DYN + LT_LIB_LINKAGE=shared +else + LIB_LINKAGE=STAT + LT_LIB_LINKAGE=static +fi + +if test "$ac_cv_mingw32" = yes ; then + PLAT=NT + DYN_EXT=dll +else + PLAT=UNIX + DYN_EXT=so +fi + +AC_SUBST(LIBSRCS) + +AC_SUBST(PLAT) +AC_SUBST(LIB_LINKAGE) +AC_SUBST(LT_LIB_LINKAGE) +AC_SUBST(DYN_EXT) + AC_SUBST(BUILD_LDAPD) AC_SUBST(BUILD_SLAPD) AC_SUBST(BUILD_BDB2) + AC_SUBST(BUILD_LDAP) AC_SUBST(BUILD_LDBM) AC_SUBST(BUILD_PASSWD) AC_SUBST(BUILD_PERL) + AC_SUBST(BUILD_QUIPU) AC_SUBST(BUILD_SHELL) + AC_SUBST(BUILD_TCL) + AC_SUBST(BUILD_BDB2_DYNAMIC) + AC_SUBST(BUILD_LDAP_DYNAMIC) + AC_SUBST(BUILD_LDBM_DYNAMIC) + AC_SUBST(BUILD_PASSWD_DYNAMIC) + AC_SUBST(BUILD_PERL_DYNAMIC) + AC_SUBST(BUILD_SHELL_DYNAMIC) + AC_SUBST(BUILD_TCL_DYNAMIC) AC_SUBST(BUILD_SLURPD) AC_SUBST(LDAP_LIBS) AC_SUBST(LDAPD_LIBS) +AC_SUBST(LDIF_LIBS) AC_SUBST(SLAPD_LIBS) AC_SUBST(SLURPD_LIBS) AC_SUBST(LDBM_LIBS) AC_SUBST(LTHREAD_LIBS) AC_SUBST(LUTIL_LIBS) +AC_SUBST(WRAP_LIBS) +AC_SUBST(MOD_TCL_LIB) +AC_SUBST(LINK_BINS_DYNAMIC) + +AC_SUBST(SLAPD_MODULES_CPPFLAGS) +AC_SUBST(SLAPD_MODULES_LDFLAGS) +AC_SUBST(SLAPD_MODULES_LIST) -AC_SUBST(SLAPD_PERL_CPPFLAGS) +AC_SUBST(PERL_CPPFLAGS) AC_SUBST(SLAPD_PERL_LDFLAGS) +AC_SUBST(MOD_PERL_LDFLAGS) AC_SUBST(KRB_LIBS) +AC_SUBST(READLINE_LIBS) +AC_SUBST(SASL_LIBS) AC_SUBST(TERMCAP_LIBS) +AC_SUBST(TLS_LIBS) +AC_SUBST(MODULES_LIBS) dnl ---------------------------------------------------------------- dnl final output @@ -1608,14 +2311,21 @@ libraries/liblutil/Makefile:build/top.mk:libraries/liblutil/Makefile.in:build/li servers/Makefile:build/top.mk:servers/Makefile.in:build/dir.mk \ servers/ldapd/Makefile:build/top.mk:servers/ldapd/Makefile.in:build/srv.mk \ servers/slapd/Makefile:build/top.mk:servers/slapd/Makefile.in:build/srv.mk \ -servers/slapd/back-ldbm/Makefile:build/top.mk:servers/slapd/back-ldbm/Makefile.in:build/srv.mk \ -servers/slapd/back-passwd/Makefile:build/top.mk:servers/slapd/back-passwd/Makefile.in:build/srv.mk \ -servers/slapd/back-perl/Makefile:build/top.mk:servers/slapd/back-perl/Makefile.in:build/srv.mk \ -servers/slapd/back-shell/Makefile:build/top.mk:servers/slapd/back-shell/Makefile.in:build/srv.mk \ +servers/slapd/back-bdb2/Makefile:build/top.mk:servers/slapd/back-bdb2/Makefile.in:build/mod.mk \ +servers/slapd/back-ldap/Makefile:build/top.mk:servers/slapd/back-ldap/Makefile.in:build/mod.mk \ +servers/slapd/back-ldbm/Makefile:build/top.mk:servers/slapd/back-ldbm/Makefile.in:build/mod.mk \ +servers/slapd/back-passwd/Makefile:build/top.mk:servers/slapd/back-passwd/Makefile.in:build/mod.mk \ +servers/slapd/back-perl/Makefile:build/top.mk:servers/slapd/back-perl/Makefile.in:build/mod.mk \ +servers/slapd/back-shell/Makefile:build/top.mk:servers/slapd/back-shell/Makefile.in:build/mod.mk \ +servers/slapd/back-tcl/Makefile:build/top.mk:servers/slapd/back-tcl/Makefile.in:build/mod.mk \ servers/slapd/shell-backends/Makefile:build/top.mk:servers/slapd/shell-backends/Makefile.in:build/srv.mk \ servers/slapd/tools/Makefile:build/top.mk:servers/slapd/tools/Makefile.in \ servers/slurpd/Makefile:build/top.mk:servers/slurpd/Makefile.in:build/srv.mk \ -tests/Makefile:build/top.mk:tests/Makefile.in \ +tests/Makefile:build/top.mk:tests/Makefile.in:build/dir.mk \ +tests/progs/Makefile:build/top.mk:tests/progs/Makefile.in:build/rules.mk \ +contrib/Makefile:build/top.mk:contrib/Makefile.in:build/dir.mk \ +contrib/saucer/Makefile:build/top.mk:contrib/saucer/Makefile.in:build/rules.mk \ +contrib/web_ldap/Makefile:build/top.mk:contrib/web_ldap/Makefile.in:build/rules.mk \ ,[ date > stamp-h echo Please \"make depend\" to build dependencies