mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
3067 lines
82 KiB
Plaintext
3067 lines
82 KiB
Plaintext
dnl $OpenLDAP$
|
|
dnl This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
dnl
|
|
dnl Copyright 1998-2004 The OpenLDAP Foundation.
|
|
dnl All rights reserved.
|
|
dnl
|
|
dnl Redistribution and use in source and binary forms, with or without
|
|
dnl modification, are permitted only as authorized by the OpenLDAP
|
|
dnl Public License.
|
|
dnl
|
|
dnl A copy of this license is available in the file LICENSE in the
|
|
dnl top-level directory of the distribution or, alternatively, at
|
|
dnl <http://www.OpenLDAP.org/license.html>.
|
|
dnl
|
|
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$], $")] [
|
|
|
|
# This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
#
|
|
# Copyright 1998-2004 The OpenLDAP Foundation.
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted only as authorized by the OpenLDAP
|
|
# Public License.
|
|
#
|
|
# A copy of this license is available in the file LICENSE in the
|
|
# top-level directory of the distribution or, alternatively, at
|
|
# <http://www.OpenLDAP.org/license.html>.
|
|
|
|
echo "Copyright 1998-2004 The OpenLDAP Foundation. All rights reserved."
|
|
echo " Restrictions apply, see COPYRIGHT and LICENSE files."
|
|
])dnl
|
|
dnl ----------------------------------------------------------------
|
|
dnl Disable config.cache!
|
|
define([AC_CACHE_LOAD], )dnl
|
|
define([AC_CACHE_SAVE], )dnl
|
|
dnl ================================================================
|
|
dnl Configure.in for OpenLDAP
|
|
AC_INIT(build/version.sh)dnl
|
|
|
|
# set unset (borrowed from autoconf 2.49c)
|
|
if (OL_FOO=OL_FOO; unset OL_FOO) >/dev/null 2>&1; then
|
|
ol_unset=unset
|
|
else
|
|
ol_unset=false
|
|
fi
|
|
# unset CDPATH
|
|
$ol_unset CDPATH || test "${CDPATH+set}" != set || { CDPATH=:; export CDPATH; }
|
|
|
|
AC_CONFIG_AUX_DIR(build)dnl
|
|
|
|
eval `$ac_aux_dir/version.sh`
|
|
if test -z "$OL_STRING"; then
|
|
AC_MSG_ERROR([could not determine version])
|
|
fi
|
|
|
|
if test -f "$ac_aux_dir/shtool" -a ! -d $ac_aux_dir/shtool; then
|
|
ac_cv_shtool="$ac_aux_dir/shtool"
|
|
else
|
|
AC_MSG_ERROR([no shtool found in $ac_aux_dir])
|
|
fi
|
|
|
|
SHTOOL="$ac_cv_shtool"
|
|
dnl AC_SUBST(SHTOOL)dnl
|
|
|
|
TB="`$SHTOOL echo -e '%B' 2>/dev/null`"
|
|
TN="`$SHTOOL echo -e '%b' 2>/dev/null`"
|
|
|
|
OPENLDAP_CVS=""
|
|
if test -d $ac_aux_dir/CVS; then
|
|
OPENLDAP_CVS="(from CVS sources) "
|
|
fi
|
|
|
|
echo "Configuring ${TB}${OL_STRING}${TN} ${OPENLDAP_CVS}..."
|
|
|
|
dnl Determine host platform
|
|
dnl we try not to use this for much
|
|
AC_CANONICAL_SYSTEM
|
|
|
|
AM_INIT_AUTOMAKE([$OL_PACKAGE],[$OL_VERSION], [no defines])dnl
|
|
AC_SUBST(PACKAGE)dnl
|
|
AC_SUBST(VERSION)dnl
|
|
AC_DEFINE_UNQUOTED(OPENLDAP_PACKAGE,"$PACKAGE",Package)
|
|
AC_DEFINE_UNQUOTED(OPENLDAP_VERSION,"$VERSION",Version)
|
|
|
|
AC_DEFINE_UNQUOTED(LDAP_VENDOR_VERSION,$OL_API_INC,Version)
|
|
AC_DEFINE_UNQUOTED(LDAP_VENDOR_VERSION_MAJOR,$OL_MAJOR,Major)
|
|
AC_DEFINE_UNQUOTED(LDAP_VENDOR_VERSION_MINOR,$OL_MINOR,Minor)
|
|
AC_DEFINE_UNQUOTED(LDAP_VENDOR_VERSION_PATCH,$OL_PATCH,Patch)
|
|
|
|
OPENLDAP_LIBRELEASE=$OL_API_LIB_RELEASE
|
|
AC_SUBST(OPENLDAP_LIBRELEASE)dnl
|
|
|
|
OPENLDAP_LIBVERSION=$OL_API_LIB_VERSION
|
|
AC_SUBST(OPENLDAP_LIBVERSION)dnl
|
|
|
|
OPENLDAP_RELEASE_DATE="$OL_RELEASE_DATE"
|
|
AC_SUBST(OPENLDAP_RELEASE_DATE)dnl
|
|
|
|
dnl We use autoconf features new to 2.13. Later versions like won't work.
|
|
dnl aclocal.m4 should be built using aclocal from automake 1.4
|
|
dnl libtool 1.4.3 should be installed.
|
|
AC_PREREQ(2.13)dnl Required Autoconf version
|
|
|
|
AC_CONFIG_HEADER(include/portable.h include/ldap_features.h include/lber_types.h)dnl
|
|
|
|
dnl ================================================================
|
|
dnl Start Args
|
|
AC_MSG_CHECKING(configure arguments)
|
|
AC_PREFIX_DEFAULT(/usr/local)
|
|
|
|
top_builddir=`pwd`
|
|
AC_SUBST(top_builddir)dnl
|
|
|
|
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"
|
|
;;
|
|
*)
|
|
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_ARG_ENABLE(dynamic,[ --enable-dynamic enable linking built binaries with dynamic libs], no)dnl
|
|
OL_ARG_ENABLE(syslog,[ --enable-syslog enable syslog support], auto)dnl
|
|
OL_ARG_ENABLE(proctitle,[ --enable-proctitle enable proctitle support], yes)dnl
|
|
dnl OL_ARG_ENABLE(referrals,[ --enable-referrals enable LDAPv2+ Referrals (experimental)], no)dnl
|
|
ol_enable_referrals=${ol_enable_referrals-no}
|
|
dnl OL_ARG_ENABLE(kbind,[ --enable-kbind enable LDAPv2+ Kerberos IV bind (deprecated)], no)dnl
|
|
ol_enable_kbind=${ol_enable_kbind-no}
|
|
OL_ARG_ENABLE(ipv6,[ --enable-ipv6 enable IPv6 support], auto)dnl
|
|
OL_ARG_ENABLE(local,[ --enable-local enable AF_LOCAL (AF_UNIX) socket support], auto)dnl
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl General "with" options
|
|
dnl OL_ARG_ENABLE(dmalloc,[ --enable-dmalloc enable debug malloc support], no)dnl
|
|
|
|
OL_ARG_WITH(cyrus_sasl,[ --with-cyrus-sasl with Cyrus SASL support],
|
|
auto, [auto yes no] )
|
|
OL_ARG_WITH(fetch,[ --with-fetch with fetch(3) URL support],
|
|
auto, [auto yes no] )
|
|
dnl OL_ARG_WITH(kerberos,[ --with-kerberos with Kerberos support],
|
|
dnl auto, [auto k5 k5only k425 kth k4 afs yes no])
|
|
ol_with_kerberos=${ol_with_kerberos-auto}
|
|
OL_ARG_WITH(threads,[ --with-threads with threads],
|
|
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] )
|
|
OL_ARG_WITH(multiple_precision,[ --with-multiple-precision
|
|
multiple precision support for statistics
|
|
auto|bignum|gmp],
|
|
auto, [auto bignum gmp yes no] )
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Server options
|
|
dnl ----------------------------------------------------------------
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl 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(aci,[ --enable-aci enable per-object ACIs (experimental)], no)dnl
|
|
OL_ARG_ENABLE(cleartext,[ --enable-cleartext enable cleartext passwords], yes)dnl
|
|
OL_ARG_ENABLE(crypt,[ --enable-crypt enable crypt(3) passwords], no)dnl
|
|
OL_ARG_ENABLE(lmpasswd,[ --enable-lmpasswd enable LAN Manager passwords], no)dnl
|
|
OL_ARG_ENABLE(spasswd,[ --enable-spasswd enable (Cyrus) SASL password verification], no)dnl
|
|
OL_ARG_ENABLE(modules,[ --enable-modules enable dynamic module support], no)dnl
|
|
dnl OL_ARG_ENABLE(multimaster,[ --enable-multimaster enable multimaster replication], no)dnl
|
|
ol_enable_multimaster=${ol_enable_multimaster-no}
|
|
OL_ARG_ENABLE(rewrite,[ --enable-rewrite enable DN rewriting in back-ldap and the rwm overlay], auto)dnl
|
|
OL_ARG_ENABLE(rlookups,[ --enable-rlookups enable reverse lookups of client hostnames], no)dnl
|
|
OL_ARG_ENABLE(slapi,[ --enable-slapi enable SLAPI support (experimental)], no)dnl
|
|
OL_ARG_ENABLE(slp,[ --enable-slp enable SLPv2 support], no)dnl
|
|
OL_ARG_ENABLE(wrappers,[ --enable-wrappers enable tcp wrapper support], no)dnl
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl SLAPD Backend Options
|
|
Backends="bdb dnssrv hdb ldap ldbm meta monitor null \
|
|
passwd perl relay shell sql"
|
|
|
|
AC_ARG_WITH(xxslapbackends,[
|
|
SLAPD Backend Options:])
|
|
|
|
OL_ARG_ENABLE(backends,[ --enable-backends enable all available backends no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(bdb,[ --enable-bdb enable Berkeley DB backend no|yes|mod],
|
|
yes, [no yes mod])dnl
|
|
OL_ARG_ENABLE(dnssrv,[ --enable-dnssrv enable dnssrv backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(hdb,[ --enable-hdb enable Hierarchical DB backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(ldap,[ --enable-ldap enable ldap backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(ldbm,[ --enable-ldbm enable ldbm backend no|yes|mod], no,
|
|
[no yes mod])dnl
|
|
OL_ARG_WITH(ldbm_api,[ --with-ldbm-api with LDBM API auto|berkeley|bcompat|mdbm|gdbm],
|
|
auto, [auto berkeley bcompat mdbm gdbm])
|
|
OL_ARG_WITH(ldbm_type,[ --with-ldbm-type use LDBM type auto|btree|hash],
|
|
auto, [auto btree hash])
|
|
OL_ARG_ENABLE(meta,[ --enable-meta enable metadirectory backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(monitor,[ --enable-monitor enable monitor backend no|yes|mod],
|
|
yes, [no yes mod])dnl
|
|
OL_ARG_ENABLE(null,[ --enable-null enable null backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(passwd,[ --enable-passwd enable passwd backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(perl,[ --enable-perl enable perl backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(relay,[ --enable-relay enable relay backend no|yes|mod],
|
|
yes, [no yes mod])dnl
|
|
OL_ARG_ENABLE(shell,[ --enable-shell enable shell backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(sql,[ --enable-sql enable sql backend no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl SLAPD Overlay Options
|
|
Overlays="chain denyop dyngroup lastmod ppolicy proxycache rwm \
|
|
refint unique"
|
|
|
|
AC_ARG_WITH(xxslapoverlays,[
|
|
SLAPD Overlay Options:])
|
|
|
|
OL_ARG_ENABLE(overlays,[ --enable-overlays enable all available overlays no|yes|mod],
|
|
no, [no yes mod])dnl
|
|
OL_ARG_ENABLE(chain,[ --enable-chain LDAP Chain Response no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(denyop,[ --enable-denyop Deny Operation overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(dyngroup,[ --enable-dyngroup Dynamic Group overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(lastmod,[ --enable-lastmod Last Modification overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(ppolicy,[ --enable-ppolicy Password Policy overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(proxycache,[ --enable-proxycache Proxy Cache overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(refint,[ --enable-refint Referential Integrity overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(rwm,[ --enable-rwm Rewrite/Remap overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
OL_ARG_ENABLE(unique,[ --enable-unique Attribute Uniqueness overlay no|yes|mod],
|
|
no, [no yes mod])
|
|
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl 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])
|
|
AC_ENABLE_STATIC
|
|
AC_ENABLE_SHARED
|
|
|
|
dnl ----------------------------------------------------------------
|
|
|
|
dnl General "enable" options
|
|
# Activate any backends that were not explicitly enabled.
|
|
# Note that back_bdb defaults to "yes" so this loop won't touch it.
|
|
if test $ol_enable_backends != no ; then
|
|
for i in $Backends; do
|
|
eval "ol_tmp=\$ol_enable_$i"
|
|
if test $ol_tmp = no ; then
|
|
eval "ol_enable_$i=$ol_enable_backends"
|
|
fi
|
|
done
|
|
fi
|
|
# Activate the overlays
|
|
if test $ol_enable_overlays != no ; then
|
|
for i in $Overlays; do
|
|
eval "ol_tmp=\$ol_enable_$i"
|
|
if test $ol_tmp = no ; then
|
|
eval "ol_enable_$i=$ol_enable_overlays"
|
|
fi
|
|
done
|
|
fi
|
|
|
|
# validate options
|
|
if test $ol_enable_slapd = no ; then
|
|
dnl SLAPD was specificallly disabled
|
|
if test $ol_enable_slapi = yes ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-slapi argument])
|
|
fi
|
|
if test $ol_enable_backends != no ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-backends argument])
|
|
fi
|
|
for i in $Backends; do
|
|
eval "ol_tmp=\$ol_enable_$i"
|
|
if test $ol_tmp != no ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-$i argument])
|
|
eval "ol_enable_$i=no"
|
|
fi
|
|
done
|
|
if test $ol_enable_modules = yes ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-modules argument])
|
|
fi
|
|
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])
|
|
fi
|
|
if test $ol_enable_rlookups = yes ; then
|
|
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_with_ldbm_api != auto ; then
|
|
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])
|
|
fi
|
|
if test $ol_enable_slurpd = yes ; then
|
|
AC_MSG_ERROR([slurpd requires slapd])
|
|
fi
|
|
if test $ol_enable_rewrite = yes ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-rewrite argument])
|
|
fi
|
|
dnl overlays
|
|
if test $ol_enable_overlays != no ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-overlays argument])
|
|
fi
|
|
for i in $Overlays; do
|
|
eval "ol_tmp=\$ol_enable_$i"
|
|
if test $ol_tmp != no ; then
|
|
AC_MSG_WARN([slapd disabled, ignoring --enable-$i argument])
|
|
eval "ol_enable_$i=no"
|
|
fi
|
|
done
|
|
|
|
# force settings to no
|
|
ol_enable_slapi=no
|
|
|
|
ol_enable_backends=no
|
|
ol_enable_overlays=no
|
|
ol_enable_modules=no
|
|
ol_enable_multimaster=no
|
|
ol_enable_rlookups=no
|
|
ol_enable_aci=no
|
|
ol_enable_wrappers=no
|
|
|
|
ol_with_ldbm_api=no
|
|
ol_with_ldbm_type=no
|
|
|
|
ol_enable_slurpd=no
|
|
|
|
ol_enable_rewrite=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])
|
|
fi
|
|
|
|
if test $ol_with_ldbm_type != auto ; then
|
|
AC_MSG_WARN([LDBM disabled, ignoring --with-ldbm-type argument])
|
|
fi
|
|
|
|
if test $ol_enable_modules != yes -a \
|
|
$ol_enable_bdb = no -a \
|
|
$ol_enable_dnssrv = no -a \
|
|
$ol_enable_hdb = no -a \
|
|
$ol_enable_ldap = no -a \
|
|
$ol_enable_meta = no -a \
|
|
$ol_enable_monitor = no -a \
|
|
$ol_enable_null = no -a \
|
|
$ol_enable_passwd = no -a \
|
|
$ol_enable_perl = no -a \
|
|
$ol_enable_relay = no -a \
|
|
$ol_enable_shell = no -a \
|
|
$ol_enable_sql = no ; then
|
|
|
|
if test $ol_enable_slapd = yes ; then
|
|
AC_MSG_ERROR([slapd requires a backend])
|
|
else
|
|
AC_MSG_WARN([skipping slapd, no backend specified])
|
|
ol_enable_slapd=no
|
|
fi
|
|
fi
|
|
|
|
ol_with_ldbm_api=no
|
|
ol_with_ldbm_type=no
|
|
|
|
if test $ol_enable_bdb != no -o $ol_enable_hdb != no; then
|
|
ol_with_ldbm_api=berkeley
|
|
fi
|
|
|
|
else
|
|
dnl SLAPD with LDBM
|
|
if test $ol_with_ldbm_api = gdbm -a \
|
|
$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])
|
|
fi
|
|
|
|
if test $ol_enable_bdb != no -o $ol_enable_hdb != no ; then
|
|
if test $ol_with_ldbm_api = auto ; then
|
|
ol_with_ldbm_api=berkeley
|
|
elif test $ol_with_ldbm_api != berkeley ; then
|
|
AC_MSG_ERROR([LDBM API not compatible with BDB/HDB])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test $ol_enable_chain != no -a $ol_enable_ldap = no ; then
|
|
AC_MSG_ERROR([--enable-chain requires --enable-ldap])
|
|
fi
|
|
|
|
if test $ol_enable_meta = yes -a $ol_enable_ldap = no ; then
|
|
AC_MSG_ERROR([--enable-meta requires --enable-ldap])
|
|
fi
|
|
|
|
if test $ol_enable_slurpd = yes ; then
|
|
dnl SLURPD was specifically enabled
|
|
if test $ol_with_threads = no ; then
|
|
AC_MSG_ERROR([slurpd requires threads])
|
|
fi
|
|
fi
|
|
|
|
if test $ol_enable_lmpasswd = yes ; then
|
|
if test $ol_with_tls = no ; then
|
|
AC_MSG_ERROR([LAN Manager passwords require OpenSSL])
|
|
fi
|
|
fi
|
|
|
|
if test $ol_enable_kbind = yes ; then
|
|
if test $ol_with_kerberos = no ; then
|
|
AC_MSG_ERROR([options require --with-kerberos])
|
|
elif test $ol_with_kerberos = auto ; then
|
|
ol_with_kerberos=yes
|
|
fi
|
|
|
|
elif test $ol_enable_kbind = no ; then
|
|
if test $ol_with_kerberos = auto ; then
|
|
ol_with_kerberos=no
|
|
elif test $ol_with_kerberos != no ; then
|
|
AC_MSG_WARN([Kerberos detection enabled unnecessarily]);
|
|
ol_with_kerberos=no
|
|
fi
|
|
fi
|
|
|
|
if test $ol_enable_spasswd = yes ; then
|
|
if test $ol_with_cyrus_sasl = no ; then
|
|
AC_MSG_ERROR([options require --with-cyrus-sasl])
|
|
fi
|
|
ol_with_cyrus_sasl=yes
|
|
fi
|
|
|
|
AC_MSG_RESULT(done)
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Initialize vars
|
|
LDAP_LIBS=
|
|
LDBM_LIBS=
|
|
LTHREAD_LIBS=
|
|
LUTIL_LIBS=
|
|
|
|
SLAPD_LIBS=
|
|
SLURPD_LIBS=
|
|
|
|
BUILD_SLAPD=no
|
|
BUILD_SLURPD=no
|
|
|
|
BUILD_THREAD=no
|
|
|
|
BUILD_SLAPI=no
|
|
SLAPD_SLAPI_DEPEND=
|
|
|
|
BUILD_BDB=no
|
|
BUILD_DNSSRV=no
|
|
BUILD_HDB=no
|
|
BUILD_LDAP=no
|
|
BUILD_LDBM=no
|
|
BUILD_META=no
|
|
BUILD_MONITOR=no
|
|
BUILD_NULL=no
|
|
BUILD_PASSWD=no
|
|
BUILD_PERL=no
|
|
BUILD_RELAY=no
|
|
BUILD_SHELL=no
|
|
BUILD_SQL=no
|
|
|
|
BUILD_CHAIN=no
|
|
BUILD_DENYOP=no
|
|
BUILD_DYNGROUP=no
|
|
BUILD_LASTMOD=no
|
|
BUILD_PPOLICY=no
|
|
BUILD_PROXYCACHE=no
|
|
BUILD_REFINT=no
|
|
BUILD_RWM=no
|
|
BUILD_UNIQUE=no
|
|
|
|
SLAPD_DYNAMIC_OVERLAYS=
|
|
|
|
SLAPD_MODULES_LDFLAGS=
|
|
SLAPD_MODULES_CPPFLAGS=
|
|
|
|
SLAPD_STATIC_BACKENDS=
|
|
SLAPD_DYNAMIC_BACKENDS=
|
|
|
|
SLAPD_PERL_LDFLAGS=
|
|
MOD_PERL_LDFLAGS=
|
|
PERL_CPPFLAGS=
|
|
|
|
SLAPD_SQL_LDFLAGS=
|
|
SLAPD_SQL_LIBS=
|
|
SLAPD_SQL_INCLUDES=
|
|
|
|
KRB4_LIBS=
|
|
KRB5_LIBS=
|
|
SASL_LIBS=
|
|
TLS_LIBS=
|
|
MODULES_LIBS=
|
|
SLAPI_LIBS=
|
|
LIBSLAPI=
|
|
LIBSLAPITOOLS=
|
|
AUTH_LIBS=
|
|
|
|
SLAPD_SLP_LIBS=
|
|
SLAPD_GMP_LIBS=
|
|
|
|
dnl ================================================================
|
|
dnl Checks for programs
|
|
|
|
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 gcc,missing)
|
|
|
|
if test "${CC}" = "missing" ; then
|
|
AC_MSG_ERROR([Unable to locate cc(1) or suitable replacement. Check PATH or set CC.])
|
|
fi
|
|
fi
|
|
|
|
if test -z "${AR}"; then
|
|
AC_CHECK_PROGS(AR,ar gar,missing)
|
|
|
|
if test "${AR}" = "missing" ; then
|
|
AC_MSG_ERROR([Unable to locate ar(1) or suitable replacement. Check PATH or set AR.])
|
|
fi
|
|
fi
|
|
|
|
AC_LIBTOOL_WIN32_DLL
|
|
AC_LIBTOOL_DLOPEN
|
|
AC_PROG_LIBTOOL
|
|
|
|
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
|
|
if test $ol_enable_perl = yes ; then
|
|
AC_MSG_ERROR([could not locate perl])
|
|
fi
|
|
|
|
else
|
|
PERL_CPPFLAGS="`$PERLBIN -MExtUtils::Embed -e ccopts`"
|
|
PERL_LDFLAGS="`$PERLBIN -MExtUtils::Embed -e ldopts|sed -e 's/ -lc / /' -e 's/ -lc$//'`"
|
|
|
|
if test x"$ol_enable_perl" = "xyes" ; then
|
|
SLAPD_PERL_LDFLAGS="$PERL_LDFLAGS"
|
|
else
|
|
MOD_PERL_LDFLAGS="$PERL_LDFLAGS"
|
|
fi
|
|
dnl should check perl version
|
|
ol_link_perl=yes
|
|
fi
|
|
fi
|
|
|
|
AC_PROG_CPP
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Checks for UNIX Variants
|
|
dnl AC_AIX
|
|
dnl AC_ISC_POSIX
|
|
dnl 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 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 AIX security library
|
|
AC_CHECK_LIB(s, afopen, [
|
|
AUTH_LIBS=-ls
|
|
AC_DEFINE(HAVE_AIX_SECURITY,1,[define if you have AIX security lib])
|
|
])
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Check for IBM OS/390
|
|
case "$target" in
|
|
*-ibm-openedition)
|
|
ac_cv_func_getopt=no
|
|
AC_DEFINE(BOTH_STRINGS_H,1,[define to use both <string.h> and <strings.h>])
|
|
;;
|
|
esac
|
|
|
|
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
|
|
for i in $Backends; do
|
|
eval "ol_tmp=\$ol_enable_$i"
|
|
if test $ol_tmp = mod ; then
|
|
AC_MSG_WARN([building static $i backend])
|
|
eval "ol_enable_$i=yes"
|
|
fi
|
|
done
|
|
for i in $Overlays; do
|
|
eval "ol_tmp=\$ol_enable_$i"
|
|
if test $ol_tmp = mod ; then
|
|
AC_MSG_WARN([building static $i overlay])
|
|
eval "ol_enable_$i=yes"
|
|
fi
|
|
done
|
|
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
|
|
|
|
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 \
|
|
bits/types.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/stat.h \
|
|
sys/syslog.h \
|
|
sys/time.h \
|
|
sys/types.h \
|
|
sys/ucred.h \
|
|
sys/uio.h \
|
|
syslog.h \
|
|
termios.h \
|
|
unistd.h \
|
|
winsock.h \
|
|
winsock2.h \
|
|
)
|
|
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Checks for libraries
|
|
|
|
dnl HP-UX requires -lV3
|
|
dnl this is not needed on newer versions of HP-UX
|
|
AC_CHECK_LIB(V3, sigset)
|
|
|
|
dnl The following is INTENTIONALLY scripted out because shell does not
|
|
dnl support variable names with the '@' character, which is what
|
|
dnl autoconf would try to generate if one merely used AC_SEARCH_LIBS
|
|
if test "$ac_cv_header_winsock_h" = yes; then
|
|
AC_CACHE_CHECK([for winsock], [ol_cv_winsock],
|
|
save_LIBS="$LIBS"
|
|
for curlib in ws2_32 wsock32; do
|
|
LIBS="$LIBS -l$curlib"
|
|
AC_TRY_LINK([#include <winsock.h>
|
|
],
|
|
[
|
|
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
|
|
if test $curlib = ws2_32; then
|
|
ol_cv_winsock=winsock2
|
|
AC_DEFINE(HAVE_WINSOCK2, 1,
|
|
[define if you have winsock2])
|
|
fi
|
|
break
|
|
fi
|
|
LIBS="$save_LIBS"
|
|
done)
|
|
fi
|
|
|
|
dnl Find socket()
|
|
dnl Likely combinations:
|
|
dnl -lsocket [ -lnsl_s | -lnsl ]
|
|
dnl -linet
|
|
|
|
AC_CHECK_FUNC(socket, :, [
|
|
dnl hopefully we won't include too many libraries
|
|
AC_CHECK_LIB(socket, main)
|
|
AC_CHECK_LIB(net, main)
|
|
AC_CHECK_LIB(nsl_s, main)
|
|
AC_CHECK_LIB(nsl, main)
|
|
AC_CHECK_LIB(inet, socket)
|
|
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 ----------------------------------------------------------------
|
|
AC_CHECK_FUNCS( poll )
|
|
AC_CHECK_HEADERS( poll.h )
|
|
|
|
dnl ----------------------------------------------------------------
|
|
# strerror checks
|
|
OL_STRERROR
|
|
|
|
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_SEARCH_LIBS(regfree, [regex gnuregex],
|
|
:, 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 UUID Support
|
|
|
|
have_uuid=no
|
|
AC_CHECK_HEADERS(sys/uuid.h)
|
|
if test $ac_cv_header_sys_uuid_h = yes ; then
|
|
save_LIBS="$LIBS"
|
|
AC_SEARCH_LIBS(uuid_to_str, uuid, [have_uuid=yes], :)
|
|
LIBS="$save_LIBS"
|
|
|
|
if test have_uuid = yes ; then
|
|
AC_DEFINE(HAVE_UUID_TO_STR,1,
|
|
[define if you have uuid_to_str()])
|
|
|
|
test "$ac_cv_search_uuid_to_str" = "none required" || \
|
|
SLAPD_LIBS="$SLAPD_LIBS $ac_cv_search_uuid_to_str"
|
|
fi
|
|
fi
|
|
|
|
dnl For windows, check for the need of RPCRT for UUID function support
|
|
if test $have_uuid = no ; then
|
|
AC_MSG_CHECKING(to see if -lrpcrt4 is needed for win32 UUID support)
|
|
save_LIBS="$LIBS"
|
|
LIBS="$LIBS -lrpcrt4"
|
|
AC_TRY_LINK([
|
|
int __stdcall UuidCreate(void *);
|
|
int __stdcall UuidToStringA(void *,void **);
|
|
],
|
|
[
|
|
UuidCreate(0);
|
|
UuidToStringA(0,0);
|
|
],
|
|
need_rpcrt=yes, need_rpcrt=no)
|
|
if test $need_rpcrt = yes; then
|
|
SLAPD_LIBS="$SLAPD_LIBS -lrpcrt4"
|
|
fi
|
|
LIBS="$save_LIBS"
|
|
AC_MSG_RESULT($need_rpcrt)
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Check for resolver routines
|
|
dnl need to check for both res_query and __res_query
|
|
dnl need to check -lc, -lbind, and -lresolv
|
|
ol_link_dnssrv=no
|
|
AC_CHECK_FUNC(res_query,:)
|
|
if test $ac_cv_func_res_query = no ; then
|
|
AC_CHECK_FUNC(__res_query,:)
|
|
ac_cv_func_res_query=$ac_cv_func___res_query
|
|
fi
|
|
|
|
if test $ac_cv_func_res_query = no ; then
|
|
AC_CHECK_LIB(bind, res_query)
|
|
ac_cv_func_res_query=$ac_cv_lib_bind_res_query
|
|
fi
|
|
|
|
if test $ac_cv_func_res_query = no ; then
|
|
AC_CHECK_LIB(bind, __res_query)
|
|
ac_cv_func_res_query=$ac_cv_lib_bind___res_query
|
|
fi
|
|
|
|
if test $ac_cv_func_res_query = no ; then
|
|
AC_CHECK_LIB(resolv, res_query)
|
|
ac_cv_func_res_query=$ac_cv_lib_resolv_res_query
|
|
fi
|
|
|
|
if test $ac_cv_func_res_query = no ; then
|
|
AC_CHECK_LIB(resolv, __res_query)
|
|
ac_cv_func_res_query=$ac_cv_lib_resolv___res_query
|
|
fi
|
|
|
|
if test $ac_cv_func_res_query = no ; then
|
|
AC_CHECK_LIB(resolv, _res_9_query)
|
|
ac_cv_func_res_query=$ac_cv_lib_resolv_res_9_query
|
|
fi
|
|
|
|
if test "$ac_cv_func_res_query" = yes ; then
|
|
AC_DEFINE(HAVE_RES_QUERY,1,
|
|
[define if you have res_query()])
|
|
|
|
if test $ol_enable_dnssrv != no ; then
|
|
ol_link_dnssrv=yes
|
|
fi
|
|
fi
|
|
|
|
if test "$ol_enable_dnssrv" != no -a "$ol_link_dnssrv" = no ; then
|
|
AC_MSG_ERROR([DNSSRV requires res_query()])
|
|
fi
|
|
|
|
AC_CHECK_FUNCS( hstrerror )
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl PF_INET6 support requires getaddrinfo and INET6_ADDRSTRLEN
|
|
dnl PF_LOCAL may use getaddrinfo in available
|
|
AC_CHECK_FUNCS( getaddrinfo getnameinfo gai_strerror inet_ntop )
|
|
|
|
ol_link_ipv6=no
|
|
if test $ac_cv_func_getaddrinfo = no -o $ac_cv_func_inet_ntop = no ; then
|
|
if test $ol_enable_ipv6 = yes ; then
|
|
AC_MSG_ERROR([IPv6 support requires getaddrinfo() and inet_ntop()])
|
|
fi
|
|
elif test $ol_enable_ipv6 != no ; then
|
|
AC_CACHE_CHECK([INET6_ADDRSTRLEN],[ol_cv_inet6_addrstrlen],[
|
|
AC_EGREP_CPP(__has_inet6_addrstrlen__,[
|
|
# include <netinet/in.h>
|
|
# ifdef INET6_ADDRSTRLEN
|
|
__has_inet6_addrstrlen__;
|
|
# endif
|
|
], [ol_cv_inet6_addrstrlen=yes], [ol_cv_inet6_addrstrlen=no])])
|
|
|
|
|
|
AC_CACHE_CHECK([struct sockaddr_storage],ol_cv_struct_sockaddr_storage,[
|
|
AC_TRY_COMPILE([
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
],[
|
|
struct sockaddr_storage ss;
|
|
], [ol_cv_struct_sockaddr_storage=yes],
|
|
[ol_cv_struct_sockaddr_storage=no])])
|
|
|
|
if test $ol_cv_inet6_addrstrlen = yes \
|
|
-a $ol_cv_struct_sockaddr_storage = yes ; then
|
|
ol_link_ipv6=yes
|
|
elif test $ol_enable_ipv6 = yes \
|
|
-a $ol_cv_inet6_addrstrlen = no ; then
|
|
AC_MSG_ERROR([IPv6 support requires INET6_ADDRSTRLEN])
|
|
elif test $ol_enable_ipv6 = yes \
|
|
-a $ol_cv_struct_sockaddr_storage = no ; then
|
|
AC_MSG_ERROR([IPv6 support requires struct sockaddr_storage])
|
|
fi
|
|
fi
|
|
|
|
if test $ol_enable_local != no ; then
|
|
AC_CHECK_HEADERS( sys/un.h )
|
|
|
|
if test $ol_enable_local = auto ; then
|
|
ol_enable_local=$ac_cv_header_sys_un_h
|
|
elif test $ac_cv_header_sys_un_h = no ; then
|
|
AC_MSG_ERROR([AF_LOCAL domain support requires sys/un.h])
|
|
fi
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Kerberos
|
|
ol_link_kbind=no
|
|
ol_link_krb5=no
|
|
ol_link_krb4=no
|
|
|
|
if test $ol_with_kerberos = yes -o $ol_with_kerberos = auto \
|
|
-o $ol_with_kerberos = k5 -o $ol_with_kerberos = k5only \
|
|
-o $ol_with_kerberos = k425 ; then
|
|
|
|
AC_CHECK_HEADERS(krb5.h)
|
|
|
|
if test $ac_cv_header_krb5_h = yes ; then
|
|
dnl lazy check for Heimdal Kerberos
|
|
AC_CHECK_HEADERS(heim_err.h)
|
|
if test $ac_cv_header_heim_err_h = yes ; then
|
|
krb5_impl=heimdal
|
|
else
|
|
krb5_impl=mit
|
|
fi
|
|
|
|
if test $krb5_impl = mit; then
|
|
AC_CHECK_LIB(k5crypto, main,
|
|
[krb5crypto=k5crypto],
|
|
[krb5crypto=crypto])
|
|
|
|
AC_CHECK_LIB(krb5, main,
|
|
[have_krb5=yes
|
|
KRB5_LIBS="-lkrb5 -l$krb5crypto -lcom_err"],
|
|
[have_krb5=no],
|
|
[-l$krb5crypto -lcom_err])
|
|
|
|
elif test $krb5_impl = heimdal; then
|
|
AC_CHECK_LIB(des, main,
|
|
[krb5crypto=des],
|
|
[krb5crypto=crypto])
|
|
|
|
AC_CHECK_LIB(krb5, main,
|
|
[have_krb5=yes
|
|
KRB5_LIBS="-lkrb5 -l$krb5crypto -lasn1 -lroken -lcom_err"],
|
|
[have_krb5=no],
|
|
[-l$krb5crypto -lasn1 -lroken -lcom_err])
|
|
|
|
AC_DEFINE(HAVE_HEIMDAL_KERBEROS, 1,
|
|
[define if you have HEIMDAL Kerberos])
|
|
|
|
else
|
|
have_krb5=no
|
|
AC_MSG_WARN([Unrecognized Kerberos5 Implementation])
|
|
fi
|
|
|
|
if test $have_krb5 = yes ; then
|
|
ol_link_krb5=yes
|
|
|
|
AC_DEFINE(HAVE_KRB5, 1,
|
|
[define if you have Kerberos V])
|
|
|
|
if test $ol_with_kerberos = k5only ; then
|
|
ol_with_kerberos=found
|
|
fi
|
|
|
|
elif test $ol_with_kerberos != auto ; then
|
|
AC_MSG_ERROR([Required Kerberos 5 support not available])
|
|
fi
|
|
|
|
fi
|
|
fi
|
|
|
|
if test $ol_link_krb5 = yes -a \( $ol_with_kerberos = yes -o \
|
|
$ol_with_kerberos = auto -o $ol_with_kerberos = k425 \) ; then
|
|
|
|
AC_CHECK_HEADERS(kerberosIV/krb.h kerberosIV/des.h)
|
|
|
|
if test $ac_cv_header_kerberosIV_krb_h = yes ; then
|
|
if test $krb5_impl = mit; then
|
|
AC_CHECK_LIB(krb4, main, [have_k425=yes
|
|
KRB4_LIBS="-lkrb4 -ldes425"], [have_k425=no],
|
|
[-ldes425 -lkrb5 -l$krb5crypto -lcom_err])
|
|
|
|
elif test $krb5_impl = heimdal; then
|
|
AC_CHECK_LIB(krb4, main, [have_k425=yes
|
|
KRB4_LIBS="-lkrb4"], [have_k425=no],
|
|
[-lkrb5 -l$krb5crypto -lasn1 -lroken -lcom_err])
|
|
|
|
else
|
|
have_425=no
|
|
AC_MSG_WARN([Unrecongized Kerberos V Implementation])
|
|
fi
|
|
|
|
if test $have_k425 = yes ; then
|
|
ol_with_kerberos=found
|
|
ol_link_krb4=yes
|
|
|
|
AC_DEFINE(HAVE_KRB425, 1,
|
|
[define if you have Kerberos V with IV support])
|
|
AC_DEFINE(HAVE_KRB4, 1,
|
|
[define if you have Kerberos IV])
|
|
|
|
AC_CACHE_CHECK([for des_debug in Kerberos libraries],
|
|
[ol_cv_var_des_debug], [
|
|
dnl save the flags
|
|
save_LIBS="$LIBS"
|
|
LIBS="$KRB4_LIBS $KRB5_LIBS $LIBS"
|
|
AC_TRY_LINK([
|
|
#include <kerberosIV/krb.h>
|
|
#include <kerberosIV/des.h>
|
|
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_link_krb5 = yes ; then
|
|
ol_with_kerberos=found
|
|
fi
|
|
|
|
if test $ol_with_kerberos = yes -o $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])
|
|
|
|
if test $have_k4 = yes ; then
|
|
ol_with_kerberos=found
|
|
ol_link_krb4=yes
|
|
|
|
AC_DEFINE(HAVE_KRB4, 1,
|
|
[define if you have Kerberos IV])
|
|
|
|
KRB4_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
|
|
|
|
if test $ol_link_krb4 = yes -a $ol_enable_kbind != no ; then
|
|
ol_link_kbind=yes
|
|
|
|
elif test $ol_enable_kbind = yes ; then
|
|
AC_MSG_ERROR([Kerberos IV detection failed])
|
|
fi
|
|
|
|
if test $ol_link_krb4 = yes -o $ol_link_krb5 = yes ; then
|
|
AC_DEFINE(HAVE_KERBEROS, 1, [define if you have Kerberos])
|
|
|
|
elif test $ol_with_kerberos != auto -a $ol_with_kerberos != no ; then
|
|
AC_MSG_ERROR([Kerberos detection failed])
|
|
fi
|
|
|
|
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
|
|
|
|
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
|
|
|
|
if test $have_ssleay = yes ; then
|
|
ol_with_tls=found
|
|
ol_link_tls=yes
|
|
|
|
AC_DEFINE(HAVE_SSLEAY, 1,
|
|
[define if you have SSLeay or OpenSSL])
|
|
|
|
if test $need_rsaref = yes; then
|
|
AC_DEFINE(HAVE_RSAREF, 1,
|
|
[define if you have RSAref])
|
|
|
|
TLS_LIBS="-lssl -lcrypto -lRSAglue -lrsaref"
|
|
else
|
|
TLS_LIBS="-lssl -lcrypto"
|
|
fi
|
|
fi
|
|
OL_SSL_COMPAT
|
|
if test $ol_cv_ssl_crl_compat = no ; then
|
|
ol_link_ssl=no
|
|
else
|
|
AC_DEFINE(HAVE_OPENSSL_CRL, 1,
|
|
[define if you have OpenSSL with CRL checking capability])
|
|
fi
|
|
fi
|
|
|
|
else
|
|
AC_WARN([TLS data protection not supported!])
|
|
fi
|
|
|
|
WITH_TLS=no
|
|
if test $ol_link_tls = yes ; then
|
|
AC_DEFINE(HAVE_TLS, 1, [define if you have TLS])
|
|
WITH_TLS=yes
|
|
|
|
elif test $ol_with_tls = auto ; then
|
|
AC_WARN([Could not locate TLS/SSL package])
|
|
AC_WARN([TLS data protection not supported!])
|
|
|
|
elif test $ol_with_tls != no ; then
|
|
AC_ERROR([Could not locate TLS/SSL package])
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl LAN Manger password checking requires DES from OpenSSL
|
|
if test $ol_enable_lmpasswd != no; then
|
|
if test $ol_link_tls != yes ; then
|
|
AC_ERROR([LAN Manager passwords require OpenSSL])
|
|
fi
|
|
|
|
AC_DEFINE(SLAPD_LMHASH, 1, [define to support LAN Manager passwords])
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Threads?
|
|
ol_link_threads=no
|
|
|
|
if test $ol_with_threads = auto -o $ol_with_threads = yes \
|
|
-o $ol_with_threads = nt ; then
|
|
|
|
OL_NT_THREADS
|
|
|
|
if test "$ol_cv_nt_threads" = yes ; then
|
|
ol_link_threads=nt
|
|
ol_with_threads=found
|
|
ol_with_yielding_select=yes
|
|
|
|
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
|
|
|
|
if test $ol_with_threads = nt ; then
|
|
AC_MSG_ERROR([could not locate NT Threads])
|
|
fi
|
|
fi
|
|
|
|
if test $ol_with_threads = auto -o $ol_with_threads = yes \
|
|
-o $ol_with_threads = posix ; then
|
|
|
|
AC_CHECK_HEADERS(pthread.h)
|
|
|
|
if test $ac_cv_header_pthread_h = yes ; then
|
|
OL_POSIX_THREAD_VERSION
|
|
|
|
if test $ol_cv_pthread_version != 0 ; then
|
|
AC_DEFINE_UNQUOTED(HAVE_PTHREADS,$ol_cv_pthread_version,
|
|
[define to pthreads API spec revision])
|
|
else
|
|
AC_MSG_ERROR([unknown pthread version])
|
|
fi
|
|
|
|
# consider threads found
|
|
ol_with_threads=found
|
|
|
|
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
|
|
|
|
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
|
|
LTHREAD_LIBS="$LTHREAD_LIBS $ol_link_pthreads"
|
|
|
|
dnl save flags
|
|
save_CPPFLAGS="$CPPFLAGS"
|
|
save_LIBS="$LIBS"
|
|
LIBS="$LTHREAD_LIBS $LIBS"
|
|
|
|
dnl All POSIX Thread (final) implementations should have
|
|
dnl sched_yield instead of pthread yield.
|
|
dnl check for both, and thr_yield for Solaris
|
|
AC_CHECK_FUNCS(sched_yield pthread_yield thr_yield)
|
|
|
|
if test $ac_cv_func_sched_yield = no -a \
|
|
$ac_cv_func_pthread_yield = no -a \
|
|
$ac_cv_func_thr_yield = no ; then
|
|
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,
|
|
[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 -a \
|
|
"$ac_cv_func_thr_yield" = no ; then
|
|
AC_MSG_WARN([could not locate sched_yield() or pthread_yield()])
|
|
fi
|
|
|
|
dnl Check functions for compatibility
|
|
AC_CHECK_FUNCS(pthread_kill pthread_rwlock_destroy)
|
|
|
|
dnl Check for pthread_detach with <pthread.h> inclusion
|
|
dnl as it's symbol may have been mangled.
|
|
AC_CACHE_CHECK([for pthread_detach with <pthread.h>],
|
|
[ol_cv_func_pthread_detach], [
|
|
dnl save the flags
|
|
AC_TRY_LINK([
|
|
#include <pthread.h>
|
|
#ifndef NULL
|
|
#define NULL (void*)0
|
|
#endif
|
|
],
|
|
[pthread_detach(NULL);],
|
|
[ol_cv_func_pthread_detach=yes],
|
|
[ol_cv_func_pthread_detach=no])
|
|
])
|
|
|
|
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 \
|
|
pthread_getconcurrency \
|
|
thr_setconcurrency \
|
|
thr_getconcurrency \
|
|
)
|
|
|
|
OL_SYS_LINUX_THREADS
|
|
OL_LINUX_THREADS
|
|
|
|
if test $ol_cv_linux_threads = error; then
|
|
AC_MSG_ERROR([LinuxThreads header/library mismatch]);
|
|
fi
|
|
|
|
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])])
|
|
|
|
if test $ol_cv_pthread_create_works = no ; then
|
|
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_CACHE_CHECK([if select yields when using pthreads],
|
|
ol_cv_pthread_select_yields,[
|
|
AC_TRY_RUN([
|
|
#include <sys/types.h>
|
|
#include <sys/time.h>
|
|
#include <unistd.h>
|
|
#include <pthread.h>
|
|
#ifndef NULL
|
|
#define NULL (void*) 0
|
|
#endif
|
|
|
|
static int fildes[2];
|
|
|
|
static void *task(p)
|
|
void *p;
|
|
{
|
|
int i;
|
|
struct timeval tv;
|
|
|
|
fd_set rfds;
|
|
|
|
tv.tv_sec=10;
|
|
tv.tv_usec=0;
|
|
|
|
FD_ZERO(&rfds);
|
|
FD_SET(fildes[0], &rfds);
|
|
|
|
/* we're not interested in any fds */
|
|
i = select(FD_SETSIZE, &rfds, NULL, NULL, &tv);
|
|
|
|
if(i < 0) {
|
|
perror("select");
|
|
exit(10);
|
|
}
|
|
|
|
exit(0); /* if we exit here, the select blocked the whole process */
|
|
}
|
|
|
|
int main(argc, argv)
|
|
int argc;
|
|
char **argv;
|
|
{
|
|
pthread_t t;
|
|
|
|
/* create a pipe to select */
|
|
if(pipe(&fildes[0])) {
|
|
perror("select");
|
|
exit(1);
|
|
}
|
|
|
|
#ifdef HAVE_PTHREAD_SETCONCURRENCY
|
|
(void) pthread_setconcurrency(2);
|
|
#else
|
|
#ifdef HAVE_THR_SETCONCURRENCY
|
|
/* Set Solaris LWP concurrency to 2 */
|
|
thr_setconcurrency(2);
|
|
#endif
|
|
#endif
|
|
|
|
#if HAVE_PTHREADS < 6
|
|
pthread_create(&t, pthread_attr_default, task, NULL);
|
|
#else
|
|
pthread_create(&t, NULL, task, NULL);
|
|
#endif
|
|
|
|
/* make sure task runs first */
|
|
#if HAVE_THR_YIELD
|
|
thr_yield();
|
|
#elif defined( HAVE_SCHED_YIELD )
|
|
sched_yield();
|
|
#elif defined( HAVE_PTHREAD_YIELD )
|
|
pthread_yield();
|
|
#endif
|
|
|
|
exit(2);
|
|
}],
|
|
[ol_cv_pthread_select_yields=no],
|
|
[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
|
|
fi
|
|
fi
|
|
|
|
dnl restore flags
|
|
CPPFLAGS="$save_CPPFLAGS"
|
|
LIBS="$save_LIBS"
|
|
else
|
|
AC_MSG_ERROR([could not locate usable POSIX Threads])
|
|
fi
|
|
fi
|
|
|
|
if test $ol_with_threads = posix ; then
|
|
AC_MSG_ERROR([could not locate POSIX Threads])
|
|
fi
|
|
fi
|
|
|
|
if test $ol_with_threads = auto -o $ol_with_threads = yes \
|
|
-o $ol_with_threads = mach ; then
|
|
|
|
dnl check for Mach CThreads
|
|
AC_CHECK_HEADERS(mach/cthreads.h cthreads.h)
|
|
if test $ac_cv_header_mach_cthreads_h = yes ; then
|
|
ol_with_threads=found
|
|
|
|
dnl check for cthreads support in current $LIBS
|
|
AC_CHECK_FUNC(cthread_fork,[ol_link_threads=yes])
|
|
|
|
if test $ol_link_threads = no ; then
|
|
dnl try -all_load
|
|
dnl this test needs work
|
|
AC_CACHE_CHECK([for cthread_fork with -all_load],
|
|
[ol_cv_cthread_all_load], [
|
|
dnl save the flags
|
|
save_LIBS="$LIBS"
|
|
LIBS="-all_load $LIBS"
|
|
AC_TRY_LINK([#include <mach/cthreads.h>],[
|
|
cthread_fork((void *)0, (void *)0);
|
|
], ol_cv_cthread_all_load=yes, ol_cv_cthread_all_load=no)
|
|
dnl restore the LIBS
|
|
LIBS="$save_LIBS"
|
|
])
|
|
|
|
if test $ol_cv_cthread_all_load = yes ; then
|
|
LTHREAD_LIBS="$LTHREAD_LIBS -all_load"
|
|
ol_link_threads=mach
|
|
ol_with_threads=found
|
|
fi
|
|
fi
|
|
|
|
elif test $ac_cv_header_cthreads_h = yes ; then
|
|
dnl Hurd variant of Mach Cthreads
|
|
dnl uses <cthreads.h> and -lthreads
|
|
|
|
ol_with_threads=found
|
|
|
|
dnl save the flags
|
|
save_LIBS="$LIBS"
|
|
LIBS="$LIBS -lthreads"
|
|
AC_CHECK_FUNC(cthread_fork,[ol_link_threads=yes])
|
|
LIBS="$save_LIBS"
|
|
|
|
if test $ol_link_threads = yes ; then
|
|
LTHREAD_LIBS="-lthreads"
|
|
ol_link_threads=mach
|
|
ol_with_threads=found
|
|
else
|
|
AC_MSG_ERROR([could not link with Mach CThreads])
|
|
fi
|
|
|
|
elif test $ol_with_threads = mach ; then
|
|
AC_MSG_ERROR([could not locate Mach CThreads])
|
|
fi
|
|
|
|
if test $ol_link_threads = mach ; then
|
|
AC_DEFINE(HAVE_MACH_CTHREADS,1,
|
|
[define if you have Mach Cthreads])
|
|
elif test $ol_with_threads = found ; then
|
|
AC_MSG_ERROR([could not link with Mach CThreads])
|
|
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
|
|
ol_with_threads=found
|
|
|
|
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
|
|
|
|
dnl check for SunOS5 LWP
|
|
AC_CHECK_HEADERS(thread.h synch.h)
|
|
if test $ac_cv_header_thread_h = yes -a $ac_cv_header_synch_h = yes ; then
|
|
AC_CHECK_LIB(thread, thr_create, [have_thr=yes], [have_thr=no])
|
|
|
|
if test $have_thr = yes ; then
|
|
AC_DEFINE(HAVE_THR,1,
|
|
[if you have Solaris LWP (thr) package])
|
|
LTHREAD_LIBS="$LTHREAD_LIBS -lthread"
|
|
ol_link_threads=thr
|
|
|
|
if test $ol_with_yielding_select = auto ; then
|
|
ol_with_yielding_select=yes
|
|
fi
|
|
|
|
dnl Check for setconcurreny functions
|
|
AC_CHECK_FUNCS( \
|
|
thr_setconcurrency \
|
|
thr_getconcurrency \
|
|
)
|
|
fi
|
|
fi
|
|
|
|
dnl check for SunOS4 LWP
|
|
AC_CHECK_HEADERS(lwp/lwp.h)
|
|
if test $ac_cv_header_lwp_lwp_h = yes ; then
|
|
AC_CHECK_LIB(lwp, lwp_create, [have_lwp=yes], [have_lwp=no])
|
|
|
|
if test $have_lwp = yes ; then
|
|
AC_DEFINE(HAVE_LWP,1,
|
|
[if you have SunOS LWP package])
|
|
LTHREAD_LIBS="$LTHREAD_LIBS -llwp"
|
|
ol_link_threads=lwp
|
|
|
|
if test $ol_with_yielding_select = auto ; then
|
|
ol_with_yielding_select=no
|
|
fi
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test $ol_with_yielding_select = yes ; then
|
|
AC_DEFINE(HAVE_YIELDING_SELECT,1,
|
|
[define if select implicitly yields])
|
|
fi
|
|
|
|
if test $ol_with_threads = manual ; then
|
|
dnl User thinks he can manually configure threads.
|
|
ol_link_threads=yes
|
|
|
|
AC_MSG_WARN([thread defines and link options must be set manually])
|
|
|
|
AC_CHECK_HEADERS(pthread.h sched.h)
|
|
AC_CHECK_FUNCS(sched_yield pthread_yield)
|
|
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 -a $ol_link_threads != nt ; then
|
|
dnl needed to get reentrant/threadsafe versions
|
|
dnl
|
|
AC_DEFINE(REENTRANT,1)
|
|
AC_DEFINE(_REENTRANT,1)
|
|
AC_DEFINE(THREAD_SAFE,1)
|
|
AC_DEFINE(_THREAD_SAFE,1)
|
|
AC_DEFINE(THREADSAFE,1)
|
|
AC_DEFINE(_THREADSAFE,1)
|
|
AC_DEFINE(_SGI_MP_SOURCE,1)
|
|
|
|
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 <errno.h>], [errno = 0;],
|
|
[ol_cv_errno_thread_specific=yes],
|
|
[ol_cv_errno_thread_specific=no])
|
|
])
|
|
|
|
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 <netdb.h>], [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
|
|
|
|
dnl When in thread environment, use
|
|
dnl #if defined( HAVE_REENTRANT_FUNCTIONS ) || defined( HAVE_FUNC_R )
|
|
dnl func_r(...);
|
|
dnl #else
|
|
dnl # if defined( HAVE_THREADS )
|
|
dnl /* lock */
|
|
dnl # endif
|
|
dnl func(...);
|
|
dnl # if defined( HAVE_THREADS )
|
|
dnl /* unlock */
|
|
dnl # endif
|
|
dnl #endif
|
|
dnl
|
|
dnl HAVE_REENTRANT_FUNCTIONS is derived from:
|
|
dnl _POSIX_REENTRANT_FUNCTIONS
|
|
dnl _POSIX_THREAD_SAFE_FUNCTIONS
|
|
dnl _POSIX_THREADSAFE_FUNCTIONS
|
|
dnl
|
|
dnl and is currently defined in <ldap_pvt_thread.h>
|
|
dnl
|
|
dnl HAVE_THREADS is defined by <ldap_pvt_thread.h> iff -UNO_THREADS
|
|
dnl
|
|
dnl libldap/*.c should only include <ldap_pvt_thread.h> iff
|
|
dnl LDAP_R_COMPILE is defined. ie:
|
|
dnl #ifdef LDAP_R_COMPILE
|
|
dnl # include <ldap_pvt_thread.h>
|
|
dnl #endif
|
|
dnl
|
|
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
|
|
dnl dnl check for reentrant/threadsafe functions
|
|
dnl dnl
|
|
dnl dnl note: these should only be used when linking
|
|
dnl dnl with $LTHREAD_LIBS
|
|
dnl dnl
|
|
dnl save_CPPFLAGS="$CPPFLAGS"
|
|
dnl save_LIBS="$LIBS"
|
|
dnl LIBS="$LTHREAD_LIBS $LIBS"
|
|
dnl AC_CHECK_FUNCS( \
|
|
dnl gmtime_r \
|
|
dnl gethostbyaddr_r gethostbyname_r \
|
|
dnl feof_unlocked unlocked_feof \
|
|
dnl putc_unlocked unlocked_putc \
|
|
dnl flockfile ftrylockfile \
|
|
dnl )
|
|
dnl CPPFLAGS="$save_CPPFLAGS"
|
|
dnl LIBS="$save_LIBS"
|
|
fi
|
|
|
|
if test $ol_link_threads = no ; then
|
|
if test $ol_with_threads = yes ; then
|
|
AC_MSG_ERROR([no suitable thread support])
|
|
fi
|
|
|
|
if test $ol_with_threads = auto ; then
|
|
AC_MSG_WARN([no suitable thread support, disabling threads])
|
|
ol_with_threads=no
|
|
fi
|
|
|
|
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 ----------------------------------------------------------------
|
|
dnl Tests for reentrant functions necessary to build -lldap_r
|
|
AC_CHECK_FUNCS( \
|
|
ctime_r \
|
|
gethostbyname_r gethostbyaddr_r \
|
|
)
|
|
|
|
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 "$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
|
|
|
|
dnl ----------------------------------------------------------------
|
|
ol_link_ldbm=no
|
|
|
|
if test $ol_with_ldbm_api = auto \
|
|
-o $ol_with_ldbm_api = berkeley \
|
|
-o $ol_with_ldbm_api = bcompat ; then
|
|
|
|
if test $ol_with_ldbm_api = bcompat; then \
|
|
OL_BERKELEY_COMPAT_DB
|
|
else
|
|
OL_BERKELEY_DB
|
|
fi
|
|
|
|
if test $ol_cv_berkeley_db != no ; then
|
|
AC_DEFINE(HAVE_BERKELEY_DB,1,
|
|
[define this if Berkeley DB is available])
|
|
|
|
ol_link_ldbm=berkeley
|
|
ol_with_ldbm_api=berkeley
|
|
|
|
if test $ol_with_ldbm_type = hash ; then
|
|
AC_DEFINE(LDBM_USE_DBHASH,1,
|
|
[define this to use DBHASH w/ LDBM backend])
|
|
else
|
|
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
|
|
dnl (it could be no, but that would be an error
|
|
if test $ol_cv_lib_db != yes ; then
|
|
LDBM_LIBS="$LDBM_LIBS $ol_cv_lib_db"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test $ol_enable_bdb != no -o $ol_enable_hdb != no; then
|
|
if test $ol_link_ldbm != berkeley ; then
|
|
AC_MSG_ERROR(BDB/HDB: BerkeleyDB not available)
|
|
else
|
|
OL_BDB_COMPAT
|
|
|
|
if test $ol_cv_bdb_compat != yes ; then
|
|
AC_MSG_ERROR([BDB/HDB: BerkeleyDB version incompatible])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test $ol_link_ldbm = no -a $ol_with_ldbm_type = btree ; then
|
|
AC_MSG_WARN([Could not find LDBM with BTREE support])
|
|
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
|
|
|
|
if test $ol_cv_gdbm = yes ; then
|
|
ol_link_ldbm=gdbm
|
|
ol_with_ldbm_api=gdbm
|
|
|
|
if test $ol_cv_lib_gdbm != yes ; then
|
|
LDBM_LIBS="$LDBM_LIBS $ol_cv_lib_gdbm"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test $ol_with_ldbm_api = ndbm ; then
|
|
OL_NDBM
|
|
|
|
if test $ol_cv_ndbm = yes ; then
|
|
ol_link_ldbm=ndbm
|
|
ol_with_ldbm_api=ndbm
|
|
|
|
if test $ol_cv_lib_ndbm != yes ; then
|
|
LDBM_LIBS="$LDBM_LIBS $ol_cv_lib_ndbm"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test $ol_link_ldbm = no -a $ol_enable_ldbm != no ; then
|
|
AC_MSG_ERROR([could not find suitable LDBM backend])
|
|
fi
|
|
|
|
if test $ol_enable_bdb = yes -o \
|
|
$ol_enable_hdb = yes -o \
|
|
$ol_enable_ldbm = yes ; then
|
|
SLAPD_LIBS="$SLAPD_LIBS \$(LDBM_LIBS)"
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
|
|
if test $ol_enable_dynamic = yes -a $enable_shared = yes ; then
|
|
BUILD_LIBS_DYNAMIC=shared
|
|
AC_DEFINE(LDAP_LIBS_DYNAMIC, 1, [define if LDAP libs are dynamic])
|
|
LTSTATIC=""
|
|
else
|
|
BUILD_LIBS_DYNAMIC=static
|
|
LTSTATIC="-static"
|
|
fi
|
|
AC_SUBST(LTSTATIC)dnl
|
|
|
|
dnl ----------------------------------------------------------------
|
|
if test $ol_enable_wrappers != no ; then
|
|
AC_CHECK_HEADERS(tcpd.h,[
|
|
AC_MSG_CHECKING([for TCP wrappers library])
|
|
save_LIBS="$LIBS"
|
|
LIBS="$LIBS -lwrap"
|
|
AC_TRY_LINK([
|
|
#include <tcpd.h>
|
|
int allow_severity = 0;
|
|
int deny_severity = 0;
|
|
|
|
struct request_info *req;
|
|
],[
|
|
hosts_access(req)
|
|
],[AC_MSG_RESULT([-lwrap])
|
|
have_wrappers=yes
|
|
LIBS="$save_LIBS"],[
|
|
dnl try with -lnsl
|
|
LIBS="$LIBS -lnsl"
|
|
AC_TRY_LINK([
|
|
#include <tcpd.h>
|
|
int allow_severity = 0;
|
|
int deny_severity = 0;
|
|
|
|
struct request_info *req;
|
|
],[
|
|
hosts_access(req)
|
|
],[AC_MSG_RESULT([-lwrap -lnsl])
|
|
have_wrappers=yes
|
|
LIBS="$save_LIBS -lnsl"],[
|
|
AC_MSG_RESULT(no)
|
|
have_wrappers=no
|
|
LIBS=$save_LIBS])],[
|
|
have_wrappers=no])],[have_wrappers=no])
|
|
|
|
if test $have_wrappers = yes ; then
|
|
AC_DEFINE(HAVE_TCPD,1, [define if you have -lwrap])
|
|
WRAP_LIBS="-lwrap"
|
|
elif test $ol_enable_wrappers = yes ; then
|
|
AC_MSG_ERROR([could not find TCP wrappers, select apppropriate options or disable])
|
|
else
|
|
AC_MSG_WARN([could not find TCP wrappers, support disabled])
|
|
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
|
|
AC_MSG_ERROR(could not find syslog, select appropriate options or disable)
|
|
fi
|
|
ol_enable_syslog=$ac_cv_func_openlog
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl dmalloc support (deprecated in favor of -DCSRIMALLOC support)
|
|
dnl if test $ol_enable_dmalloc != no ; then
|
|
dnl AC_CHECK_HEADERS(dmalloc.h)
|
|
dnl AC_CHECK_LIB(dmalloc, dmalloc_shutdown)
|
|
dnl fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl SQL
|
|
ol_link_sql=no
|
|
if test $ol_enable_sql != no ; then
|
|
AC_CHECK_HEADERS(sql.h sqlext.h,[],[
|
|
AC_MSG_ERROR([could not locate SQL headers])
|
|
])
|
|
|
|
AC_CHECK_LIB(iodbc,SQLDriverConnect,[have_iodbc=yes],[have_iodbc=no])
|
|
if test $have_iodbc = yes ; then
|
|
ol_link_sql="-liodbc"
|
|
else
|
|
AC_CHECK_LIB(odbc,SQLDriverConnect,[have_odbc=yes],[have_odbc=no])
|
|
if test $have_odbc = yes ; then
|
|
ol_link_sql="-lodbc"
|
|
fi
|
|
fi
|
|
|
|
if test $ol_link_sql != no ; then
|
|
SLAPD_SQL_LIBS="$ol_link_sql"
|
|
|
|
elif test $ol_enable_sql != auto ; then
|
|
AC_MSG_ERROR([could not locate suitable ODBC library])
|
|
fi
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl
|
|
dnl Check for Cyrus SASL
|
|
dnl
|
|
WITH_SASL=no
|
|
ol_link_sasl=no
|
|
ol_link_spasswd=no
|
|
if test $ol_with_cyrus_sasl != no ; then
|
|
AC_CHECK_HEADERS(sasl/sasl.h sasl.h)
|
|
|
|
if test $ac_cv_header_sasl_sasl_h = yes -o $ac_cv_header_sasl_h = yes; then
|
|
AC_CHECK_LIB(sasl2, sasl_client_init,
|
|
[ol_link_sasl="-lsasl2"],
|
|
[AC_CHECK_LIB(sasl, sasl_client_init,
|
|
[ol_link_sasl="-lsasl"])])
|
|
fi
|
|
|
|
if test $ol_link_sasl = no ; then
|
|
if test $ol_with_cyrus_sasl != auto ; then
|
|
AC_MSG_ERROR([Could not locate Cyrus SASL])
|
|
else
|
|
AC_MSG_WARN([Could not locate Cyrus SASL])
|
|
AC_MSG_WARN([SASL authentication not supported!])
|
|
if test $ol_link_tls = no ; then
|
|
AC_MSG_WARN([Strong authentication not supported!])
|
|
fi
|
|
fi
|
|
else
|
|
OL_SASL_COMPAT
|
|
if test $ol_cv_sasl_compat = no ; then
|
|
ol_link_sasl=no
|
|
AC_MSG_ERROR([Cyrus SASL library located but is incompatible])
|
|
fi
|
|
|
|
AC_DEFINE(HAVE_CYRUS_SASL,1,[define if you have Cyrus SASL])
|
|
SASL_LIBS="$ol_link_sasl"
|
|
if test $ol_enable_spasswd != no ; then
|
|
ol_link_spasswd=yes
|
|
fi
|
|
|
|
ac_save_LIBS="$LIBS"
|
|
LIBS="$LIBS $ol_link_sasl"
|
|
AC_CHECK_FUNC(sasl_version, [AC_DEFINE(HAVE_SASL_VERSION,1,
|
|
[define if your SASL library has sasl_version()])])
|
|
LIBS="$ac_save_LIBS"
|
|
|
|
WITH_SASL=yes
|
|
fi
|
|
|
|
else
|
|
AC_MSG_WARN([SASL authentication not supported!])
|
|
if test $ol_link_tls = no ; then
|
|
AC_MSG_WARN([Strong authentication not supported!])
|
|
fi
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Check for entropy sources
|
|
if test $cross_compiling != yes -a "$ac_cv_mingw32" != 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
|
|
LUTIL_LIBS="$LUTIL_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 FreeBSD (and others) have crypt(3) in -lcrypt
|
|
if test $ol_enable_crypt != no ; then
|
|
save_LIBS="$LIBS"
|
|
LIBS="$TLS_LIBS $LIBS"
|
|
|
|
AC_CHECK_FUNC(crypt, [have_crypt=yes], [
|
|
LIBS="$save_LIBS"
|
|
AC_CHECK_LIB(crypt, crypt, [LUTIL_LIBS="$LUTIL_LIBS -lcrypt"
|
|
have_crypt=yes], [have_crypt=no])])
|
|
|
|
LIBS="$save_LIBS"
|
|
|
|
if test $have_crypt = yes ; then
|
|
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
|
|
AC_MSG_ERROR([could not find crypt, select appropriate options or disable])
|
|
fi
|
|
|
|
AC_MSG_WARN([disabling crypt support])
|
|
ol_enable_crypt=no
|
|
fi
|
|
fi
|
|
|
|
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"
|
|
LIBSRCS="$LIBSRCS setproctitle.c"])])
|
|
|
|
if test $have_setproctitle = yes ; then
|
|
AC_DEFINE(HAVE_SETPROCTITLE,1,
|
|
[define if setproctitle(3) is available])
|
|
fi
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Check for SLPv2 Compliant API Library
|
|
if test $ol_enable_slp != no ; then
|
|
AC_CHECK_HEADERS( slp.h )
|
|
|
|
if test $ac_cv_header_slp_h = yes ; then
|
|
AC_CHECK_LIB(slp, SLPOpen, [have_slp=yes], [have_slp=no])
|
|
if test $have_slp = yes ; then
|
|
AC_DEFINE(HAVE_SLP, 1, [define if you have -lslp])
|
|
SLAPD_SLP_LIBS=-lslp
|
|
fi
|
|
|
|
elif test $ol_enable_slp = yes ; then
|
|
AC_MSG_ERROR([SLP not found])
|
|
fi
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Check for multiple precision support
|
|
if test "$ol_with_multiple_precision" != "no" ; then
|
|
ol_have_bignum=no
|
|
ol_have_gmp=no
|
|
|
|
AC_CHECK_HEADERS(openssl/bn.h bn.h)
|
|
AC_CHECK_HEADERS(openssl/crypto.h crypto.h)
|
|
AC_CHECK_HEADERS( gmp.h )
|
|
|
|
if test "$ol_with_tls" = "found" ; then
|
|
ol_have_bn_h=no
|
|
ol_have_crypto_h=no
|
|
|
|
if test "$ac_cv_header_openssl_bn_h" = "yes" \
|
|
-o "$ac_cv_header_bn_h" = "yes" ; then
|
|
ol_have_bn_h=yes
|
|
fi
|
|
|
|
if test "$ac_cv_header_openssl_crypto_h" = "yes" \
|
|
-o "$ac_cv_header_crypto_h" = "yes" ; then
|
|
ol_have_crypto_h=yes
|
|
fi
|
|
|
|
if test "$ol_have_bn_h" = "yes" \
|
|
-a "$ol_have_crypto_h" = "yes" ; then
|
|
ol_have_bignum=yes
|
|
fi
|
|
fi
|
|
|
|
if test $ac_cv_header_gmp_h = yes ; then
|
|
AC_CHECK_LIB(gmp, __gmpz_add_ui, [have_gmp=yes], [have_gmp=no])
|
|
if test $have_gmp = yes ; then
|
|
ol_have_gmp=yes
|
|
fi
|
|
fi
|
|
|
|
AC_MSG_CHECKING([for multiple precision support])
|
|
|
|
ol_mp_support="none"
|
|
case "$ol_with_multiple_precision" in
|
|
auto)
|
|
dnl preferred sequence:
|
|
dnl - OpenSSL's BIGNUM (if libssl is already linked)
|
|
dnl - GNU's MP
|
|
dnl - unsigned long
|
|
if test "$ol_have_bignum" = "yes" ; then
|
|
ol_mp_support="bignum"
|
|
else
|
|
if test "$ol_have_gmp" = "yes" ; then
|
|
ol_mp_support="gmp"
|
|
fi
|
|
fi
|
|
;;
|
|
bignum)
|
|
if test "$ol_have_bignum" != "yes" ; then
|
|
AC_MSG_ERROR([OpenSSL's BIGNUM not available])
|
|
fi
|
|
ol_mp_support="bignum"
|
|
;;
|
|
gmp)
|
|
if test "$ol_have_gmp" != "yes" ; then
|
|
AC_MSG_ERROR([GMP not available])
|
|
fi
|
|
ol_mp_support="gmp"
|
|
;;
|
|
yes)
|
|
if test "$ol_have_bignum" = "yes" ; then
|
|
ol_mp_support="bignum"
|
|
elif test "$ol_have_gmp" = "yes" ; then
|
|
ol_mp_support="gmp"
|
|
else
|
|
AC_MSG_ERROR([not available])
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
case "$ol_mp_support" in
|
|
bignum)
|
|
AC_DEFINE(HAVE_BIGNUM, 1,
|
|
[define if you have SSLeay or OpenSSL's BIGNUM])
|
|
;;
|
|
gmp)
|
|
AC_DEFINE(HAVE_GMP, 1, [define if you have -lgmp])
|
|
SLAPD_GMP_LIBS=-lgmp
|
|
;;
|
|
none)
|
|
;;
|
|
esac
|
|
|
|
AC_MSG_RESULT($ol_mp_support)
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
|
|
|
dnl Checks for long long
|
|
AC_CACHE_CHECK([long long], ol_cv_type_long_long, [
|
|
AC_TRY_COMPILE([], [long long x;],
|
|
[ol_cv_type_long_long=yes],
|
|
[ol_cv_type_long_long=no])])
|
|
if test $ol_cv_type_long_long = yes; then
|
|
AC_DEFINE(HAVE_LONG_LONG, 1, [define if you have 'long long'])
|
|
fi
|
|
|
|
AC_TYPE_MODE_T
|
|
AC_TYPE_OFF_T
|
|
AC_TYPE_PID_T
|
|
AM_TYPE_PTRDIFF_T
|
|
AC_TYPE_SIGNAL
|
|
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_MSG_WARN([Crossing compiling... all bets are off!])
|
|
AC_DEFINE(CROSS_COMPILING, 1, [define if cross compiling])
|
|
else
|
|
AC_C_BIGENDIAN
|
|
fi
|
|
|
|
AC_COMPILE_CHECK_SIZEOF(short)
|
|
AC_COMPILE_CHECK_SIZEOF(int)
|
|
AC_COMPILE_CHECK_SIZEOF(long)
|
|
AC_COMPILE_CHECK_SIZEOF(wchar_t)
|
|
|
|
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
|
|
dnl check for vsnprintf
|
|
AC_CHECK_FUNCS(snprintf vsnprintf)
|
|
fi
|
|
|
|
AC_CHECK_FUNCS( \
|
|
bcopy \
|
|
closesocket \
|
|
chroot \
|
|
endgrent \
|
|
endpwent \
|
|
fcntl \
|
|
flock \
|
|
fstat \
|
|
getdtablesize \
|
|
getgrgid \
|
|
gethostname \
|
|
getpass \
|
|
getpassphrase \
|
|
getpwuid \
|
|
getpwnam \
|
|
getspnam \
|
|
gettimeofday \
|
|
initgroups \
|
|
lockf \
|
|
memcpy \
|
|
memmove \
|
|
mkstemp \
|
|
mktemp \
|
|
pipe \
|
|
read \
|
|
recv \
|
|
recvfrom \
|
|
setpwfile \
|
|
setgid \
|
|
setegid \
|
|
setsid \
|
|
setuid \
|
|
seteuid \
|
|
sigaction \
|
|
signal \
|
|
sigset \
|
|
strdup \
|
|
strpbrk \
|
|
strrchr \
|
|
strsep \
|
|
strstr \
|
|
strtol \
|
|
strtoul \
|
|
strtoq \
|
|
strtouq \
|
|
strtoll \
|
|
strspn \
|
|
sysconf \
|
|
usleep \
|
|
waitpid \
|
|
wait4 \
|
|
write \
|
|
send \
|
|
sendmsg \
|
|
sendto \
|
|
)
|
|
|
|
dnl We actually may need to replace more than this.
|
|
AC_REPLACE_FUNCS(getopt getpeereid)
|
|
|
|
if test "$ac_cv_func_getopt" != yes; then
|
|
LIBSRCS="$LIBSRCS getopt.c"
|
|
fi
|
|
if test "$ac_cv_func_getpeereid" != yes; then
|
|
OL_MSGHDR_MSG_ACCRIGHTS
|
|
LIBSRCS="$LIBSRCS getpeereid.c"
|
|
fi
|
|
if test "$ac_cv_func_snprintf" != yes -o "$ac_cv_func_vsnprintf" != yes; then
|
|
if test "$ac_cv_func_snprintf" != yes; then
|
|
AC_DEFINE(snprintf, ber_pvt_snprintf, [define to snprintf routine])
|
|
fi
|
|
if test "$ac_cv_func_vsnprintf" != yes; then
|
|
AC_DEFINE(vsnprintf, ber_pvt_vsnprintf, [define to snprintf routine])
|
|
fi
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl Sort out defines
|
|
|
|
if test "$ol_enable_slapi" != no ; then
|
|
dnl This check is done also if --enable-modules is used;
|
|
dnl it is duplicated here, 'cause it'd be cached anyway
|
|
AC_CHECK_HEADERS(ltdl.h)
|
|
|
|
if test $ac_cv_header_ltdl_h != yes ; then
|
|
AC_MSG_ERROR([could not locate <ltdl.h>])
|
|
fi
|
|
AC_CHECK_LIB(ltdl, lt_dlinit, [
|
|
SLAPI_LIBS=-lltdl
|
|
LIBSLAPI=libslapi.a
|
|
LIBSLAPITOOLS=../libslapi.a
|
|
AC_DEFINE(HAVE_LIBLTDL,1,[define if you have libtool -ltdl])
|
|
],[AC_MSG_ERROR([could not locate libtool -lltdl])])
|
|
|
|
AC_DEFINE(LDAP_SLAPI,1, [define this to add SLAPI code])
|
|
fi
|
|
|
|
if test "$ol_enable_debug" != no ; then
|
|
AC_DEFINE(LDAP_DEBUG,1,
|
|
[define this to add debugging code])
|
|
fi
|
|
if test "$ol_enable_syslog" = yes ; then
|
|
AC_DEFINE(LDAP_SYSLOG,1,
|
|
[define this to add syslog code])
|
|
fi
|
|
if test "$ol_link_kbind" != no ; then
|
|
AC_DEFINE(LDAP_API_FEATURE_X_OPENLDAP_V2_KBIND,LDAP_VENDOR_VERSION)
|
|
fi
|
|
if test "$ol_enable_proctitle" != no ; then
|
|
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)
|
|
fi
|
|
if test "$ol_enable_local" != no; then
|
|
AC_DEFINE(LDAP_PF_LOCAL,1,[define to support PF_LOCAL])
|
|
fi
|
|
if test "$ol_link_ipv6" != no; then
|
|
AC_DEFINE(LDAP_PF_INET6,1,[define to support PF_INET6])
|
|
fi
|
|
if test "$ol_enable_cleartext" != no ; then
|
|
AC_DEFINE(SLAPD_CLEARTEXT,1,[define to support cleartext passwords])
|
|
fi
|
|
if test "$ol_enable_crypt" != no ; then
|
|
AC_DEFINE(SLAPD_CRYPT,1,[define to support crypt(3) passwords])
|
|
fi
|
|
if test "$ol_link_spasswd" != no ; then
|
|
AC_DEFINE(SLAPD_SPASSWD,1,[define to support SASL passwords])
|
|
fi
|
|
if test "$ol_enable_multimaster" != no ; then
|
|
AC_DEFINE(SLAPD_MULTIMASTER,1,[define to support multimaster replication])
|
|
fi
|
|
if test "$ol_enable_rlookups" != no ; then
|
|
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_link_modules" != no ; then
|
|
AC_DEFINE(SLAPD_MODULES,1,[define to support modules])
|
|
BUILD_SLAPD=yes
|
|
SLAPD_MODULES_LDFLAGS="-dlopen self"
|
|
fi
|
|
|
|
AC_DEFINE(SLAPD_MOD_STATIC,1,[statically linked module])
|
|
AC_DEFINE(SLAPD_MOD_DYNAMIC,2,[dynamically linked module])
|
|
|
|
if test "$ol_enable_bdb" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_BDB=$ol_enable_bdb
|
|
if test "$ol_enable_bdb" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-bdb"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-bdb"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_BDB,$MFLAG,[define to support BDB backend])
|
|
fi
|
|
|
|
if test "$ol_enable_dnssrv" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_DNSSRV=$ol_enable_dnssrv
|
|
if test "$ol_enable_dnssrv" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-dnssrv"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-dnssrv"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_DNSSRV,$MFLAG,[define to support DNS SRV backend])
|
|
fi
|
|
|
|
if test "$ol_enable_hdb" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_HDB=$ol_enable_hdb
|
|
if test "$ol_enable_hdb" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-hdb"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-hdb"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_HDB,$MFLAG,[define to support HDB backend])
|
|
fi
|
|
|
|
if test "$ol_enable_ldap" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_LDAP=$ol_enable_ldap
|
|
if test "$ol_enable_ldap" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-ldap"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-ldap"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_LDAP,$MFLAG,[define to support LDAP backend])
|
|
fi
|
|
|
|
if test "$ol_link_ldbm" != no -a $ol_enable_ldbm != no; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_LDBM=$ol_enable_ldbm
|
|
if test "$ol_enable_ldbm" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-ldbm"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-ldbm"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_LDBM,$MFLAG,[define to support LDBM backend])
|
|
fi
|
|
|
|
if test "$ol_enable_meta" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_META=$ol_enable_meta
|
|
BUILD_REWRITE=yes
|
|
if test "$ol_enable_meta" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-meta"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-meta"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_META,$MFLAG,[define to support LDAP Metadirectory backend])
|
|
fi
|
|
|
|
if test "$ol_enable_monitor" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_MONITOR=$ol_enable_monitor
|
|
if test "$ol_enable_monitor" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-monitor"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-monitor"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_MONITOR,$MFLAG,[define to support cn=Monitor backend])
|
|
fi
|
|
|
|
if test "$ol_enable_null" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_NULL=$ol_enable_null
|
|
if test "$ol_enable_null" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-null"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-null"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_NULL,$MFLAG,[define to support NULL backend])
|
|
fi
|
|
|
|
if test "$ol_enable_passwd" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_PASSWD=$ol_enable_passwd
|
|
if test "$ol_enable_passwd" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-passwd"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-passwd"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_PASSWD,$MFLAG,[define to support PASSWD backend])
|
|
fi
|
|
|
|
if test "$ol_link_perl" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_PERL=$ol_enable_perl
|
|
if test "$ol_enable_perl" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-perl"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-perl"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_PERL,$MFLAG,[define to support PERL backend])
|
|
fi
|
|
|
|
if test "$ol_enable_relay" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_RELAY=$ol_enable_relay
|
|
if test "$ol_enable_relay" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-relay"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-relay"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_RELAY,$MFLAG,[define to support relay backend])
|
|
fi
|
|
|
|
if test "$ol_enable_shell" != no ; then
|
|
if test "$ol_link_thread" != no ; then
|
|
AC_MSG_WARN([Use of --without-threads is recommended with back-shell])
|
|
fi
|
|
BUILD_SLAPD=yes
|
|
BUILD_SHELL=$ol_enable_shell
|
|
if test "$ol_enable_shell" = mod ; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-shell"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-shell"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_SHELL,$MFLAG,[define to support SHELL backend])
|
|
fi
|
|
|
|
if test "$ol_link_sql" != no ; then
|
|
BUILD_SLAPD=yes
|
|
BUILD_SQL=$ol_enable_sql
|
|
if test "$ol_enable_sql" = mod; then
|
|
SLAPD_DYNAMIC_BACKENDS="$SLAPD_DYNAMIC_BACKENDS back-sql"
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
else
|
|
SLAPD_STATIC_BACKENDS="$SLAPD_STATIC_BACKENDS back-sql"
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_SQL,$MFLAG,[define to support SQL backend])
|
|
fi
|
|
|
|
if test "$ol_enable_chain" != no ; then
|
|
BUILD_CHAIN=$ol_enable_chain
|
|
if test "$ol_enable_chain" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS chain.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_CHAIN,$MFLAG,[define for Dynamic Group overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_denyop" != no ; then
|
|
BUILD_DENYOP=$ol_enable_denyop
|
|
if test "$ol_enable_denyop" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS denyop.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_DENYOP,$MFLAG,[define for Dynamic Group overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_dyngroup" != no ; then
|
|
BUILD_DYNGROUP=$ol_enable_dyngroup
|
|
if test "$ol_enable_dyngroup" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS dyngroup.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_DYNGROUP,$MFLAG,[define for Dynamic Group overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_lastmod" != no ; then
|
|
BUILD_LASTMOD=$ol_enable_lastmod
|
|
if test "$ol_enable_lastmod" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS lastmod.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_LASTMOD,$MFLAG,[define for Last Modification overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_ppolicy" != no ; then
|
|
BUILD_PPOLICY=$ol_enable_ppolicy
|
|
if test "$ol_enable_ppolicy" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS ppolicy.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_PPOLICY,$MFLAG,[define for Password Policy overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_proxycache" != no ; then
|
|
BUILD_PROXYCACHE=$ol_enable_proxycache
|
|
if test "$ol_enable_proxycache" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS pcache.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_PROXYCACHE,$MFLAG,[define for Proxy Cache overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_refint" != no ; then
|
|
BUILD_REFINT=$ol_enable_refint
|
|
if test "$ol_enable_refint" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS refint.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_REFINT,$MFLAG,[define for Referential Integrity overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_rwm" != no ; then
|
|
BUILD_REWRITE=yes
|
|
BUILD_RWM=$ol_enable_rwm
|
|
if test "$ol_enable_rwm" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS rwm.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_RWM,$MFLAG,[define for Rewrite/Remap overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_unique" != no ; then
|
|
BUILD_UNIQUE=$ol_enable_unique
|
|
if test "$ol_enable_unique" = mod ; then
|
|
MFLAG=SLAPD_MOD_DYNAMIC
|
|
SLAPD_DYNAMIC_OVERLAYS="$SLAPD_DYNAMIC_OVERLAYS unique.la"
|
|
else
|
|
MFLAG=SLAPD_MOD_STATIC
|
|
fi
|
|
AC_DEFINE_UNQUOTED(SLAPD_OVER_UNIQUE,$MFLAG,[define for Attribute Uniqueness overlay])
|
|
fi
|
|
|
|
if test "$ol_enable_slurpd" != no -a "$ol_link_threads" != no -a \
|
|
$BUILD_SLAPD = yes ; then
|
|
BUILD_SLURPD=yes
|
|
fi
|
|
|
|
if test "$ol_enable_rewrite" != no ; then
|
|
AC_DEFINE(ENABLE_REWRITE,1,[define to enable rewriting in back-ldap and back-meta])
|
|
BUILD_REWRITE=yes
|
|
fi
|
|
|
|
if test "$ol_enable_slapi" != no ; then
|
|
AC_DEFINE(ENABLE_SLAPI,1,[define to enable slapi library])
|
|
BUILD_SLAPI=yes
|
|
SLAPD_SLAPI_DEPEND=libslapi.a
|
|
fi
|
|
|
|
dnl ----------------------------------------------------------------
|
|
|
|
dnl
|
|
dnl For Windows build, we don't want to include -dlopen flags.
|
|
dnl They hurt more than they help.
|
|
dnl
|
|
|
|
if test "$ac_cv_mingw32" = yes ; then
|
|
PLAT=NT
|
|
SLAPD_MODULES_LDFLAGS=
|
|
else
|
|
PLAT=UNIX
|
|
fi
|
|
|
|
if test -z "$SLAPD_STATIC_BACKENDS"; then
|
|
SLAPD_NO_STATIC='#'
|
|
else
|
|
SLAPD_NO_STATIC=
|
|
fi
|
|
|
|
dnl Generate static backend header file
|
|
BACKEND_HEADER=servers/slapd/backend.h
|
|
cat > $BACKEND_HEADER << EOF
|
|
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
*
|
|
* Copyright 1998-2004 The OpenLDAP Foundation.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
|
* Public License.
|
|
*
|
|
* A copy of this license is available in the file LICENSE in the
|
|
* top-level directory of the distribution or, alternatively, at
|
|
* <http://www.OpenLDAP.org/license.html>.
|
|
*/
|
|
/* This file is automatically generated by configure; please do not edit.
|
|
*/
|
|
|
|
EOF
|
|
|
|
for b in $SLAPD_STATIC_BACKENDS; do
|
|
bb=`echo "$b" | sed -e 's;back-;;'`
|
|
|
|
cat >> $BACKEND_HEADER << EOF
|
|
extern BI_init ${bb}_back_initialize;
|
|
EOF
|
|
done
|
|
|
|
cat >> $BACKEND_HEADER << EOF
|
|
|
|
static BackendInfo binfo[[]] = {
|
|
EOF
|
|
|
|
for b in $SLAPD_STATIC_BACKENDS; do
|
|
bb=`echo "$b" | sed -e 's;back-;;'`
|
|
|
|
cat >> $BACKEND_HEADER << EOF
|
|
{ "$bb", ${bb}_back_initialize },
|
|
EOF
|
|
done
|
|
|
|
cat >> $BACKEND_HEADER << EOF
|
|
{ NULL, NULL }
|
|
};
|
|
|
|
/* end of generated file */
|
|
EOF
|
|
dnl done generating static backend header file
|
|
|
|
AC_SUBST(LIBSRCS)
|
|
AC_SUBST(PLAT)
|
|
AC_SUBST(WITH_SASL)
|
|
AC_SUBST(WITH_TLS)
|
|
AC_SUBST(WITH_MODULES_ENABLED)
|
|
AC_SUBST(BUILD_LIBS_DYNAMIC)
|
|
|
|
AC_SUBST(BUILD_SLAPD)
|
|
dnl slapi
|
|
AC_SUBST(BUILD_SLAPI)
|
|
AC_SUBST(SLAPD_SLAPI_DEPEND)
|
|
dnl backends
|
|
AC_SUBST(BUILD_BDB)
|
|
AC_SUBST(BUILD_DNSSRV)
|
|
AC_SUBST(BUILD_HDB)
|
|
AC_SUBST(BUILD_LDAP)
|
|
AC_SUBST(BUILD_LDBM)
|
|
AC_SUBST(BUILD_META)
|
|
AC_SUBST(BUILD_MONITOR)
|
|
AC_SUBST(BUILD_NULL)
|
|
AC_SUBST(BUILD_PASSWD)
|
|
AC_SUBST(BUILD_RELAY)
|
|
AC_SUBST(BUILD_PERL)
|
|
AC_SUBST(BUILD_SHELL)
|
|
AC_SUBST(BUILD_SQL)
|
|
dnl overlays
|
|
AC_SUBST(BUILD_CHAIN)
|
|
AC_SUBST(BUILD_DENYOP)
|
|
AC_SUBST(BUILD_DYNGROUP)
|
|
AC_SUBST(BUILD_LASTMOD)
|
|
AC_SUBST(BUILD_PPOLICY)
|
|
AC_SUBST(BUILD_PROXYCACHE)
|
|
AC_SUBST(BUILD_REFINT)
|
|
AC_SUBST(BUILD_RWM)
|
|
AC_SUBST(BUILD_UNIQUE)
|
|
AC_SUBST(BUILD_SLURPD)
|
|
|
|
AC_SUBST(LDAP_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(SLAPD_MODULES_CPPFLAGS)
|
|
AC_SUBST(SLAPD_MODULES_LDFLAGS)
|
|
|
|
AC_SUBST(SLAPD_NO_STATIC)
|
|
AC_SUBST(SLAPD_STATIC_BACKENDS)
|
|
AC_SUBST(SLAPD_DYNAMIC_BACKENDS)
|
|
AC_SUBST(SLAPD_DYNAMIC_OVERLAYS)
|
|
|
|
AC_SUBST(PERL_CPPFLAGS)
|
|
AC_SUBST(SLAPD_PERL_LDFLAGS)
|
|
AC_SUBST(MOD_PERL_LDFLAGS)
|
|
|
|
AC_SUBST(KRB4_LIBS)
|
|
AC_SUBST(KRB5_LIBS)
|
|
AC_SUBST(SASL_LIBS)
|
|
AC_SUBST(TLS_LIBS)
|
|
AC_SUBST(MODULES_LIBS)
|
|
AC_SUBST(SLAPI_LIBS)
|
|
AC_SUBST(LIBSLAPI)
|
|
AC_SUBST(LIBSLAPITOOLS)
|
|
AC_SUBST(AUTH_LIBS)
|
|
|
|
AC_SUBST(SLAPD_SLP_LIBS)
|
|
AC_SUBST(SLAPD_GMP_LIBS)
|
|
|
|
AC_SUBST(SLAPD_SQL_LDFLAGS)
|
|
AC_SUBST(SLAPD_SQL_LIBS)
|
|
AC_SUBST(SLAPD_SQL_INCLUDES)
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl final help output
|
|
AC_ARG_WITH(xxinstall,[
|
|
See INSTALL file for further details.])
|
|
|
|
dnl ----------------------------------------------------------------
|
|
dnl final output
|
|
dnl
|
|
|
|
AC_OUTPUT( \
|
|
Makefile:build/top.mk:Makefile.in:build/dir.mk \
|
|
doc/Makefile:build/top.mk:doc/Makefile.in:build/dir.mk \
|
|
doc/man/Makefile:build/top.mk:doc/man/Makefile.in:build/dir.mk \
|
|
doc/man/man1/Makefile:build/top.mk:doc/man/man1/Makefile.in:build/man.mk \
|
|
doc/man/man3/Makefile:build/top.mk:doc/man/man3/Makefile.in:build/man.mk \
|
|
doc/man/man5/Makefile:build/top.mk:doc/man/man5/Makefile.in:build/man.mk \
|
|
doc/man/man8/Makefile:build/top.mk:doc/man/man8/Makefile.in:build/man.mk \
|
|
clients/Makefile:build/top.mk:clients/Makefile.in:build/dir.mk \
|
|
clients/tools/Makefile:build/top.mk:clients/tools/Makefile.in:build/rules.mk \
|
|
include/Makefile:build/top.mk:include/Makefile.in \
|
|
libraries/Makefile:build/top.mk:libraries/Makefile.in:build/dir.mk \
|
|
libraries/liblber/Makefile:build/top.mk:libraries/liblber/Makefile.in:build/lib.mk:build/lib-shared.mk \
|
|
libraries/libldap/Makefile:build/top.mk:libraries/libldap/Makefile.in:build/lib.mk:build/lib-shared.mk \
|
|
libraries/libldap_r/Makefile:build/top.mk:libraries/libldap_r/Makefile.in:build/lib.mk:build/lib-shared.mk \
|
|
libraries/liblunicode/Makefile:build/top.mk:libraries/liblunicode/Makefile.in:build/lib.mk:build/lib-static.mk \
|
|
libraries/liblutil/Makefile:build/top.mk:libraries/liblutil/Makefile.in:build/lib.mk:build/lib-static.mk \
|
|
libraries/librewrite/Makefile:build/top.mk:libraries/librewrite/Makefile.in:build/lib.mk:build/lib-static.mk \
|
|
servers/Makefile:build/top.mk:servers/Makefile.in:build/dir.mk \
|
|
servers/slapd/Makefile:build/top.mk:servers/slapd/Makefile.in:build/srv.mk \
|
|
servers/slapd/back-bdb/Makefile:build/top.mk:servers/slapd/back-bdb/Makefile.in:build/mod.mk \
|
|
servers/slapd/back-dnssrv/Makefile:build/top.mk:servers/slapd/back-dnssrv/Makefile.in:build/mod.mk \
|
|
servers/slapd/back-hdb/Makefile:build/top.mk:servers/slapd/back-hdb/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-meta/Makefile:build/top.mk:servers/slapd/back-meta/Makefile.in:build/mod.mk \
|
|
servers/slapd/back-monitor/Makefile:build/top.mk:servers/slapd/back-monitor/Makefile.in:build/mod.mk \
|
|
servers/slapd/back-null/Makefile:build/top.mk:servers/slapd/back-null/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-relay/Makefile:build/top.mk:servers/slapd/back-relay/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-sql/Makefile:build/top.mk:servers/slapd/back-sql/Makefile.in:build/mod.mk \
|
|
servers/slapd/shell-backends/Makefile:build/top.mk:servers/slapd/shell-backends/Makefile.in:build/srv.mk \
|
|
servers/slapd/slapi/Makefile:build/top.mk:servers/slapd/slapi/Makefile.in:build/lib.mk:build/lib-shared.mk \
|
|
servers/slapd/overlays/Makefile:build/top.mk:servers/slapd/overlays/Makefile.in:build/lib.mk \
|
|
servers/slurpd/Makefile:build/top.mk:servers/slurpd/Makefile.in:build/srv.mk \
|
|
tests/Makefile:build/top.mk:tests/Makefile.in:build/dir.mk \
|
|
tests/run \
|
|
tests/progs/Makefile:build/top.mk:tests/progs/Makefile.in:build/rules.mk \
|
|
,[
|
|
chmod +x tests/run
|
|
date > stamp-h
|
|
echo Please run \"make depend\" to build dependencies
|
|
])
|