2012-10-22 21:28:41 +01:00
# -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.
2009-10-16 06:20:23 +00:00
2009-11-05 14:05:26 +00:00
AC_PREREQ([2.59])
2014-06-16 17:27:03 +02:00
# For released versions, this is in x.y.z format.
# For GIT versions, this is x.y.z-git, where x.y.z denotes the software
# version that was used as a base + changes that were made later, but
# are not released yet.
2015-09-09 18:56:23 +02:00
AC_INIT(kea, 0.9.2-git, kea-dev@lists.isc.org)
2009-10-16 06:20:23 +00:00
AC_CONFIG_SRCDIR(README)
2014-01-07 17:02:33 +05:30
# serial-tests is not available in automake version before 1.13, so
# we'll check that and conditionally use serial-tests. This check is
# adopted from code by Richard W.M. Jones:
# https://www.redhat.com/archives/libguestfs/2013-February/msg00102.html
m4_define([serial_tests], [
m4_esyscmd([automake --version |
head -1 |
awk '{split ($NF,a,"."); if (a[1] == 1 && a[2] >= 12) { print "serial-tests" }}'
])
])
AM_INIT_AUTOMAKE(foreign serial_tests)
2012-02-16 11:48:40 +01:00
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])dnl be backward compatible
2009-10-16 06:20:23 +00:00
AC_CONFIG_HEADERS([config.h])
2012-04-30 09:32:17 +05:30
AC_CONFIG_MACRO_DIR([m4macros])
2009-10-16 06:20:23 +00:00
2015-02-27 14:36:24 +01:00
AC_CANONICAL_HOST
2009-10-16 06:20:23 +00:00
# Checks for programs.
AC_PROG_CXX
2011-01-07 11:59:03 -08:00
2014-08-11 16:09:43 +02:00
# Check for exact Kea version.
AC_MSG_CHECKING(whether this is a tarball or git source)
if test -d "${srcdir}/.git"; then
KEA_SRCID="git `(cd "${top_srcdir}";git rev-parse HEAD)`"
AC_MSG_RESULT("git")
else
KEA_SRCID="tarball"
AC_MSG_RESULT("tarball")
fi
# Export EXTENDED_VERSION to config.h
# This will be either "tarball" or "git abcd".
AC_DEFINE_UNQUOTED([EXTENDED_VERSION], ["${KEA_SRCID}"], [Extended Kea version])
2015-05-11 16:19:43 +02:00
# Find a separator for path_replacer
for sep in "+" "," ";" "&" "__NONE__"; do
if `pwd | grep -q $sep`; then continue; fi
if `echo ${prefix} | grep -q $sep`; then continue; fi
if `echo ${sysconfdir} | grep -q $sep`; then continue; fi
if `echo ${localstatedir} | grep -q $sep`; then continue; fi
SEP=$sep
break
done
if test "$sep" = "__NONE__"; then
AC_MSG_ERROR([can't find a separator character in '+,;&' for the path_replacer shell script])
fi
AC_SUBST(SEP)
2012-10-23 09:25:20 +05:30
# Enable low-performing debugging facilities? This option optionally
# enables some debugging aids that perform slowly and hence aren't built
# by default.
2012-10-18 19:02:04 +05:30
AC_ARG_ENABLE([debug],
AS_HELP_STRING([--enable-debug],
[enable debugging (default is no)]),
[case "${enableval}" in
2012-10-18 19:12:37 +05:30
yes) debug_enabled=yes ;;
no) debug_enabled=no ;;
2012-10-18 19:02:04 +05:30
*) AC_MSG_ERROR([bad value ${enableval} for --enable-debug]) ;;
2012-10-18 19:12:37 +05:30
esac],[debug_enabled=no])
AM_CONDITIONAL([DEBUG_ENABLED], [test x$debug_enabled = xyes])
2012-10-23 09:25:20 +05:30
AM_COND_IF([DEBUG_ENABLED], [AC_DEFINE([ENABLE_DEBUG], [1], [Enable low-performing debugging facilities?])])
2012-10-18 19:02:04 +05:30
2011-01-07 11:59:03 -08:00
# Libtool configuration
#
2011-08-25 16:36:56 +02:00
# libtool cannot handle spaces in paths, so exit early if there is one
if [ test `echo $PWD | grep -c ' '` != "0" ]; then
2014-08-06 12:51:57 +02:00
AC_MSG_ERROR([Kea cannot be built in a directory that contains spaces, because of libtool limitations. Please change the directory name, or use a symbolic link that does not contain spaces.])
2011-08-25 16:36:56 +02:00
fi
2011-01-07 11:59:03 -08:00
# On FreeBSD (and probably some others), clang++ does not meet an autoconf
# assumption in identifying libtool configuration regarding shared library:
2011-02-28 08:39:49 -08:00
# the configure script will execute "$CC -shared $CFLAGS/$CXXFLAGS -v" and
# expect the output contains -Lxxx or -Ryyy. This is the case for g++, but
# not for clang++, and, as a result, it will cause various errors in linking
# programs or running them with a shared object (such as some of our python
# scripts).
2011-01-07 11:59:03 -08:00
# To work around this problem we define a temporary variable
# "CXX_LIBTOOL_LDFLAGS". It's expected to be defined as, e.g, "-L/usr/lib"
# to temporarily fake the output so that it will be compatible with that of
# g++.
CFLAGS_SAVED=$CFLAGS
2011-02-28 08:39:49 -08:00
CXXFLAGS_SAVED=$CXXFLAGS
2011-01-07 11:59:03 -08:00
CFLAGS="$CFLAGS $CXX_LIBTOOL_LDFLAGS"
2011-02-28 08:39:49 -08:00
CXXFLAGS="$CXXFLAGS $CXX_LIBTOOL_LDFLAGS"
2014-08-21 16:10:12 +02:00
LT_INIT
2011-01-07 11:59:03 -08:00
CFLAGS=$CFLAGS_SAVED
2011-02-28 08:39:49 -08:00
CXXFLAGS=$CXXFLAGS_SAVED
2010-01-26 22:15:42 +00:00
2010-03-08 07:58:25 +00:00
# Use C++ language
2010-06-24 01:41:29 +00:00
AC_LANG([C++])
# Identify the compiler: this check must be after AC_PROG_CXX and AC_LANG.
2010-06-23 06:25:14 +00:00
AM_CONDITIONAL(USE_GXX, test "X${GXX}" = "Xyes")
2010-06-24 01:33:47 +00:00
AC_CHECK_DECL([__SUNPRO_CC], [SUNCXX="yes"], [SUNCXX="no"])
2010-10-10 03:27:23 +00:00
AC_CHECK_DECL([__clang__], [CLANGPP="yes"], [CLANGPP="no"])
AM_CONDITIONAL(USE_CLANGPP, test "X${CLANGPP}" = "Xyes")
2010-06-23 06:25:14 +00:00
2014-08-12 13:03:33 +02:00
dnl Determine if we are using GNU sed
2013-09-12 15:45:08 +02:00
GNU_SED=no
2014-01-21 11:58:56 -06:00
$SED --version 2> /dev/null | grep GNU > /dev/null 2>&1
2013-09-12 15:45:08 +02:00
if test $? -eq 0; then
GNU_SED=yes
fi
2010-07-07 18:42:45 +00:00
# Linker options
2014-08-14 18:30:48 +02:00
# check -R, "-Wl,-R" or -rpath
2012-10-31 15:57:26 -07:00
AX_ISC_RPATH
2010-07-07 18:42:45 +00:00
2012-10-07 23:53:26 -07:00
# Compiler dependent settings: define some mandatory CXXFLAGS here.
2014-08-12 13:11:38 +02:00
# We also use a separate variable KEA_CXXFLAGS. This will (and should) be
2012-10-07 23:53:26 -07:00
# used as the default value for each specific AM_CXXFLAGS:
2014-08-12 13:11:38 +02:00
# AM_CXXFLAGS = $(KEA_CXXFLAGS)
2012-10-07 23:53:26 -07:00
# AM_CXXFLAGS += ... # add module specific flags
# We need this so that we can disable some specific compiler warnings per
# module basis; since AM_CXXFLAGS are placed before CXXFLAGS, and since
# gcc's -Wno-XXX option must be specified after -Wall or -Wextra, we cannot
# specify the default warning flags in CXXFLAGS and let specific modules
# "override" the default.
# This may be used to try linker flags.
2014-08-12 13:03:33 +02:00
AC_DEFUN([KEA_CXX_TRY_FLAG], [
2012-10-07 23:53:26 -07:00
AC_MSG_CHECKING([whether $CXX supports $1])
2014-08-12 13:03:33 +02:00
kea_save_CXXFLAGS="$CXXFLAGS"
2012-10-07 23:53:26 -07:00
CXXFLAGS="$CXXFLAGS $1"
AC_LINK_IFELSE([AC_LANG_SOURCE([int main(void){ return 0;}])],
2014-08-12 13:03:33 +02:00
[kea_cxx_flag=yes], [kea_cxx_flag=no])
CXXFLAGS="$kea_save_CXXFLAGS"
2012-10-07 23:53:26 -07:00
2014-08-12 13:03:33 +02:00
if test "x$kea_cxx_flag" = "xyes"; then
2012-10-07 23:53:26 -07:00
ifelse([$2], , :, [$2])
else
ifelse([$3], , :, [$3])
fi
2014-08-12 13:03:33 +02:00
AC_MSG_RESULT([$kea_cxx_flag])
2012-10-07 23:53:26 -07:00
])
2013-11-13 13:02:08 +05:30
CXX_VERSION="unknown"
2012-10-07 23:53:26 -07:00
# SunStudio compiler requires special compiler options for boost
# (http://blogs.sun.com/sga/entry/boost_mini_howto)
if test "$SUNCXX" = "yes"; then
2013-09-16 10:36:41 +02:00
CXX_VERSION=`$CXX -V 2> /dev/null | head -1`
2012-10-07 23:53:26 -07:00
CXXFLAGS="$CXXFLAGS -library=stlport4 -features=tmplife -features=tmplrefstatic"
MULTITHREADING_FLAG="-mt"
fi
# Newer versions of clang++ promotes "unused driver arguments" warnings to
# a fatal error with -Werror, causing build failure. Since we use multiple
# compilers on multiple systems, this can easily happen due to settings for
# non clang++ environments that could be just ignored otherwise. It can also
# happen if clang++ is used via ccache. So, although probably suboptimal,
# we suppress this particular warning. Note that it doesn't weaken checks
# on the source code.
if test "$CLANGPP" = "yes"; then
2013-09-12 15:45:08 +02:00
CXX_VERSION=`$CXX --version 2> /dev/null | head -1`
2014-08-12 13:11:38 +02:00
KEA_CXXFLAGS="$KEA_CXXFLAGS -Qunused-arguments"
2012-10-07 23:53:26 -07:00
fi
2014-08-12 13:03:33 +02:00
KEA_CXX_TRY_FLAG([-Wno-missing-field-initializers],
2012-10-07 23:53:26 -07:00
[WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG="-Wno-missing-field-initializers"])
AC_SUBST(WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG)
# gcc specific settings:
if test "X$GXX" = "Xyes"; then
2013-09-12 15:45:08 +02:00
CXX_VERSION=`$CXX --version 2> /dev/null | head -1`
2014-08-12 13:11:38 +02:00
KEA_CXXFLAGS="$KEA_CXXFLAGS -Wall -Wextra -Wnon-virtual-dtor -Wwrite-strings -Woverloaded-virtual -Wno-sign-compare"
2012-10-07 23:53:26 -07:00
case "$host" in
*-solaris*)
MULTITHREADING_FLAG=-pthreads
# In Solaris, IN6ADDR_ANY_INIT and IN6ADDR_LOOPBACK_INIT need -Wno-missing-braces
2014-08-12 13:11:38 +02:00
KEA_CXXFLAGS="$KEA_CXXFLAGS -Wno-missing-braces"
2012-10-07 23:53:26 -07:00
;;
2014-10-28 17:24:16 +01:00
*-apple-darwin*)
MULTITHREADING_FLAG=
;;
2012-10-07 23:53:26 -07:00
*)
MULTITHREADING_FLAG=-pthread
;;
esac
# Don't use -Werror if configured not to
AC_ARG_WITH(werror,
AC_HELP_STRING([--with-werror], [Compile using -Werror (default=yes)]),
[
case "${withval}" in
yes) with_werror=1 ;;
no) with_werror=0 ;;
*) AC_MSG_ERROR(bad value ${withval} for --with-werror) ;;
esac],
[with_werror=1])
werror_ok=0
# Certain versions of gcc (g++) have a bug that incorrectly warns about
# the use of anonymous name spaces even if they're closed in a single
# translation unit. For these versions we have to disable -Werror.
if test $with_werror = 1; then
CXXFLAGS_SAVED="$CXXFLAGS"
2014-08-12 13:11:38 +02:00
CXXFLAGS="$CXXFLAGS $KEA_CXXFLAGS -Werror"
2012-10-07 23:53:26 -07:00
AC_MSG_CHECKING(for in-TU anonymous namespace breakage)
2013-02-21 13:05:20 -08:00
# We use struct, not class, here, because some compilers complain about
# "unused private members", causing a false positive.
AC_TRY_COMPILE([namespace { struct Foo {}; }
namespace isc {struct Bar {Foo foo_;};} ],,
2012-10-07 23:53:26 -07:00
[AC_MSG_RESULT(no)
werror_ok=1
2014-08-12 13:11:38 +02:00
KEA_CXXFLAGS="$KEA_CXXFLAGS -Werror"],
2012-10-07 23:53:26 -07:00
[AC_MSG_RESULT(yes)])
CXXFLAGS="$CXXFLAGS_SAVED"
fi
2012-10-10 11:02:24 -07:00
fi dnl GXX = yes
2010-08-13 23:22:54 +00:00
# allow building programs with static link. we need to make it selective
# because loadable modules cannot be statically linked.
AC_ARG_ENABLE([static-link],
AC_HELP_STRING([--enable-static-link],
[build programs with static link [[default=no]]]),
[enable_static_link=yes], [enable_static_link=no])
AM_CONDITIONAL(USE_STATIC_LINK, test $enable_static_link = yes)
2014-08-06 12:51:57 +02:00
AM_COND_IF([USE_STATIC_LINK], [AC_DEFINE([USE_STATIC_LINK], [1], [Was Kea statically linked?])])
2010-08-13 23:22:54 +00:00
2010-09-20 03:20:56 +00:00
# Check validity about some libtool options
if test $enable_static_link = yes -a $enable_static = no; then
AC_MSG_ERROR([--enable-static-link requires --enable-static])
fi
2015-09-19 13:25:24 +02:00
if test $enable_static_link = no -a $enable_shared = no; then
AC_MSG_ERROR([--disable-static-link requires --enable-shared])
2010-09-20 03:20:56 +00:00
fi
2010-08-18 20:51:43 +00:00
# OS dependent configuration
2014-08-12 13:03:33 +02:00
kea_undefined_pthread_behavior=no
2010-08-18 20:51:43 +00:00
2010-06-23 06:25:14 +00:00
case "$host" in
2010-06-24 01:00:15 +00:00
*-solaris*)
# Solaris requires special definitions to get some standard libraries
# (e.g. getopt(3)) available with common used header files.
CPPFLAGS="$CPPFLAGS -D_XPG4_2 -D__EXTENSIONS__"
2011-11-29 08:38:52 -05:00
# "now" binding is necessary to prevent deadlocks in C++ static initialization code
LDFLAGS="$LDFLAGS -z now"
2012-10-26 08:44:57 +05:30
# Destroying locked mutexes, condition variables being waited
# on, etc. are undefined behavior on Solaris, so we set it as
# such here.
2014-08-12 13:03:33 +02:00
kea_undefined_pthread_behavior=yes
2010-06-24 01:00:15 +00:00
;;
2010-08-18 20:51:43 +00:00
*-apple-darwin*)
2012-02-21 09:22:15 -08:00
# Starting with OSX 10.7 (Lion) we must choose which IPv6 API to use
# (RFC2292 or RFC3542).
CPPFLAGS="$CPPFLAGS -D__APPLE_USE_RFC_3542"
2013-10-28 00:09:54 -07:00
# In OS X 10.9 (and possibly any future versions?) pthread_cond_destroy
# doesn't work as documented, which makes some of unit tests fail.
2015-02-27 14:36:24 +01:00
AC_MSG_CHECKING([OS X versions where destroying locked locks do not fail])
AC_TRY_COMPILE(
[#include <Availability.h>],
[#ifdef __MAC_OS_X_VERSION_MIN_REQUIRED
#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090
#error " OS X >= 10.9"
#endif
#endif
return 1;],
[AC_MSG_RESULT([OS X < 10.9])],
[AC_MSG_RESULT([OS X >= 10.9])
kea_undefined_pthread_behavior=yes])
2010-08-18 20:51:43 +00:00
;;
2011-11-11 15:56:54 +01:00
*-freebsd*)
2015-03-02 18:43:13 +01:00
# On FreeBSD10.1 pthread_cond_destroy doesn't work as documented, which
# causes the CondVarTest.destroyWhileWait test to fail. According to the
# pthread_cond_destroy documentation for FreeBSD, this function should
# return EBUSY error when there is a thread waiting for the conditional
# variable, whereas this function returned success code. We treat it here
# as an undefined behavior. Also note that this issue was only visible
# when gtest 1.7 was in use, because the previous versions of gtest
# didn't seem to have support for the death tests on FreeBSD. As a
# result, the test was not executed and the error didn't occur.
kea_undefined_pthread_behavior=yes
2012-03-22 15:56:23 +05:30
;;
2010-06-23 06:25:14 +00:00
esac
2014-08-12 13:03:33 +02:00
if [ test $kea_undefined_pthread_behavior = "yes" ]; then
2013-10-28 00:09:54 -07:00
AC_DEFINE([HAS_UNDEFINED_PTHREAD_BEHAVIOR], [1], [Does this platform have some undefined pthreads behavior?])
fi
2010-03-08 07:58:25 +00:00
2013-02-01 14:43:54 -08:00
# Our experiments have shown Solaris 10 has broken support for the
# IPV6_USE_MIN_MTU socket option for getsockopt(); it doesn't return the value
# previously set via setsockopt(). We know it doesn't happen on one instance
# on Solaris 11, but we don't know whether it happens for any Solaris 10
# implementations or for earlier versions of Solaris. In any case, at the
# moment this matters for only one unittest case, so we'll simply disable
# the affected test using the following definition with the specific hardcoding
# of that version of Solaris.
case "$host" in
*-solaris2.10)
AC_DEFINE([HAVE_BROKEN_GET_IPV6_USE_MIN_MTU], [1],
[Define to 1 if getsockopt(IPV6_USE_MIN_MTU) does not work])
;;
esac
2014-05-10 07:32:21 -07:00
m4_define([_AM_PYTHON_INTERPRETER_LIST], [python python3.4 python3.3 python3.2 python3.1 python3])
2010-03-14 20:45:07 +00:00
AC_ARG_WITH([pythonpath],
AC_HELP_STRING([--with-pythonpath=PATH],
2010-03-17 23:40:59 +00:00
[specify an absolute path to python executable when automatic version check (incorrectly) fails]),
2010-03-14 20:45:07 +00:00
[python_path="$withval"], [python_path="auto"])
if test "$python_path" = auto; then
2014-06-25 15:00:26 +02:00
AM_PATH_PYTHON([3.1],,[PYTHON=no])
2010-03-14 20:45:07 +00:00
else
2010-03-21 02:36:03 +00:00
# Older versions of automake can't handle python3 well. This is an
# in-house workaround for them.
2010-03-14 20:45:07 +00:00
PYTHON=$python_path
AC_SUBST(PYTHON)
2010-03-17 23:16:56 +00:00
PYTHON_PREFIX='${prefix}'
AC_SUBST(PYTHON_PREFIX)
PYTHON_EXEC_PREFIX='$(exec_prefix)'
AC_SUBST(PYTHON_EXEC_PREFIX)
2010-03-21 02:36:03 +00:00
PYTHON_VERSION=[`$PYTHON -c "import sys; sys.stdout.write(sys.version[:3])"`]
if test `echo "$PYTHON_VERSION >= 3.1" | bc` != 1 ; then
AC_MSG_ERROR(["Python version too old: $PYTHON_VERSION, need 3.1 or higher"])
fi
2010-03-17 23:40:59 +00:00
AC_SUBST(PYTHON_VERSION)
PYTHON_PLATFORM=`$PYTHON -c "import sys; print(sys.platform)"`
2010-03-17 23:16:56 +00:00
AC_SUBST(PYTHON_PLATFORM)
2010-03-21 02:36:03 +00:00
pythondir='${prefix}/lib/python'$PYTHON_VERSION'/site-packages'
2010-03-17 23:16:56 +00:00
AC_SUBST(pythondir)
2010-03-19 02:15:46 +00:00
pkgpythondir='${pythondir}/'$PACKAGE
2010-03-17 23:16:56 +00:00
AC_SUBST(pkgpythondir)
2010-03-21 02:36:03 +00:00
pyexecdir='${exec_prefix}/lib/python'$PYTHON_VERSION'/site-packages'
2010-03-17 23:16:56 +00:00
AC_SUBST(pyexecdir)
2010-03-19 02:15:46 +00:00
pkgpyexecdir='${pyexecdir}/'$PACKAGE
2010-03-17 23:16:56 +00:00
AC_SUBST(pkgpyexecdir)
2010-03-14 20:45:07 +00:00
fi
2009-12-03 08:21:01 +00:00
2010-01-26 22:15:42 +00:00
# produce PIC unless we disable shared libraries. need this for python bindings.
2010-06-23 06:25:14 +00:00
if test $enable_shared != "no" -a "X$GXX" = "Xyes"; then
2014-08-12 13:11:38 +02:00
KEA_CXXFLAGS="$KEA_CXXFLAGS -fPIC"
2010-01-26 22:15:42 +00:00
fi
2014-08-12 13:11:38 +02:00
AC_SUBST(KEA_CXXFLAGS)
2010-05-28 00:42:50 +00:00
2009-10-16 06:20:23 +00:00
# Checks for libraries.
2010-02-10 19:11:57 +00:00
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
2011-03-01 04:21:47 +00:00
AC_SEARCH_LIBS(nanosleep, [rt])
2013-07-09 14:11:30 +01:00
AC_SEARCH_LIBS(dlsym, [dl])
2010-02-10 19:11:57 +00:00
2009-10-16 06:20:23 +00:00
# Checks for header files.
# Checks for typedefs, structures, and compiler characteristics.
AC_HEADER_STDBOOL
AC_TYPE_SIZE_T
2010-05-31 19:29:15 +00:00
2011-11-30 17:00:42 +01:00
# Detect OS type (it may be used to do OS-specific things, e.g.
# interface detection in DHCP)
2015-02-27 14:36:24 +01:00
AC_MSG_CHECKING(OS type)
2015-02-27 17:28:21 +01:00
BSD_TYPE="notaBSD"
2015-02-27 14:36:24 +01:00
case $host in
*-linux*)
AC_DEFINE([OS_LINUX], [1], [Running on Linux?])
2011-12-16 18:45:13 +01:00
OS_TYPE="Linux"
2011-11-30 17:00:42 +01:00
CPPFLAGS="$CPPFLAGS -DOS_LINUX"
;;
2015-02-27 14:36:24 +01:00
*-apple-darwin*)
AC_DEFINE([OS_BSD], [1], [Running on BSD?])
AC_DEFINE([OS_OSX], [1], [Running on OSX?])
OS_TYPE="BSD"
BSD_TYPE="OSX"
CPPFLAGS="$CPPFLAGS -DOS_BSD"
;;
*-freebsd*)
AC_DEFINE([OS_BSD], [1], [Running on BSD?])
AC_DEFINE([OS_FREEBSD], [1], [Running on FreeBSD?])
OS_TYPE="BSD"
BSD_TYPE="FreeBSD"
CPPFLAGS="$CPPFLAGS -DOS_BSD"
;;
*-netbsd*)
AC_DEFINE([OS_BSD], [1], [Running on BSD?])
AC_DEFINE([OS_NETBSD], [1], [Running on NetBSD?])
OS_TYPE="BSD"
BSD_TYPE="NetBSD"
CPPFLAGS="$CPPFLAGS -DOS_BSD"
;;
*-openbsd*)
AC_DEFINE([OS_BSD], [1], [Running on BSD?])
AC_DEFINE([OS_OPENBSD], [1], [Running on OpenBSD?])
2011-11-30 17:00:42 +01:00
OS_TYPE="BSD"
2015-02-27 14:36:24 +01:00
BSD_TYPE="OpenBSD"
2011-11-30 17:00:42 +01:00
CPPFLAGS="$CPPFLAGS -DOS_BSD"
;;
2015-02-27 14:36:24 +01:00
*-solaris*)
AC_DEFINE([OS_SOLARIS], [1], [Running on Solaris?])
2011-11-30 17:00:42 +01:00
OS_TYPE="Solaris"
2012-05-10 18:48:50 +02:00
CPPFLAGS="$CPPFLAGS -DOS_SUN"
2011-11-30 17:00:42 +01:00
;;
*)
OS_TYPE="Unknown"
2015-02-27 14:36:24 +01:00
# $host_os is more user friendly than full $host
AC_MSG_WARN("Unsupported OS: $host_os")
2011-11-30 17:00:42 +01:00
;;
esac
AC_MSG_RESULT($OS_TYPE)
2011-12-16 18:45:13 +01:00
AM_CONDITIONAL(OS_LINUX, test $OS_TYPE = Linux)
2011-11-30 17:00:42 +01:00
AM_CONDITIONAL(OS_BSD, test $OS_TYPE = BSD)
AM_CONDITIONAL(OS_SOLARIS, test $OS_TYPE = Solaris)
2015-02-27 14:36:24 +01:00
AM_CONDITIONAL(OS_OSX, test $BSD_TYPE = OSX)
AM_CONDITIONAL(OS_FREEBSD, test $BSD_TYPE = FreeBSD)
AM_CONDITIONAL(OS_NETBSD, test $BSD_TYPE = NetBSD)
AM_CONDITIONAL(OS_OPENBSD, test $BSD_TYPE = OpenBSD)
2013-07-10 00:43:01 +01:00
2009-10-30 17:47:35 +00:00
AC_MSG_CHECKING(for sa_len in struct sockaddr)
AC_TRY_COMPILE([
#include <sys/types.h>
#include <sys/socket.h>],
[struct sockaddr sa; sa.sa_len = 0; return (0);],
[AC_MSG_RESULT(yes)
2010-05-31 19:29:15 +00:00
AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
2009-10-30 17:47:35 +00:00
AC_MSG_RESULT(no))
2012-07-05 21:48:16 -05:00
enable_gtest="no"
2012-07-06 16:03:09 -05:00
GTEST_INCLUDES=
2012-07-05 21:48:16 -05:00
AC_ARG_WITH([gtest-source],
[AS_HELP_STRING([--with-gtest-source=PATH],
2014-10-28 17:24:16 +01:00
[location of the Googletest source])],
[enable_gtest="yes" ; GTEST_SOURCE="$withval"])
2012-07-05 21:48:16 -05:00
AC_ARG_WITH([gtest],
[AS_HELP_STRING([--with-gtest=PATH],
[specify a path to gtest header files (PATH/include) and library (PATH/lib)])],
[gtest_path="$withval"; enable_gtest="yes"], [gtest_path="no"])
2009-12-29 16:07:20 +00:00
AC_ARG_WITH(lcov,
2009-12-31 18:13:15 +00:00
[ --with-lcov[=PROGRAM] enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
2009-12-29 16:07:20 +00:00
USE_LCOV="no"
if test "$lcov" != "no"; then
# force gtest if not set
2012-07-05 21:48:16 -05:00
if test "$enable_gtest" = "no"; then
2010-01-26 19:41:22 +00:00
# AC_MSG_ERROR("lcov needs gtest for test coverage report")
AC_MSG_NOTICE([gtest support is now enabled, because used by coverage tests])
2012-07-05 21:48:16 -05:00
enable_gtest="yes"
2009-12-29 16:07:20 +00:00
fi
if test "$lcov" != "yes"; then
2010-01-26 19:41:22 +00:00
LCOV=$lcov
2009-12-29 16:07:20 +00:00
else
2010-01-26 19:41:22 +00:00
AC_PATH_PROG([LCOV], [lcov])
2009-12-29 16:07:20 +00:00
fi
2010-01-26 19:41:22 +00:00
if test -x "${LCOV}"; then
USE_LCOV="yes"
else
AC_MSG_ERROR([Cannot find lcov.])
2009-12-29 16:07:20 +00:00
fi
# is genhtml always in the same directory?
2013-03-19 12:39:37 +01:00
GENHTML=`echo "$LCOV" | ${SED} s/lcov$/genhtml/`
2009-12-29 16:07:20 +00:00
if test ! -x $GENHTML; then
AC_MSG_ERROR([genhtml not found, needed for lcov])
fi
2009-12-31 18:13:15 +00:00
# GCC specific?
2010-01-26 19:41:22 +00:00
CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
2009-12-31 18:13:15 +00:00
LIBS=" $LIBS -lgcov"
2009-12-29 16:07:20 +00:00
AC_SUBST(CPPFLAGS)
AC_SUBST(LIBS)
AC_SUBST(LCOV)
AC_SUBST(GENHTML)
fi
AC_SUBST(USE_LCOV)
2012-03-12 19:32:42 +01:00
# Simplified, non-caching AC_CHECK_PROG
# Searches $PATH for the existence of argument 2,
# and sets the full path to the variable in argument 1.
# if not found, and a third argument is given, the value
2012-03-15 11:24:07 +01:00
# is set to that. If not, the value is untouched.
# Does not take absolute paths into account at this point,
2012-03-12 19:32:42 +01:00
# and also works for single files only (arguments are not
# stripped like in AC_CHECK_PROG)
AC_DEFUN([ACX_CHECK_PROG_NONCACHE], [
RESULT=""
IFS_SAVED="$IFS"
2012-03-15 11:24:07 +01:00
IFS=${PATH_SEPARATOR}
2012-03-12 19:32:42 +01:00
for cur_path in ${PATH} ; do
if test -e "${cur_path}/$2" ; then
RESULT="${cur_path}/$2"
fi
done
if test "$RESULT" = "" ; then
2012-03-15 11:24:07 +01:00
:
2012-03-12 19:32:42 +01:00
m4_ifvaln([$3], [$1=$3])
else
$1=$RESULT
fi
IFS="$IFS_SAVED"
])
2014-06-30 15:26:38 +02:00
# Avoid checking Botan if OpenSSL is wanted
AC_ARG_WITH([openssl],
[AS_HELP_STRING([--with-openssl[[=PATH]]], [Enables OpenSSL,
location can be specified optionally])],
[use_openssl="$withval"],
[use_openssl="auto"])
2012-03-12 19:32:42 +01:00
# Botan helper test function
2012-03-15 11:24:07 +01:00
# Tries to compile a botan program, given the output of the given
# config tool
2012-03-12 19:32:42 +01:00
# Arguments:
# - name of tool (checked for path), must support --libs and --cflags
# - fixed argument(s) for tool
# - action if successful
AC_DEFUN([ACX_TRY_BOTAN_TOOL], [
TOOL=$1
TOOL_ARG=$2
BOTAN_TOOL=""
2012-03-15 11:24:07 +01:00
ACX_CHECK_PROG_NONCACHE([BOTAN_TOOL], [${TOOL}])
AC_MSG_CHECKING([usability of ${TOOL} ${TOOL_ARG}])
2012-03-12 19:32:42 +01:00
if test "$BOTAN_TOOL" != "" ; then
if test -x ${BOTAN_TOOL}; then
2014-06-30 15:26:38 +02:00
CRYPTO_LIBS=`$BOTAN_TOOL $TOOL_ARG --libs`
2012-03-12 19:32:42 +01:00
LIBS_SAVED=${LIBS}
2014-06-30 15:26:38 +02:00
LIBS="$LIBS $CRYPTO_LIBS"
CRYPTO_INCLUDES=`$BOTAN_TOOL $TOOL_ARG --cflags`
2012-03-12 19:32:42 +01:00
CPPFLAGS_SAVED=${CPPFLAGS}
2014-06-30 15:26:38 +02:00
CPPFLAGS="$CRYPTO_INCLUDES $CPPFLAGS"
2012-03-12 19:32:42 +01:00
#AC_MSG_RESULT([found])
AC_LINK_IFELSE(
[AC_LANG_PROGRAM([#include <botan/botan.h>
#include <botan/hash.h>
],
[using namespace Botan;
LibraryInitializer::initialize();
HashFunction *h = get_hash("MD5");
])],
[ AC_MSG_RESULT([ok])
$3
],
2012-03-15 11:24:07 +01:00
[ AC_MSG_RESULT([not usable]) ]
2012-03-12 19:32:42 +01:00
)
LIBS=${LIBS_SAVED}
CPPFLAGS=${CPPFLAGS_SAVED}
else
AC_MSG_RESULT([not executable])
fi
else
AC_MSG_RESULT([not found])
fi
BOTAN_TOOL=""
AC_SUBST(BOTAN_TOOL)
]
)
2011-04-08 15:49:22 +02:00
# Check for Botan
2012-03-15 11:24:07 +01:00
#
# Unless --with-botan-config is given, we first try to find these config
# scripts ourselves. Unfortunately, on some systems, these scripts do not
# provide the correct implementation, so for each script found, we try
# a compilation test (ACX_TRY_BOTAN_TOOL). If none are found, or none of
# them work, we see if pkg-config is available. If so, we try the several
# potential pkg-config .pc files. Again, on some systems, these can return
# incorrect information as well, so the try-compile test is repeated for
# each.
#
# If a working config script or pkgconfig file is found, we then munge its
# output for use in our Makefiles, and to make sure it works, another header
# and compilation test is done (this should also check whether we can compile
# against botan should neither -config scripts nor pkgconfig data exist).
#
2012-03-05 15:49:03 +01:00
botan_config="yes"
2014-06-30 15:26:38 +02:00
if test "${use_openssl}" != "auto" -a "${use_openssl}" != "no" ; then
botan_config="no"
fi
2012-03-05 15:49:03 +01:00
AC_ARG_WITH([botan-config],
AC_HELP_STRING([--with-botan-config=PATH],
[specify the path to the botan-config script]),
[botan_config="$withval"])
if test "${botan_config}" = "no" ; then
2014-06-30 15:26:38 +02:00
if test "${use_openssl}" = "no" ; then
AC_MSG_ERROR([Need Botan or OpenSSL for libcryptolink])
fi
elif test "${botan_config}" != "yes" ; then
2012-03-05 15:49:03 +01:00
if test -x "${botan_config}" ; then
if test -d "${botan_config}" ; then
AC_MSG_ERROR([${botan_config} is a directory])
else
BOTAN_CONFIG="${botan_config}"
fi
2011-04-28 21:34:55 +00:00
else
2012-03-15 11:24:07 +01:00
AC_MSG_ERROR([--with-botan-config should point to a botan-config program and not a directory (${botan_config})])
2011-04-28 21:34:55 +00:00
fi
else
2011-10-27 17:55:06 +02:00
BOTAN_CONFIG=""
2012-03-09 21:59:59 +01:00
# first try several possible names of the config script
2012-03-15 11:24:07 +01:00
# (botan-config-1.8 is there just in case, the official name change
# came later)
2012-03-09 21:59:59 +01:00
BOTAN_CONFIG_VERSIONS="botan-config-1.10 botan-config-1.9 botan-config-1.8 botan-config"
for botan_config in $BOTAN_CONFIG_VERSIONS; do
2012-03-12 19:32:42 +01:00
ACX_TRY_BOTAN_TOOL([$botan_config],,
2012-03-15 11:24:07 +01:00
[ BOTAN_CONFIG="$botan_config" ]
2012-03-12 19:32:42 +01:00
)
if test "$BOTAN_CONFIG" != "" ; then
2012-03-09 21:59:59 +01:00
break
fi
done
2011-10-27 17:55:06 +02:00
if test "$BOTAN_CONFIG" = "" ; then
2012-03-09 21:59:59 +01:00
AC_PATH_PROG([PKG_CONFIG], [pkg-config])
if test "$PKG_CONFIG" != "" ; then
# Ok so no script found, see if pkg-config knows of it.
# Unfortunately, the botan.pc files also have their minor version
# in their name, so we need to try them one by one
BOTAN_VERSIONS="botan-1.10 botan-1.9 botan-1.8"
for version in $BOTAN_VERSIONS; do
2012-03-12 19:32:42 +01:00
ACX_TRY_BOTAN_TOOL([pkg-config], ["$version --silence-errors"],
2012-03-15 11:24:07 +01:00
[ BOTAN_CONFIG="$PKG_CONFIG $version" ]
2012-03-12 19:32:42 +01:00
)
if test "$BOTAN_CONFIG" != "" ; then
2011-10-27 17:55:06 +02:00
break
fi
2012-03-09 21:59:59 +01:00
done
fi
2011-10-27 17:55:06 +02:00
fi
2011-04-28 21:34:55 +00:00
fi
2012-03-12 19:32:42 +01:00
2012-02-16 11:48:39 +01:00
if test "x${BOTAN_CONFIG}" != "x"
then
2014-06-30 15:26:38 +02:00
CRYPTO_LIBS=`${BOTAN_CONFIG} --libs`
CRYPTO_INCLUDES=`${BOTAN_CONFIG} --cflags`
2012-02-16 11:48:39 +01:00
# We expect botan-config --libs to contain -L<path_to_libbotan>, but
# this is not always the case. As a heuristics workaround we add
# -L`botan-config --prefix/lib` in this case (if not present already).
2014-06-30 15:26:38 +02:00
# Same for CRYPTO_INCLUDES (but using include instead of lib) below.
2012-02-16 11:48:39 +01:00
if [ ${BOTAN_CONFIG} --prefix >/dev/null 2>&1 ] ; then
2014-06-30 15:26:38 +02:00
echo ${CRYPTO_LIBS} | grep -- -L > /dev/null || \
CRYPTO_LIBS="-L`${BOTAN_CONFIG} --prefix`/lib ${CRYPTO_LIBS}"
echo ${CRYPTO_INCLUDES} | grep -- -I > /dev/null || \
CRYPTO_INCLUDES="-I`${BOTAN_CONFIG} --prefix`/include ${CRYPTO_INCLUDES}"
2012-02-16 11:48:39 +01:00
fi
2011-04-08 15:49:22 +02:00
fi
2013-09-12 15:45:08 +02:00
2014-06-30 15:26:38 +02:00
if test "x${CRYPTO_LIBS}" != "x"
then
dnl Determine the Botan version
AC_MSG_CHECKING([Botan version])
cat > conftest.cpp << EOF
2013-09-12 15:45:08 +02:00
#include <botan/version.h>
AUTOCONF_BOTAN_VERSION=BOTAN_VERSION_MAJOR . BOTAN_VERSION_MINOR . BOTAN_VERSION_PATCH
EOF
2014-06-30 15:26:38 +02:00
CRYPTO_VERSION=`$CPP $CPPFLAGS $CRYPTO_INCLUDES conftest.cpp | grep '^AUTOCONF_BOTAN_VERSION=' | $SED -e 's/^AUTOCONF_BOTAN_VERSION=//' -e 's/[[ ]]//g' -e 's/"//g' 2> /dev/null`
if test -z "$CRYPTO_VERSION"; then
CRYPTO_VERSION="unknown"
fi
$RM -f conftest.cpp
AC_MSG_RESULT([$CRYPTO_VERSION])
# botan-config script (and the way we call pkg-config) returns -L and -l
# as one string, but we need them in separate values
CRYPTO_LDFLAGS=
for flag in ${CRYPTO_LIBS}; do
CRYPTO_LDFLAGS="${CRYPTO_LDFLAGS} `echo $flag | ${SED} -ne '/^\(\-L\)/p'`"
CRYPTO_LIBS="${CRYPTO_LIBS} `echo $flag | ${SED} -ne '/^\(\-l\)/p'`"
done
# See crypto_rpath for some info on why we do this
if test "x$ISC_RPATH_FLAG" != "x"; then
CRYPTO_RPATH=
for flag in ${CRYPTO_LIBS}; do
CRYPTO_RPATH="${CRYPTO_RPATH} `echo $flag | ${SED} -ne "s/^\(\-L\)/${ISC_RPATH_FLAG}/p"`"
done
# According to the libtool manual, it should be sufficient if we
# specify the "-R libdir" in our wrapper library of botan (no other
# programs will need libbotan directly); "libdir" should be added to
# the program's binary image. But we've seen in our build environments
# that (some versions of?) libtool doesn't propagate -R as documented,
# and it caused a linker error at run time. To work around this, we
# also add the rpath to the global LDFLAGS.
LDFLAGS="$CRYPTO_RPATH $LDFLAGS"
fi
# Even though chances are high we already performed a real compilation check
# in the search for the right (pkg)config data, we try again here, to
# be sure.
CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$CRYPTO_INCLUDES $CPPFLAGS"
LIBS_SAVED="$LIBS"
LIBS="$LIBS $CRYPTO_LIBS"
# ac_header_preproc is an autoconf symbol (undocumented but stable) that
# is set if the pre-processor phase passes. Thus by adding a custom
# failure handler we can detect the difference between a header not existing
# (or not even passing the pre-processor phase) and a header file resulting
# in compilation failures.
AC_CHECK_HEADERS([botan/botan.h],,[
CRYPTO_INCLUDES=""
CRYPTO_LIBS=""
CRYPTO_LDFLAGS=""
CRYPTO_RPATH=""
2013-11-14 10:02:35 +02:00
if test "x$ac_header_preproc" = "xyes"; then
2014-06-30 15:26:38 +02:00
AC_MSG_RESULT([
2013-09-17 13:56:12 +02:00
botan/botan.h was found but is unusable. The most common cause of this problem
is attempting to use an updated C++ compiler with older C++ libraries, such as
the version of Botan that comes with your distribution. If you have updated
your C++ compiler we highly recommend that you use support libraries such as
Boost and Botan that were compiled with the same compiler version.])
2013-11-14 10:02:35 +02:00
else
2014-06-30 15:26:38 +02:00
AC_MSG_RESULT([Missing required header files.])
2013-11-14 10:02:35 +02:00
fi]
2014-06-30 15:26:38 +02:00
)
CPPFLAGS=$CPPFLAGS_SAVED
LIBS=$LIBS_SAVED
fi
if test "x${CRYPTO_LIBS}" != "x"
then
CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$CRYPTO_INCLUDES $CPPFLAGS"
LIBS_SAVED="$LIBS"
LIBS="$LIBS $CRYPTO_LIBS"
AC_LINK_IFELSE(
2011-04-28 13:04:44 +00:00
[AC_LANG_PROGRAM([#include <botan/botan.h>
#include <botan/hash.h>
],
2011-04-08 15:49:22 +02:00
[using namespace Botan;
LibraryInitializer::initialize();
2011-04-28 13:04:44 +00:00
HashFunction *h = get_hash("MD5");
2011-04-08 15:49:22 +02:00
])],
[AC_MSG_RESULT([checking for Botan library... yes])],
[AC_MSG_RESULT([checking for Botan library... no])
2014-06-30 15:26:38 +02:00
CRYPTO_INCLUDES=""
CRYPTO_LIBS=""
CRYPTO_LDFLAGS=""
CRYPTO_RPATH=""
AC_MSG_RESULT([Needs Botan library 1.8 or higher. On some systems,
2012-03-05 15:49:03 +01:00
the botan package has a few missing dependencies (libbz2 and
2014-06-30 15:26:38 +02:00
libgmp), if libbotan has been installed and you see this message,
2012-03-05 15:49:03 +01:00
try upgrading to a higher version of botan or installing libbz2
and libgmp.])]
2014-06-30 15:26:38 +02:00
)
CPPFLAGS=$CPPFLAGS_SAVED
LIBS=$LIBS_SAVED
fi
if test "x${CRYPTO_LIBS}" != "x"
then
CRYPTO_NAME="Botan"
DISABLED_CRYPTO="OpenSSL"
CRYPTO_PACKAGE="botan-1.8"
CRYPTO_CFLAGS=""
DISTCHECK_CRYPTO_CONFIGURE_FLAG="--with-botan=$botan_config"
AC_DEFINE_UNQUOTED([WITH_BOTAN], [], [Compile with Botan crypto])
else
CRYPTO_NAME="OpenSSL"
DISABLED_CRYPTO="Botan"
CRYPTO_PACKAGE="openssl-1.0.0"
AC_DEFINE_UNQUOTED([WITH_OPENSSL], [], [Compile with OpenSSL crypto])
AC_MSG_CHECKING(for OpenSSL library)
# from bind9
if test "${use_openssl}" = "auto" ; then
use_openssl="yes"
fi
if test "${use_openssl}" = "yes" ; then
for d in /usr /usr/local /usr/local/ssl /usr/pkg /usr/sfw; do
if test -f $d/include/openssl/opensslv.h; then
use_openssl=$d; break
fi
done
fi
if test "${use_openssl}" = "yes" ; then
AC_MSG_ERROR([OpenSSL auto detection failed])
fi
if ! test -f "${use_openssl}"/include/openssl/opensslv.h ; then
AC_MSG_ERROR([OpenSSL not found at ${use_openssl}])
fi
AC_MSG_RESULT(yes)
if test "${use_openssl}" = "/usr" ; then
CRYPTO_INCLUDES=""
CRYPTO_LIBS="-lcrypto"
DISTCHECK_CRYPTO_CONFIGURE_FLAG="--with-openssl"
case "$host" in
*-apple-darwin*)
# Starting with OSX 10.7 (Lion) OpenSSL is deprecated
CRYPTO_CFLAGS="-Wno-deprecated-declarations"
;;
*)
CRYPTO_CFLAGS=""
;;
esac
else
CRYPTO_CFLAGS=""
CRYPTO_INCLUDES="-I${use_openssl}/include"
DISTCHECK_CRYPTO_CONFIGURE_FLAG="--with-openssl=${use_openssl}"
case $host in
*-solaris*)
CRYPTO_LIBS="-L${use_openssl}/lib -R${use_openssl}/lib -lcrypto"
;;
*-hp-hpux*)
CRYPTO_LIBS="-L${use_openssl}/lib -Wl,+b: -lcrypto"
;;
*-apple-darwin*)
if test -f "${use_openssl}/lib/libcrypto.dylib" ; then
CRYPTO_LIBS="-L${use_openssl}/lib -lcrypto"
else
CRYPTO_LIBS="${use_openssl}/lib/libcrypto.a"
fi
;;
*)
CRYPTO_LIBS="-L${use_openssl}/lib -lcrypto"
;;
esac
fi
dnl Determine the OpenSSL version
AC_MSG_CHECKING([OpenSSL version])
cat > conftest.cpp << EOF
#include <openssl/opensslv.h>
AUTOCONF_OPENSSL_VERSION=OPENSSL_VERSION_TEXT
EOF
CRYPTO_VERSION=`$CPP $CPPFLAGS $CRYPTO_INCLUDES conftest.cpp | grep '^AUTOCONF_OPENSSL_VERSION=' | $SED -e 's/^AUTOCONF_OPENSSL_VERSION=//' -e 's/"//g' 2> /dev/null`
if test -z "$CRYPTO_VERSION" ; then
CRYPTO_VERSION="unknown"
fi
$RM -f conftest.cpp
AC_MSG_RESULT([$CRYPTO_VERSION])
#CRYPTO_LDFLAGS="-ldl"
CRYPTO_LDFLAGS=""
CRYPTO_RPATH=""
2014-09-17 11:31:49 +02:00
dnl Check avaibility of SHA-2
AC_MSG_CHECKING([support of SHA-2])
LIBS_SAVED=${LIBS}
LIBS="$LIBS $CRYPTO_LIBS"
CPPFLAGS_SAVED=${CPPFLAGS}
CPPFLAGS="$CRYPTO_INCLUDES $CPPFLAGS"
AC_LINK_IFELSE(
[AC_LANG_PROGRAM([#include <openssl/evp.h>],
[const EVP_MD* h224 = EVP_sha224();
const EVP_MD* h256 = EVP_sha256();
const EVP_MD* h384 = EVP_sha384();
const EVP_MD* h512 = EVP_sha512();
])],
[AC_MSG_RESULT([yes])],
[AC_MSG_ERROR([missing EVP entry for SHA-2])])
LIBS=${LIBS_SAVED}
CPPFLAGS=${CPPFLAGS_SAVED}
2014-06-30 15:26:38 +02:00
fi
AM_CONDITIONAL(HAVE_BOTAN, test "$CRYPTO_NAME" = "Botan")
AM_CONDITIONAL(HAVE_OPENSSL, test "$CRYPTO_NAME" = "OpenSSL")
AC_SUBST(CRYPTO_INCLUDES)
AC_SUBST(CRYPTO_CFLAGS)
AC_SUBST(CRYPTO_LIBS)
AC_SUBST(CRYPTO_LDFLAGS)
AC_SUBST(CRYPTO_PACKAGE)
AC_SUBST(CRYPTO_RPATH)
AC_SUBST(DISTCHECK_CRYPTO_CONFIGURE_FLAG)
2012-10-22 20:05:35 +01:00
# Check for MySql. The path to the mysql_config program is given with
2012-10-22 21:28:41 +01:00
# the --with-mysql-config (default to /usr/bin/mysql-config). By default,
# the software is not built with MySQL support enabled.
2012-10-22 20:05:35 +01:00
mysql_config="no"
2012-10-24 14:12:06 +01:00
AC_ARG_WITH([dhcp-mysql],
AC_HELP_STRING([--with-dhcp-mysql=PATH],
[path to the MySQL 'mysql_config' script (MySQL is used for the DHCP database)]),
2012-10-22 20:05:35 +01:00
[mysql_config="$withval"])
if test "${mysql_config}" = "yes" ; then
MYSQL_CONFIG="/usr/bin/mysql_config"
elif test "${mysql_config}" != "no" ; then
MYSQL_CONFIG="${withval}"
fi
if test "$MYSQL_CONFIG" != "" ; then
2012-10-24 14:12:06 +01:00
if test -d "$MYSQL_CONFIG" -o ! -x "$MYSQL_CONFIG" ; then
AC_MSG_ERROR([--with-dhcp-mysql should point to a mysql_config program])
2012-10-22 20:05:35 +01:00
fi
MYSQL_CPPFLAGS=`$MYSQL_CONFIG --cflags`
MYSQL_LIBS=`$MYSQL_CONFIG --libs`
2013-09-10 11:33:32 +02:00
MYSQL_VERSION=`$MYSQL_CONFIG --version`
2012-10-22 20:05:35 +01:00
AC_SUBST(MYSQL_CPPFLAGS)
AC_SUBST(MYSQL_LIBS)
# Check that a simple program using MySQL functions can compile and link.
CPPFLAGS_SAVED="$CPPFLAGS"
LIBS_SAVED="$LIBS"
CPPFLAGS="$MYSQL_CPPFLAGS $CPPFLAGS"
LIBS="$MYSQL_LIBS $LIBS"
AC_LINK_IFELSE(
2012-11-14 07:33:55 -06:00
[AC_LANG_PROGRAM([#include <mysql.h>],
2012-10-22 20:05:35 +01:00
[MYSQL mysql_handle;
(void) mysql_init(&mysql_handle);
])],
[AC_MSG_RESULT([checking for MySQL headers and library... yes])],
[AC_MSG_RESULT([checking for MySQL headers and library... no])
AC_MSG_ERROR([Needs MySQL library])]
)
CPPFLAGS=$CPPFLAGS_SAVED
LIBS=$LIBS_SAVED
# Note that MYSQL is present in the config.h file
AC_DEFINE([HAVE_MYSQL], [1], [MySQL is present])
fi
2014-02-25 15:54:02 -05:00
# Solaris puts FIONREAD in filio.h
2014-04-25 13:44:55 -04:00
AC_CHECK_HEADERS(sys/filio.h,,,)
2014-02-25 15:54:02 -05:00
2012-10-22 20:05:35 +01:00
# ... and at the shell level, so Makefile.am can take action depending on this.
AM_CONDITIONAL(HAVE_MYSQL, test "$MYSQL_CONFIG" != "")
2014-03-11 15:42:26 +01:00
pg_config="no"
AC_ARG_WITH([dhcp-pgsql],
AC_HELP_STRING([--with-dhcp-pgsql=PATH],
[path to the PostgreSQL 'pg_config' script]),
[pg_config="$withval"])
if test "${pg_config}" = "yes" ; then
PG_CONFIG="/usr/bin/pg_config"
elif test "${pg_config}" != "no" ; then
PG_CONFIG="${withval}"
fi
if test "$PG_CONFIG" != "" ; then
if test -d "$PG_CONFIG" -o ! -x "$PG_CONFIG" ; then
AC_MSG_ERROR([--with-dhcp-pgsql should point to a pg_config program])
fi
PGSQL_CPPFLAGS=`$PG_CONFIG --cppflags`
PGSQL_INCLUDEDIR=`$PG_CONFIG --includedir`
2014-05-19 16:49:11 +02:00
PGSQL_INCLUDEDIR_SERVER=`$PG_CONFIG --includedir-server`
PGSQL_CPPFLAGS="$PGSQL_CPPFLAGS -I$PGSQL_INCLUDEDIR -I$PGSQL_INCLUDEDIR_SERVER"
2014-03-28 07:17:51 -04:00
PGSQL_LIBS=`$PG_CONFIG --libdir`
PGSQL_LIBS="-L$PGSQL_LIBS -lpq"
2014-03-11 15:42:26 +01:00
PGSQL_VERSION=`$PG_CONFIG --version`
AC_SUBST(PGSQL_CPPFLAGS)
AC_SUBST(PGSQL_LIBS)
# Check that a simple program using PostgreSQL functions can compile and link.
CPPFLAGS_SAVED="$CPPFLAGS"
LIBS_SAVED="$LIBS"
CPPFLAGS="$PGSQL_CPPFLAGS $CPPFLAGS"
LIBS="$PGSQL_LIBS $LIBS"
AC_LINK_IFELSE(
[AC_LANG_PROGRAM([#include <libpq-fe.h>],
[PGconn * c = PQconnectdb("dbname = 'postgres'");
PQfinish(c);])],
[AC_MSG_RESULT([checking for PostgreSQL headers and library... yes])],
[AC_MSG_RESULT([checking for PostgreSQL headers and library... no])
AC_MSG_ERROR([Needs PostgreSQL library])]
)
2014-12-29 16:09:12 +01:00
AC_CHECK_HEADERS([utils/errcodes.h],,
2015-01-05 14:35:44 +01:00
AC_MSG_ERROR([Missing required header file (errcodes.h) from PostgreSQL server-development package]))
2014-12-29 16:09:12 +01:00
2014-03-11 15:42:26 +01:00
CPPFLAGS=$CPPFLAGS_SAVED
LIBS=$LIBS_SAVED
# Note that PostgreSQL is present in the config.h file
AC_DEFINE([HAVE_PGSQL], [1], [PostgreSQL is present])
fi
# ... and at the shell level, so Makefile.am can take action depending on this.
AM_CONDITIONAL(HAVE_PGSQL, test "$PG_CONFIG" != "")
2011-04-08 15:49:22 +02:00
2011-05-19 13:52:58 +01:00
# Check for log4cplus
log4cplus_path="yes"
AC_ARG_WITH([log4cplus],
AC_HELP_STRING([--with-log4cplus=PATH],
[specify exact directory of log4cplus library and headers]),
[log4cplus_path="$withval"])
2011-09-29 11:17:37 -05:00
if test "${log4cplus_path}" = "no" ; then
2011-05-19 13:52:58 +01:00
AC_MSG_ERROR([Need log4cplus])
elif test "${log4cplus_path}" != "yes" ; then
LOG4CPLUS_INCLUDES="-I${log4cplus_path}/include"
2011-11-30 16:08:29 +01:00
LOG4CPLUS_LIBS="-L${log4cplus_path}/lib"
2011-05-19 13:52:58 +01:00
else
# If not specified, try some common paths.
log4cplusdirs="/usr/local /usr/pkg /opt /opt/local"
for d in $log4cplusdirs
do
if test -f $d/include/log4cplus/logger.h; then
LOG4CPLUS_INCLUDES="-I$d/include"
2011-11-30 16:08:29 +01:00
LOG4CPLUS_LIBS="-L$d/lib"
2011-05-19 13:52:58 +01:00
break
fi
done
fi
2012-10-07 21:20:52 -07:00
LOG4CPLUS_LIBS="$LOG4CPLUS_LIBS -llog4cplus $MULTITHREADING_FLAG"
2011-05-19 13:52:58 +01:00
2011-11-30 16:08:29 +01:00
AC_SUBST(LOG4CPLUS_LIBS)
2011-05-19 13:52:58 +01:00
AC_SUBST(LOG4CPLUS_INCLUDES)
CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$LOG4CPLUS_INCLUDES $CPPFLAGS"
2011-11-30 14:53:58 +01:00
LIBS_SAVED="$LIBS"
2011-11-30 16:08:29 +01:00
LIBS="$LOG4CPLUS_LIBS $LIBS"
2011-05-19 13:52:58 +01:00
AC_CHECK_HEADERS([log4cplus/logger.h],,AC_MSG_ERROR([Missing required header files.]))
AC_LINK_IFELSE(
[AC_LANG_PROGRAM([#include <log4cplus/logger.h>
],
[using namespace log4cplus;
Logger logger = Logger::getInstance("main");
])],
[AC_MSG_RESULT([checking for log4cplus library... yes])],
[AC_MSG_RESULT([checking for log4cplus library... no])
AC_MSG_ERROR([Needs log4cplus library])]
)
2013-09-10 11:33:32 +02:00
dnl Determine the log4cplus version, used mainly for config.report.
AC_MSG_CHECKING([log4cplus version])
cat > conftest.cpp << EOF
2013-09-12 15:45:08 +02:00
#include <log4cplus/version.h>
2013-09-10 11:33:32 +02:00
AUTOCONF_LOG4CPLUS_VERSION=LOG4CPLUS_VERSION_STR
EOF
2013-09-12 15:45:08 +02:00
LOG4CPLUS_VERSION=`$CPP $CPPFLAGS conftest.cpp | grep '^AUTOCONF_LOG4CPLUS_VERSION=' | $SED -e 's/^AUTOCONF_LOG4CPLUS_VERSION=//' -e 's/[[ ]]//g' -e 's/"//g' 2> /dev/null`
2013-09-10 11:33:32 +02:00
if test -z "$LOG4CPLUS_VERSION"; then
LOG4CPLUS_VERSION="unknown"
fi
$RM -f conftest.cpp
AC_MSG_RESULT([$LOG4CPLUS_VERSION])
2011-05-19 13:52:58 +01:00
CPPFLAGS=$CPPFLAGS_SAVED
2011-11-30 14:53:58 +01:00
LIBS=$LIBS_SAVED
2011-05-19 13:52:58 +01:00
2010-09-23 08:37:43 +00:00
#
# Configure Boost header path
#
2014-08-12 13:09:33 +02:00
AX_BOOST_FOR_KEA
2012-12-27 17:54:42 -08:00
# Boost offset_ptr is required in one library and not optional right now, so
# we unconditionally fail here if it doesn't work.
2013-08-16 09:59:55 +02:00
if test "$BOOST_OFFSET_PTR_WOULDFAIL" = "yes" -a "$werror_ok" = 1; then
2012-12-27 17:54:42 -08:00
AC_MSG_ERROR([Failed to compile a required header file. Try upgrading Boost to 1.44 or higher (when using clang++) or specifying --without-werror. See the ChangeLog entry for Trac no. 2147 for more details.])
2010-03-18 01:56:04 +00:00
fi
2012-08-01 18:19:00 -07:00
2013-07-08 08:19:31 +05:30
if test "$BOOST_STATIC_ASSERT_WOULDFAIL" = "yes" -a X"$werror_ok" = X1; then
AC_MSG_ERROR([Failed to use Boost static assertions. Try upgrading Boost to 1.54 or higher (when using GCC 4.8) or specifying --without-werror. See trac ticket no. 3039 for more details.])
fi
2012-12-27 18:14:36 -08:00
# There's a known bug in FreeBSD ports for Boost that would trigger a false
2012-12-27 18:59:06 -08:00
# warning in build with g++ and -Werror (we exclude clang++ explicitly to
# avoid unexpected false positives).
2012-12-28 21:48:36 +00:00
if test "$BOOST_NUMERIC_CAST_WOULDFAIL" = "yes" -a X"$werror_ok" = X1 -a $CLANGPP = "no"; then
2012-12-27 18:14:36 -08:00
AC_MSG_ERROR([Failed to compile a required header file. If you are using FreeBSD and Boost installed via ports, retry with specifying --without-werror. See the ChangeLog entry for Trac no. 1991 for more details.])
fi
# Add some default CPP flags needed for Boost, identified by the AX macro.
2012-12-28 07:11:03 +00:00
CPPFLAGS="$CPPFLAGS $CPPFLAGS_BOOST_THREADCONF"
2010-03-18 01:56:04 +00:00
2015-06-17 22:08:26 +02:00
# Can be required by gtest, boost and perhaps still asio
2011-11-30 14:53:58 +01:00
PTHREAD_LDFLAGS=
AC_CHECK_LIB(pthread, pthread_create,[ PTHREAD_LDFLAGS=-lpthread ], [])
AC_SUBST(PTHREAD_LDFLAGS)
AC_SUBST(MULTITHREADING_FLAG)
2011-02-23 19:01:11 +01:00
2009-12-29 16:07:20 +00:00
#
2010-01-26 19:41:22 +00:00
# Check availability of gtest, which will be used for unit tests.
2009-12-29 16:07:20 +00:00
#
2012-07-06 16:03:09 -05:00
GTEST_LDFLAGS=
GTEST_LDADD=
DISTCHECK_GTEST_CONFIGURE_FLAG=
2013-09-10 11:33:32 +02:00
GTEST_VERSION="unknown"
2012-07-11 18:04:19 -05:00
2012-07-06 16:03:09 -05:00
if test "x$enable_gtest" = "xyes" ; then
2012-07-05 21:48:16 -05:00
2012-12-10 13:41:48 -06:00
DISTCHECK_GTEST_CONFIGURE_FLAG="--with-gtest=$gtest_path"
2012-07-16 14:57:11 +02:00
if test -n "$with_gtest_source" ; then
2012-07-05 21:48:16 -05:00
2014-10-30 00:42:41 +01:00
if test "x$GTEST_SOURCE" = "xyes" ; then
2012-07-05 21:48:16 -05:00
2012-07-06 18:46:20 -05:00
AC_MSG_CHECKING([for gtest source])
2012-07-05 21:48:16 -05:00
# If not specified, try some common paths.
2012-07-06 18:46:20 -05:00
GTEST_SOURCE=
2012-07-16 14:57:11 +02:00
for d in /usr/src/gtest /usr/local /usr/pkg /opt /opt/local ; do
if test -f $d/src/gtest-all.cc -a $d/src/gtest_main.cc; then
GTEST_SOURCE=$d
AC_MSG_RESULT([$GTEST_SOURCE])
break
fi
done
2012-07-06 18:46:20 -05:00
if test -z $GTEST_SOURCE ; then
2012-07-16 14:57:11 +02:00
AC_MSG_ERROR([no gtest source but it was selected])
2012-07-06 18:46:20 -05:00
fi
2014-10-30 00:42:41 +01:00
else
2012-07-06 18:46:20 -05:00
AC_CHECK_FILES([$GTEST_SOURCE/src/gtest-all.cc]
2014-10-30 00:42:41 +01:00
[$GTEST_SOURCE/src/gtest_main.cc],
[have_gtest_source=yes],
[AC_MSG_ERROR([no gtest source at $GTEST_SOURCE])])
fi
have_gtest_source=yes
GTEST_LDFLAGS="\$(top_builddir)/ext/gtest/libgtest.a"
DISTCHECK_GTEST_CONFIGURE_FLAG="--with-gtest-source=$GTEST_SOURCE"
GTEST_INCLUDES="-I$GTEST_SOURCE -I$GTEST_SOURCE/include"
# See $GTEST_SOURCE/include/gtest/internal/gtest-port.h
# about GTEST_HAS_PTHREAD.
case "$host" in
2012-07-11 18:04:19 -05:00
*-solaris*|*-linux*|*-hpux*)
GTEST_LDADD="$GTEST_LDADD $PTHREAD_LDFLAGS"
;;
2014-10-30 00:42:41 +01:00
esac
2012-07-16 14:57:11 +02:00
fi
2014-10-30 00:42:41 +01:00
if test "$gtest_path" != "no" ; then
if test "$gtest_path" != "yes"; then
GTEST_PATHS=$gtest_path
if test -x "${gtest_path}/bin/gtest-config" ; then
GTEST_CONFIG="${gtest_path}/bin/gtest-config"
fi
else
AC_PATH_PROG([GTEST_CONFIG], [gtest-config])
2012-07-16 14:57:11 +02:00
fi
2014-10-30 00:42:41 +01:00
if test -x "${GTEST_CONFIG}" ; then :
# using cppflags instead of cxxflags
GTEST_INCLUDES=`${GTEST_CONFIG} --cppflags`
GTEST_LDFLAGS=`${GTEST_CONFIG} --ldflags`
GTEST_LDADD=`${GTEST_CONFIG} --libs`
GTEST_VERSION=`${GTEST_CONFIG} --version`
GTEST_FOUND="true"
else
AC_MSG_WARN([Unable to locate Google Test gtest-config.])
if test -z "${GTEST_PATHS}" ; then
GTEST_PATHS="/usr /usr/local"
2012-07-16 14:57:11 +02:00
fi
2014-10-30 00:42:41 +01:00
GTEST_FOUND="false"
fi
if test "${GTEST_FOUND}" != "true"; then
GTEST_FOUND="false"
for dir in $GTEST_PATHS; do
if test -f "$dir/include/gtest/gtest.h"; then
GTEST_INCLUDES="-I$dir/include"
GTEST_LDFLAGS="-L$dir/lib"
GTEST_LDADD="-lgtest"
GTEST_FOUND="true"
# There is no gtest-config script on this
# system, which is supposed to inform us
# whether we need pthreads as well (a
# gtest compile-time option). So we still
# need to test that manually.
CPPFLAGS_SAVED="$CPPFLAGS"
CPPFLAGS="$CPPFLAGS $GTEST_INCLUDES"
LDFLAGS_SAVED="$LDFLAGS"
LDFLAGS="$LDFLAGS $GTEST_LDFLAGS"
LIBS_SAVED=$LIBS
LIBS="$LIBS $GTEST_LDADD"
AC_MSG_CHECKING([Checking whether gtest tests need pthreads])
# First try to compile without pthreads
AC_TRY_LINK([
#include <gtest/gtest.h>
],[
int i = 0;
char* c = NULL;
::testing::InitGoogleTest(&i, &c);
return (0);
],
[ AC_MSG_RESULT(no) ],
[
LIBS="$SAVED_LIBS $GTEST_LDADD $PTHREAD_LDFLAGS"
# Now try to compile with pthreads
AC_TRY_LINK([
#include <gtest/gtest.h>
],[
int i = 0;
char* c = NULL;
::testing::InitGoogleTest(&i, &c);
return (0);
],
[ AC_MSG_RESULT(yes)
GTEST_LDADD="$GTEST_LDADD $PTHREAD_LDFLAGS"
],
# Apparently we can't compile it at all
[ AC_MSG_ERROR(unable to compile with gtest) ])
])
CPPFLAGS=$CPPFLAGS_SAVED
LDFLAGS=$LDFLAGS_SAVED
LIBS=$LIBS_SAVED
break
fi
done
fi
if test "${GTEST_FOUND}" != "true"; then
AC_MSG_ERROR([Cannot find gtest in: $GTEST_PATHS])
fi
2012-07-06 16:03:09 -05:00
2014-10-30 00:42:41 +01:00
fi
2009-10-17 00:14:33 +00:00
fi
2012-07-06 16:03:09 -05:00
AM_CONDITIONAL(HAVE_GTEST, test $enable_gtest != "no")
AM_CONDITIONAL(HAVE_GTEST_SOURCE, test "X$have_gtest_source" = "Xyes")
2011-10-06 16:00:48 -05:00
AC_SUBST(DISTCHECK_GTEST_CONFIGURE_FLAG)
2009-10-27 00:09:38 +00:00
AC_SUBST(GTEST_INCLUDES)
AC_SUBST(GTEST_LDFLAGS)
AC_SUBST(GTEST_LDADD)
2012-07-06 16:03:09 -05:00
AC_SUBST(GTEST_SOURCE)
2009-10-17 00:14:33 +00:00
2010-05-28 01:25:08 +00:00
#
# ASIO: we extensively use it as the C++ event management module.
#
2011-02-14 16:13:43 +01:00
# Use our 'coroutine' header from ext
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/coroutine"
#
2015-09-03 20:07:39 +02:00
# Doesn't seem to be required?
CPPFLAGS="$CPPFLAGS -DBOOST_ASIO_HEADER_ONLY"
2015-09-04 10:42:21 +02:00
#
2010-09-21 04:04:49 +00:00
# Disable threads: Currently we don't use them.
2015-09-04 10:42:21 +02:00
CPPFLAGS="$CPPFLAGS -DBOOST_ASIO_DISABLE_THREADS=1"
# We tried to stay header only
if test "x${BOOST_LIBS}" = "x"; then
# Don't want boost system library
CPPFLAGS="$CPPFLAGS -DBOOST_ERROR_CODE_HEADER_ONLY"
# Avoid boost::system::throws multiple defines
CPPFLAGS="$CPPFLAGS -DBOOST_SYSTEM_NO_DEPRECATED"
fi
2010-05-31 01:05:35 +00:00
2012-03-21 10:05:33 +05:30
# Check for functions that are not available on all platforms
2012-03-20 00:17:20 +05:30
AC_CHECK_FUNCS([pselect])
2010-05-31 01:05:35 +00:00
# /dev/poll issue: ASIO uses /dev/poll by default if it's available (generally
# the case with Solaris). Unfortunately its /dev/poll specific code would
# trigger the gcc's "missing-field-initializers" warning, which would
# subsequently make the build fail with -Werror. Further, older versions of
2010-05-31 01:42:42 +00:00
# gcc don't provide an option to selectively suppress this warning.
2010-05-31 01:05:35 +00:00
# So, for the moment, we simply disable the use of /dev/poll. Unless we
# implement recursive DNS server with randomized ports, we don't need the
# scalability that /dev/poll can provide, so this decision wouldn't affect
2011-01-19 08:13:54 -06:00
# run time performance. Hopefully we can find a better solution or the ASIO
2010-05-31 01:05:35 +00:00
# code will be updated by the time we really need it.
AC_CHECK_HEADERS(sys/devpoll.h, ac_cv_have_devpoll=yes, ac_cv_have_devpoll=no)
2010-06-23 06:25:14 +00:00
if test "X$ac_cv_have_devpoll" = "Xyes" -a "X$GXX" = "Xyes"; then
2015-09-20 09:31:12 +02:00
CPPFLAGS="$CPPFLAGS -DBOOST_ASIO_DISABLE_DEV_POLL=1"
2010-05-31 01:05:35 +00:00
fi
2010-05-27 18:57:15 +00:00
2011-03-03 17:16:55 -08:00
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)
2011-10-05 16:56:56 +01:00
AC_PATH_PROGS(AWK, gawk awk)
AC_SUBST(AWK)
2011-03-03 17:16:55 -08:00
2015-11-04 22:03:51 +09:00
AC_ARG_ENABLE(generate_parser, [AC_HELP_STRING([--enable-generate-parser],
[indicates that the parsers will be regenerated. This implies that the
bison and flex are required [default=no]])],
enable_generate_parser=$enableval, enable_generate_parser=no)
# Check if flex is avaible. Flex is not needed for building Kea sources,
# unless you want to regenerate grammar in src/lib/eval
AC_PROG_LEX
# Check if bison is available. Bison is not needed for building Kea sources,
# unless you want to regenerate grammar in src/lib/eval
AC_PROG_YACC
if test "x$enable_generate_parser" != xno; then
if test "x$LEX" == "x"; then
AC_MSG_ERROR("Flex is required for enable-generate-parser, but was not found")
fi
if test "x$YACC" == "x"; then
AC_MSG_ERROR("Bison it required for enable-generate-parser, but was not found")
fi
# Ok, let's check if we have at least 3.0.0 version of the bison. The code used
# to generate src/lib/eval parser is roughly based on bison 3.0 examples.
cat > bisontest.y << EOF
%require "3.0.0"
%token X
%%
%start Y;
Y: X;
EOF
# Try to compile.
$YACC bisontest.y -o bisontest.cc
if test $? -ne 0 ; then
$YACC -V
AC_MSG_ERROR("Error with $YACC. Possibly incorrect version? Required at least 3.0.0.")
fi
rm -f bisontest.y bisontest.cc
fi
2012-08-02 20:55:20 -05:00
AC_ARG_ENABLE(generate_docs, [AC_HELP_STRING([--enable-generate-docs],
[regenerate documentation using Docbook [default=no]])],
enable_generate_docs=$enableval, enable_generate_docs=no)
2012-06-01 12:38:13 -07:00
2012-08-02 20:55:20 -05:00
if test "x$enable_generate_docs" != xno ; then
2014-06-25 15:05:26 +02:00
if test "$PYTHON" == "no" ; then
2014-06-25 15:00:26 +02:00
AC_MSG_ERROR("Python3 is required for enable-generate-docs")
fi
# Check for xsltproc
2012-06-01 12:38:13 -07:00
AC_PATH_PROG([XSLTPROC], [xsltproc])
if test -z "$XSLTPROC"; then
2012-08-02 20:55:20 -05:00
AC_MSG_ERROR("xsltproc not found; it is required for --enable-generate-docs")
2012-06-01 12:38:13 -07:00
else
AC_MSG_CHECKING([if $XSLTPROC works])
# run xsltproc to see if works
$XSLTPROC --novalid --xinclude --nonet http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl
if test $? -ne 0 ; then
AC_MSG_ERROR("Error with $XSLTPROC using release/xsl/current/manpages/docbook.xsl")
fi
$XSLTPROC --novalid --xinclude --nonet http://docbook.sourceforge.net/release/xsl/current/html/docbook.xsl
if test $? -ne 0 ; then
AC_MSG_ERROR("Error with $XSLTPROC using release/xsl/current/html/docbook.xsl")
fi
2012-06-15 08:07:18 -05:00
AC_MSG_RESULT(yes)
2012-06-01 12:38:13 -07:00
fi
2013-07-25 11:25:39 +05:30
AC_PATH_PROG([ELINKS], [elinks])
if test -z "$ELINKS"; then
AC_MSG_ERROR("elinks not found; it is required for --enable-generate-docs")
fi
2012-06-01 12:38:13 -07:00
fi
2014-12-23 12:54:35 -08:00
# Don't fail here if not found, used to generate PDF documentation.
AC_PATH_PROG([DBLATEX], [dblatex])
AM_CONDITIONAL(HAVE_DBLATEX, test "x$DBLATEX" != "x")
2010-03-18 12:52:31 +00:00
2012-08-02 20:55:20 -05:00
AM_CONDITIONAL(GENERATE_DOCS, test x$enable_generate_docs != xno)
2009-10-16 06:20:23 +00:00
2010-03-19 14:06:09 +00:00
AC_ARG_ENABLE(install-configurations,
[AC_HELP_STRING([--disable-install-configurations],
[do not install configuration])], install_configurations=$enableval, install_configurations=yes)
2010-03-19 04:47:16 +00:00
2010-03-19 14:06:09 +00:00
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
2010-03-19 04:47:16 +00:00
2012-05-01 15:18:42 +05:30
AC_ARG_ENABLE(logger-checks, [AC_HELP_STRING([--enable-logger-checks],
[check logger messages [default=no]])], enable_logger_checks=$enableval, enable_logger_checks=no)
AM_CONDITIONAL(ENABLE_LOGGER_CHECKS, test x$enable_logger_checks != xno)
AM_COND_IF([ENABLE_LOGGER_CHECKS], [AC_DEFINE([ENABLE_LOGGER_CHECKS], [1], [Check logger messages?])])
2013-06-18 23:50:17 +05:30
# Check for asciidoc
AC_PATH_PROG(ASCIIDOC, asciidoc, no)
AM_CONDITIONAL(HAVE_ASCIIDOC, test "x$ASCIIDOC" != "xno")
# Check for plantuml
AC_PATH_PROG(PLANTUML, plantuml, no)
AM_CONDITIONAL(HAVE_PLANTUML, test "x$PLANTUML" != "xno")
2012-06-12 16:29:15 +05:30
# Check for valgrind
AC_PATH_PROG(VALGRIND, valgrind, no)
AM_CONDITIONAL(HAVE_VALGRIND, test "x$VALGRIND" != "xno")
2012-10-11 17:22:23 +02:00
# Also check for valgrind headers
# We could consider adding them to the source code tree, as this
# is the encouraged method of using them; they are BSD-licensed.
# However, until we find that this is a problem, we just use
# the system-provided ones, if available
AC_CHECK_HEADERS(valgrind/valgrind.h, [AC_DEFINE([HAVE_VALGRIND_HEADERS], [1], [Check valgrind headers])])
2012-06-18 16:24:34 +05:30
found_valgrind="not found"
if test "x$VALGRIND" != "xno"; then
found_valgrind="found"
2012-06-12 16:29:15 +05:30
fi
2012-09-20 11:19:51 +02:00
# Check for optreset in unistd.h. On BSD systems the optreset is
# used to reset the state of getopt() function. Resetting its state
# is required if command line arguments are parsed multiple times
# during a program. On Linux this variable will not exist because
# getopt() reset is performed by setting optind = 0. On Operating
# Systems where optreset is defined use optreset = 1 and optind = 1
# to reset internal state of getopt(). Failing to do so will result
# in unpredictable output from getopt().
AC_MSG_CHECKING([whether optreset variable is defined in unistd.h])
AC_TRY_LINK(
[#include <unistd.h>],
2012-09-21 18:22:45 +02:00
[extern int optreset; optreset=1;],
2012-09-20 11:19:51 +02:00
[ AC_MSG_RESULT(yes)
var_optreset_exists=yes],
[ AC_MSG_RESULT(no)
var_optreset_exists=no]
)
AM_CONDITIONAL(HAVE_OPTRESET, test "x$var_optreset_exists" != "xno")
2012-09-20 12:02:55 +02:00
AM_COND_IF([HAVE_OPTRESET], [AC_DEFINE([HAVE_OPTRESET], [1], [Check for optreset?])])
2012-09-20 11:19:51 +02:00
2015-05-11 15:23:18 +02:00
AC_DEFINE([CONFIG_H_WAS_INCLUDED], [1], [config.h inclusion marker])
2013-12-30 11:04:25 +02:00
AC_CONFIG_FILES([compatcheck/Makefile
dns++.pc
2013-06-18 23:50:17 +05:30
doc/design/datasrc/Makefile
2013-12-30 11:04:25 +02:00
doc/design/Makefile
doc/guide/Makefile
doc/Makefile
doc/version.ent
2015-09-20 09:44:51 +02:00
ext/coroutine/Makefile
2015-05-17 16:32:28 +02:00
ext/gtest/Makefile
2013-12-30 11:04:25 +02:00
ext/Makefile
m4macros/Makefile
Makefile
2014-07-30 17:15:45 +01:00
src/Makefile
src/bin/Makefile
2013-12-30 11:04:25 +02:00
src/bin/d2/Makefile
src/bin/d2/spec_config.h.pre
src/bin/d2/tests/Makefile
2014-06-26 09:06:07 -04:00
src/bin/d2/tests/d2_process_tests.sh
2013-12-30 11:04:25 +02:00
src/bin/d2/tests/test_data_files_config.h
src/bin/dhcp4/Makefile
src/bin/dhcp4/spec_config.h.pre
src/bin/dhcp4/tests/Makefile
2014-07-30 17:15:45 +01:00
src/bin/dhcp4/tests/dhcp4_process_tests.sh
2013-12-30 11:04:25 +02:00
src/bin/dhcp4/tests/marker_file.h
2014-01-06 10:56:59 -05:00
src/bin/dhcp4/tests/test_data_files_config.h
2013-12-30 11:04:25 +02:00
src/bin/dhcp4/tests/test_libraries.h
src/bin/dhcp6/Makefile
src/bin/dhcp6/spec_config.h.pre
src/bin/dhcp6/tests/Makefile
2014-07-30 17:15:45 +01:00
src/bin/dhcp6/tests/dhcp6_process_tests.sh
2013-12-30 11:04:25 +02:00
src/bin/dhcp6/tests/marker_file.h
src/bin/dhcp6/tests/test_data_files_config.h
src/bin/dhcp6/tests/test_libraries.h
2014-07-30 17:15:45 +01:00
src/bin/keactrl/Makefile
src/bin/keactrl/keactrl
2014-06-12 14:25:39 +02:00
src/bin/keactrl/keactrl.conf
2014-06-09 18:19:43 +02:00
src/bin/keactrl/tests/Makefile
2014-07-30 17:15:45 +01:00
src/bin/keactrl/tests/keactrl_tests.sh
2015-01-22 16:31:04 +01:00
src/bin/lfc/Makefile
src/bin/lfc/tests/Makefile
2014-07-30 17:15:45 +01:00
src/bin/perfdhcp/Makefile
src/bin/perfdhcp/tests/Makefile
src/bin/perfdhcp/tests/testdata/Makefile
2014-11-05 13:17:28 +01:00
src/bin/admin/Makefile
src/bin/admin/kea-admin
src/bin/admin/scripts/Makefile
src/bin/admin/tests/Makefile
2015-06-29 14:08:46 -04:00
src/bin/admin/tests/data/Makefile
2014-11-05 13:17:28 +01:00
src/bin/admin/tests/memfile_tests.sh
src/bin/admin/tests/mysql_tests.sh
2015-05-28 14:18:04 -04:00
src/bin/admin/tests/pgsql_tests.sh
2014-11-05 13:17:28 +01:00
src/bin/admin/scripts/mysql/Makefile
2014-12-05 23:33:53 +01:00
src/bin/admin/scripts/mysql/upgrade_1.0_to_2.0.sh
2015-05-28 14:18:04 -04:00
src/bin/admin/scripts/mysql/upgrade_2.0_to_3.0.sh
2015-10-01 15:38:09 -04:00
src/bin/admin/scripts/mysql/upgrade_3.0_to_4.0.sh
2014-11-05 13:17:28 +01:00
src/bin/admin/scripts/pgsql/Makefile
2015-10-20 08:36:14 -04:00
src/bin/admin/scripts/pgsql/upgrade_1.0_to_2.0.sh
2014-07-30 17:15:45 +01:00
src/hooks/Makefile
2013-10-11 14:10:06 -04:00
src/hooks/dhcp/Makefile
src/hooks/dhcp/user_chk/Makefile
src/hooks/dhcp/user_chk/tests/Makefile
2013-12-30 11:04:25 +02:00
src/hooks/dhcp/user_chk/tests/test_data_files_config.h
2014-07-30 17:15:45 +01:00
src/lib/Makefile
2011-04-07 17:59:29 +08:00
src/lib/asiodns/Makefile
2011-04-08 17:02:44 +08:00
src/lib/asiodns/tests/Makefile
2013-12-30 11:04:25 +02:00
src/lib/asiolink/Makefile
src/lib/asiolink/tests/Makefile
2009-10-30 17:28:17 +00:00
src/lib/cc/Makefile
2010-08-13 23:22:54 +00:00
src/lib/cc/tests/Makefile
2015-07-22 11:53:35 -04:00
src/lib/cfgrpt/Makefile
2015-07-22 12:56:45 -04:00
src/lib/cfgrpt/tests/Makefile
2013-12-30 11:04:25 +02:00
src/lib/config/Makefile
src/lib/config/tests/Makefile
2014-07-30 17:15:45 +01:00
src/lib/config/tests/data_def_unittests_config.h
2013-12-30 11:04:25 +02:00
src/lib/config/tests/testdata/Makefile
src/lib/cryptolink/Makefile
src/lib/cryptolink/tests/Makefile
2014-07-30 17:15:45 +01:00
src/lib/dhcp/Makefile
src/lib/dhcp/tests/Makefile
2013-12-30 11:04:25 +02:00
src/lib/dhcp_ddns/Makefile
src/lib/dhcp_ddns/tests/Makefile
src/lib/dhcpsrv/Makefile
src/lib/dhcpsrv/tests/Makefile
src/lib/dhcpsrv/tests/test_libraries.h
2014-07-30 17:15:45 +01:00
src/lib/dhcpsrv/testutils/Makefile
2013-12-30 11:04:25 +02:00
src/lib/dns/Makefile
2014-07-30 17:15:45 +01:00
src/lib/dns/gen-rdatacode.py
2013-12-30 11:04:25 +02:00
src/lib/dns/tests/Makefile
src/lib/dns/tests/testdata/Makefile
src/lib/exceptions/Makefile
src/lib/exceptions/tests/Makefile
src/lib/hooks/Makefile
src/lib/hooks/tests/Makefile
src/lib/hooks/tests/marker_file.h
src/lib/hooks/tests/test_libraries.h
2014-07-30 17:15:45 +01:00
src/lib/log/Makefile
2013-12-30 11:04:25 +02:00
src/lib/log/compiler/Makefile
src/lib/log/interprocess/Makefile
src/lib/log/interprocess/tests/Makefile
2014-07-30 17:15:45 +01:00
src/lib/log/tests/Makefile
2013-12-30 11:04:25 +02:00
src/lib/log/tests/buffer_logger_test.sh
src/lib/log/tests/console_test.sh
src/lib/log/tests/destination_test.sh
src/lib/log/tests/init_logger_test.sh
src/lib/log/tests/local_file_test.sh
src/lib/log/tests/logger_lock_test.sh
src/lib/log/tests/severity_test.sh
src/lib/log/tests/tempdir.h
src/lib/testutils/Makefile
2014-07-30 17:15:45 +01:00
src/lib/testutils/dhcp_test_lib.sh
2015-05-14 19:43:05 +02:00
src/lib/stats/Makefile
src/lib/stats/tests/Makefile
2013-12-30 11:04:25 +02:00
src/lib/util/Makefile
2014-07-30 17:15:45 +01:00
src/lib/util/io/Makefile
2011-08-04 17:23:22 -07:00
src/lib/util/python/Makefile
2014-07-30 17:15:45 +01:00
src/lib/util/python/gen_wiredata.py
2011-04-27 10:35:13 +02:00
src/lib/util/tests/Makefile
2015-02-05 18:43:16 +01:00
src/lib/util/tests/process_spawn_app.sh
2013-12-30 11:04:25 +02:00
src/lib/util/threads/Makefile
src/lib/util/threads/tests/Makefile
src/lib/util/unittests/Makefile
2015-10-26 20:11:22 +01:00
src/lib/eval/Makefile
src/lib/eval/tests/Makefile
2015-02-28 01:37:39 +01:00
tools/Makefile
2014-08-08 12:57:20 +02:00
tools/path_replacer.sh
2013-12-30 10:47:23 +02:00
])
AC_CONFIG_COMMANDS([permissions], [
2014-06-13 10:46:13 +02:00
chmod +x src/bin/dhcp4/tests/dhcp4_process_tests.sh
chmod +x src/bin/dhcp6/tests/dhcp6_process_tests.sh
2014-06-04 15:55:05 +02:00
chmod +x src/bin/keactrl/keactrl
2014-06-09 18:19:43 +02:00
chmod +x src/bin/keactrl/tests/keactrl_tests.sh
2014-11-05 14:36:25 +01:00
chmod +x src/bin/admin/kea-admin
2010-03-12 17:16:02 +00:00
chmod +x src/lib/dns/gen-rdatacode.py
2011-05-26 17:45:17 +01:00
chmod +x src/lib/log/tests/console_test.sh
2011-06-06 14:11:27 +01:00
chmod +x src/lib/log/tests/destination_test.sh
2011-06-29 19:08:56 +01:00
chmod +x src/lib/log/tests/init_logger_test.sh
chmod +x src/lib/log/tests/local_file_test.sh
2012-05-28 18:25:26 +05:30
chmod +x src/lib/log/tests/logger_lock_test.sh
2011-05-27 19:13:33 +01:00
chmod +x src/lib/log/tests/severity_test.sh
2011-08-04 17:23:22 -07:00
chmod +x src/lib/util/python/gen_wiredata.py
2015-02-05 18:43:16 +01:00
chmod +x src/lib/util/tests/process_spawn_app.sh
2014-08-08 12:57:20 +02:00
chmod +x tools/path_replacer.sh
2013-12-30 11:04:25 +02:00
])
2013-12-30 10:47:23 +02:00
2009-10-16 06:20:23 +00:00
AC_OUTPUT
2010-05-17 14:05:15 +00:00
dnl Print the results
dnl
2014-08-11 16:09:43 +02:00
EXTENDED_VERSION=${PACKAGE_VERSION}
if test "$KEA_SRCID" != ""; then
EXTENDED_VERSION="${EXTENDED_VERSION} ($KEA_SRCID)"
fi
2010-05-17 14:05:15 +00:00
cat > config.report << END
2014-04-14 21:18:01 +02:00
Kea source configure results:
2010-05-17 14:05:15 +00:00
-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
Package:
2013-09-10 11:33:32 +02:00
Name: ${PACKAGE_NAME}
Version: ${PACKAGE_VERSION}
2014-08-11 16:09:43 +02:00
Extended version:${EXTENDED_VERSION}
2013-09-10 11:33:32 +02:00
OS Family: ${OS_TYPE}
2013-09-12 15:45:08 +02:00
Using GNU sed: ${GNU_SED}
2013-09-10 11:33:32 +02:00
C++ Compiler:
CXX: ${CXX}
2013-09-12 15:45:08 +02:00
CXX_VERSION: ${CXX_VERSION}
2013-09-10 11:33:32 +02:00
DEFS: ${DEFS}
CPPFLAGS: ${CPPFLAGS}
CXXFLAGS: ${CXXFLAGS}
LDFLAGS: ${LDFLAGS}
2014-08-12 13:11:38 +02:00
KEA_CXXFLAGS: ${KEA_CXXFLAGS}
2014-06-25 15:00:26 +02:00
END
2013-09-10 11:33:32 +02:00
2014-06-25 15:00:26 +02:00
if test "$PYTHON" != "no" ; then
cat >> config.report << END
2013-09-10 11:33:32 +02:00
2014-07-01 13:05:44 +02:00
Python3:
2013-09-10 11:33:32 +02:00
PYTHON_VERSION: ${PYTHON_VERSION}
PYTHON_INCLUDES: ${PYTHON_INCLUDES}
PYTHON_CXXFLAGS: ${PYTHON_CXXFLAGS}
PYTHON_LDFLAGS: ${PYTHON_LDFLAGS}
PYTHON_LIB: ${PYTHON_LIB}
2014-06-25 15:00:26 +02:00
END
else
cat >> config.report << END
2014-07-01 13:05:44 +02:00
Python3:
not installed
2014-06-25 15:00:26 +02:00
END
fi
cat >> config.report << END
2013-09-10 11:33:32 +02:00
Boost:
BOOST_VERSION: ${BOOST_VERSION}
BOOST_INCLUDES: ${BOOST_INCLUDES}
2015-09-04 10:42:21 +02:00
BOOST_LIBS: ${BOOST_LIBS}
2013-09-10 11:33:32 +02:00
2014-06-30 15:26:38 +02:00
${CRYPTO_NAME}:
CRYPTO_VERSION: ${CRYPTO_VERSION}
CRYPTO_CFLAGS: ${CRYPTO_CFLAGS}
CRYPTO_INCLUDES: ${CRYPTO_INCLUDES}
CRYPTO_LDFLAGS: ${CRYPTO_LDFLAGS}
CRYPTO_LIBS: ${CRYPTO_LIBS}
${DISABLED_CRYPTO}: no
2013-09-10 11:33:32 +02:00
Log4cplus:
LOG4CPLUS_VERSION: ${LOG4CPLUS_VERSION}
LOG4CPLUS_INCLUDES: ${LOG4CPLUS_INCLUDES}
LOG4CPLUS_LIBS: ${LOG4CPLUS_LIBS}
2014-04-22 15:21:26 +02:00
Kea config backend:
2014-07-01 13:05:44 +02:00
CONFIG_BACKEND: ${CONFIG_BACKEND}
2015-11-04 22:03:51 +09:00
Flex/bison:
FLEX: ${LEX}
BISON: ${YACC}
2012-10-29 13:43:31 +00:00
END
# Avoid confusion on DNS/DHCP and only mention MySQL if it
# were specified on the command line.
if test "$MYSQL_CPPFLAGS" != "" ; then
cat >> config.report << END
2013-09-10 11:33:32 +02:00
MySQL:
MYSQL_VERSION: ${MYSQL_VERSION}
MYSQL_CPPFLAGS: ${MYSQL_CPPFLAGS}
MYSQL_LIBS: ${MYSQL_LIBS}
END
2014-03-11 15:42:26 +01:00
else
cat >> config.report << END
2014-07-01 13:05:44 +02:00
MySQL:
no
2014-03-11 15:42:26 +01:00
END
fi
if test "$PGSQL_CPPFLAGS" != "" ; then
cat >> config.report << END
PostgreSQL:
PGSQL_VERSION: ${PGSQL_VERSION}
PGSQL_CPPFLAGS: ${PGSQL_CPPFLAGS}
PGSQL_LIBS: ${PGSQL_LIBS}
END
else
cat >> config.report << END
2014-07-01 13:05:44 +02:00
PostgreSQL:
no
2014-03-11 15:42:26 +01:00
END
2013-09-10 11:33:32 +02:00
fi
if test "$enable_gtest" != "no"; then
cat >> config.report << END
GTest:
GTEST_VERSION: ${GTEST_VERSION}
GTEST_INCLUDES: ${GTEST_INCLUDES}
GTEST_LDFLAGS: ${GTEST_LDFLAGS}
GTEST_LDADD: ${GTEST_LDADD}
GTEST_SOURCE: ${GTEST_SOURCE}
2012-10-29 13:43:31 +00:00
END
fi
cat >> config.report << END
2010-05-17 14:05:15 +00:00
Features:
$enable_features
Developer:
2012-10-18 19:12:37 +05:30
Enable Debugging: $debug_enabled
2012-07-06 16:03:09 -05:00
Google Tests: $enable_gtest
2012-06-18 16:24:34 +05:30
Valgrind: $found_valgrind
2010-10-07 17:30:20 +00:00
C++ Code Coverage: $USE_LCOV
2012-06-12 19:41:21 +05:30
Logger checks: $enable_logger_checks
2012-08-02 20:55:20 -05:00
Generate Documentation: $enable_generate_docs
2015-11-04 22:03:51 +09:00
Parser Generation: $enable_generate_parser
2010-05-17 14:05:15 +00:00
END
cat config.report
cat <<EOF
2014-08-06 12:51:57 +02:00
Now you can type "make" to build Kea. Note that if you intend to
2013-10-01 13:54:18 +05:30
run "make check", you must run "make" first as some files need to be
generated by "make" before "make check" can be run.
2010-05-17 14:05:15 +00:00
2013-12-02 16:06:17 +02:00
When running "make install" do not use any form of parallel or job
2013-12-05 17:38:23 +05:30
server options (such as GNU make's -j option). Doing so may cause
errors.
2013-12-02 16:06:17 +02:00
2010-05-17 14:05:15 +00:00
EOF