configure.ac 47.2 KB
Newer Older
1 2 3
#                                               -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.

4
AC_PREREQ([2.59])
Jeremy C. Reed's avatar
Jeremy C. Reed committed
5
AC_INIT(bind10-devel, 20120316, bind10-dev@isc.org)
6 7
AC_CONFIG_SRCDIR(README)
AM_INIT_AUTOMAKE
8
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])dnl be backward compatible
9 10 11 12
AC_CONFIG_HEADERS([config.h])

# Checks for programs.
AC_PROG_CXX
13 14 15

# Libtool configuration
#
Jelte Jansen's avatar
Jelte Jansen committed
16 17 18 19 20 21

# libtool cannot handle spaces in paths, so exit early if there is one
if [ test `echo $PWD | grep -c ' '` != "0"  ]; then
    AC_MSG_ERROR([BIND 10 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.])
fi

22 23
# On FreeBSD (and probably some others), clang++ does not meet an autoconf
# assumption in identifying libtool configuration regarding shared library:
24 25 26 27 28
# 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).
29 30 31 32 33
# 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
34
CXXFLAGS_SAVED=$CXXFLAGS
35
CFLAGS="$CFLAGS $CXX_LIBTOOL_LDFLAGS"
36
CXXFLAGS="$CXXFLAGS $CXX_LIBTOOL_LDFLAGS"
37
AC_PROG_LIBTOOL
38
CFLAGS=$CFLAGS_SAVED
39
CXXFLAGS=$CXXFLAGS_SAVED
40

41
# Use C++ language
42 43 44
AC_LANG([C++])

# Identify the compiler: this check must be after AC_PROG_CXX and AC_LANG.
45
AM_CONDITIONAL(USE_GXX, test "X${GXX}" = "Xyes")
46
AC_CHECK_DECL([__SUNPRO_CC], [SUNCXX="yes"], [SUNCXX="no"])
47 48
AC_CHECK_DECL([__clang__], [CLANGPP="yes"], [CLANGPP="no"])
AM_CONDITIONAL(USE_CLANGPP, test "X${CLANGPP}" = "Xyes")
49

50 51
# Linker options

Jelte Jansen's avatar
Jelte Jansen committed
52 53
# check -R and -Wl,-R rather than gcc specific -rpath to be as portable
# as possible.
54 55 56 57
AC_MSG_CHECKING([whether -R flag is available in linker])
LDFLAGS_SAVED="$LDFLAGS"
LDFLAGS="$LDFLAGS -R/usr/lib"
AC_TRY_LINK([],[],
58 59 60 61 62 63 64 65 66 67 68 69
    [ AC_MSG_RESULT(yes)
        rpath_flag=-R
    ],[ AC_MSG_RESULT(no)
        AC_MSG_CHECKING([whether -Wl,-R flag is available in linker])
        LDFLAGS="$LDFLAGS_SAVED -Wl,-R"
        AC_TRY_LINK([], [],
            [ AC_MSG_RESULT(yes)
                rpath_flag=-Wl,-R
            ],[ AC_MSG_RESULT(no)
                 rpath_flag=no
            ])
    ])
70 71
LDFLAGS=$LDFLAGS_SAVED

JINMEI Tatuya's avatar
JINMEI Tatuya committed
72 73 74 75 76 77 78 79
# 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)

JINMEI Tatuya's avatar
JINMEI Tatuya committed
80 81 82 83 84 85 86 87
# 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
if test $enable_shared = no; then
	AC_MSG_ERROR([BIND 10 requires shared libraries to be built])
fi

Michal Vaner's avatar
Michal Vaner committed
88 89 90 91 92 93
# allow configuring without setproctitle.
AC_ARG_ENABLE(setproctitle-check,
AC_HELP_STRING([--disable-setproctitle-check],
  [do not check for python setproctitle module (used to give nice names to python processes)]),
  setproctitle_check=$enableval, setproctitle_check=yes)

94 95 96 97
# OS dependent configuration
SET_ENV_LIBRARY_PATH=no
ENV_LIBRARY_PATH=LD_LIBRARY_PATH

98
case "$host" in
99 100 101 102
*-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__"
Dima Volodin's avatar
Dima Volodin committed
103 104
	# "now" binding is necessary to prevent deadlocks in C++ static initialization code
	LDFLAGS="$LDFLAGS -z now"
105
	;;
106
*-apple-darwin*)
107 108 109 110
	# Starting with OSX 10.7 (Lion) we must choose which IPv6 API to use
	# (RFC2292 or RFC3542).
	CPPFLAGS="$CPPFLAGS -D__APPLE_USE_RFC_3542"

Jeremy C. Reed's avatar
Jeremy C. Reed committed
111
	# libtool doesn't work perfectly with Darwin: libtool embeds the
112 113 114 115 116 117 118 119
	# final install path in dynamic libraries and our loadable python
	# modules always refer to that path even if it's loaded within the
	# source tree.  This prevents pre-install tests from working.
	# To work around this problem we explicitly specify paths to dynamic
	# libraries when we use them in the source tree.
	SET_ENV_LIBRARY_PATH=yes
	ENV_LIBRARY_PATH=DYLD_LIBRARY_PATH
	;;
120 121 122
*-freebsd*)
	SET_ENV_LIBRARY_PATH=yes
	;;
123 124 125
*-netbsd*)
	SET_ENV_LIBRARY_PATH=yes
	;;
126
esac
127 128 129
AM_CONDITIONAL(SET_ENV_LIBRARY_PATH, test $SET_ENV_LIBRARY_PATH = yes)
AC_SUBST(SET_ENV_LIBRARY_PATH)
AC_SUBST(ENV_LIBRARY_PATH)
130

131
m4_define([_AM_PYTHON_INTERPRETER_LIST], [python python3 python3.1 python3.2])
132 133
AC_ARG_WITH([pythonpath],
AC_HELP_STRING([--with-pythonpath=PATH],
134
  [specify an absolute path to python executable when automatic version check (incorrectly) fails]),
135 136 137 138
  [python_path="$withval"], [python_path="auto"])
if test "$python_path" = auto; then
	AM_PATH_PYTHON([3.1])
else
139 140
	# Older versions of automake can't handle python3 well.  This is an
	# in-house workaround for them.
141 142
	PYTHON=$python_path
	AC_SUBST(PYTHON)
143 144 145 146
	PYTHON_PREFIX='${prefix}'
	AC_SUBST(PYTHON_PREFIX)
	PYTHON_EXEC_PREFIX='$(exec_prefix)'
	AC_SUBST(PYTHON_EXEC_PREFIX)
147 148 149 150
	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
151 152
	AC_SUBST(PYTHON_VERSION)
	PYTHON_PLATFORM=`$PYTHON -c "import sys; print(sys.platform)"`
153
	AC_SUBST(PYTHON_PLATFORM)
154
	pythondir='${prefix}/lib/python'$PYTHON_VERSION'/site-packages'
155
	AC_SUBST(pythondir)
156
	pkgpythondir='${pythondir}/'$PACKAGE
157
	AC_SUBST(pkgpythondir)
158
	pyexecdir='${exec_prefix}/lib/python'$PYTHON_VERSION'/site-packages'
159
	AC_SUBST(pyexecdir)
160
	pkgpyexecdir='${pyexecdir}/'$PACKAGE
161
	AC_SUBST(pkgpyexecdir)
162
fi
163

164 165 166 167 168 169 170 171 172 173
# We need to store the default pyexecdir in a separate variable so that
# we can specify in Makefile.am the install directory of various BIND 10
# python scripts and loadable modules; in Makefile.am we cannot replace
# $(pyexecdir) using itself, e.g, this doesn't work:
# pyexecdir = $(pyexecdir)/isc/some_module
# The separate variable makes this setup possible as follows:
# pyexecdir = $(PYTHON_SITEPKG_DIR)/isc/some_module
PYTHON_SITEPKG_DIR=${pyexecdir}
AC_SUBST(PYTHON_SITEPKG_DIR)

174
# This will be commonly used in various Makefile.am's that need to generate
175 176 177 178 179 180 181 182 183
# python log messages.
PYTHON_LOGMSGPKG_DIR="\$(top_builddir)/src/lib/python/isc/log_messages"
AC_SUBST(PYTHON_LOGMSGPKG_DIR)

# This is python package paths commonly used in python tests.  See
# README of log_messages for why it's included.
COMMON_PYTHON_PATH="\$(abs_top_builddir)/src/lib/python/isc/log_messages:\$(abs_top_srcdir)/src/lib/python:\$(abs_top_builddir)/src/lib/python"
AC_SUBST(COMMON_PYTHON_PATH)

184 185 186
# Check for python development environments
if test -x ${PYTHON}-config; then
	PYTHON_INCLUDES=`${PYTHON}-config --includes`
187

188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204
	for flag in `${PYTHON}-config --ldflags`; do
		# add any '-L..." flags to PYTHON_LDFLAGS
		flag=`echo $flag | sed -ne 's/^\(\-L.*\)$/\1/p'`
		if test "X${flag}" != X; then
			PYTHON_LDFLAGS="$PYTHON_LDFLAGS ${flag}"
		fi
	done
	# on some platforms, ${PYTHON}-config --ldflags doesn't provide a -L
	# option while having the library under a non trivial directory.
	# as a workaround we try the "lib" sub directory under the common
	# prefix for this python.
	if test -z "${PYTHON_LDFLAGS}"; then
		PYTHON_LDFLAGS="-L`${PYTHON}-config --prefix`/lib"
	fi
else
	if test "X$PYTHON_INCLUDES" = X -o "X$PYTHON_LDFLAGS" = X; then
		AC_MSG_WARN([${PYTHON}-config does not exist or is not executable, so we could not detect python development environment.  Your system may require an additional package (e.g. "python3-dev").  Alternatively, if you are sure you have python headers and libraries, define PYTHON_INCLUDES and PYTHON_LDFLAGS and run this script.])
205 206
	fi
fi
207

208 209 210 211
# Some OSes including NetBSD don't install libpython.so in a well known path.
# To avoid requiring dynamic library path with our python wrapper loadable
# modules, we embed the path to the modules when possible.  We do this even
# when the path is known in the common operational environment (e.g. when
Jeremy C. Reed's avatar
Jeremy C. Reed committed
212
# it's stored in a common "hint" file) for simplicity.
213
if test $rpath_flag != no; then
214 215
	python_rpath=
	for flag in ${PYTHON_LDFLAGS}; do
216
		python_rpath="${python_rpath} `echo $flag | sed -ne "s/^\(\-L\)/${rpath_flag}/p"`"
217 218 219 220
	done
	PYTHON_LDFLAGS="${PYTHON_LDFLAGS} ${python_rpath}"
fi

221 222 223
AC_SUBST(PYTHON_INCLUDES)
AC_SUBST(PYTHON_LDFLAGS)

224 225 226 227 228
CPPFLAGS_SAVED="$CPPFLAGS"
CPPFLAGS="$CPPFLAGS ${PYTHON_INCLUDES}"
AC_CHECK_HEADERS([Python.h],, AC_MSG_ERROR([Missing Python.h]))
CPPFLAGS="$CPPFLAGS_SAVED"

229
# Check for python library.  Needed for Python-wrapper libraries.
230 231 232 233 234 235 236 237
LDFLAGS_SAVED="$LDFLAGS"
LDFLAGS="$LDFLAGS $PYTHON_LDFLAGS"
python_bin="python${PYTHON_VERSION}"
AC_CHECK_LIB($python_bin, main, python_lib=$python_bin, python_lib=no)
if test $python_lib != "no"; then
	PYTHON_LIB="-l$python_lib"
fi
AC_SUBST(PYTHON_LIB)
238
LDFLAGS=$LDFLAGS_SAVED
239

Michal Vaner's avatar
Michal Vaner committed
240 241 242 243 244 245 246
# Check for the setproctitle module
if test "$setproctitle_check" = "yes" ; then
    AC_MSG_CHECKING(for setproctitle module)
    if "$PYTHON" -c 'import setproctitle' 2>/dev/null ; then
        AC_MSG_RESULT(ok)
    else
        AC_MSG_RESULT(missing)
247 248 249
        AC_MSG_WARN([Missing setproctitle python module.
Use --disable-setproctitle-check to skip this check.
In this case we will continue, but naming of python processes will not work.])
Michal Vaner's avatar
Michal Vaner committed
250 251 252
    fi
fi

253 254
# TODO: check for _sqlite3.py module

255 256
# Compiler dependent settings: define some mandatory CXXFLAGS here.
# We also use a separate variable B10_CXXFLAGS.  This will (and should) be
Jeremy C. Reed's avatar
Jeremy C. Reed committed
257
# used as the default value for each specific AM_CXXFLAGS:
258 259 260 261 262 263 264 265
# AM_CXXFLAGS = $(B10_CXXFLAGS)
# 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.

266
# This may be used to try linker flags.
267 268 269 270 271 272
AC_DEFUN([BIND10_CXX_TRY_FLAG], [
  AC_MSG_CHECKING([whether $CXX supports $1])

  bind10_save_CXXFLAGS="$CXXFLAGS"
  CXXFLAGS="$CXXFLAGS $1"

273
  AC_LINK_IFELSE([AC_LANG_SOURCE([int main(void){ return 0;}])],
274
                 [bind10_cxx_flag=yes], [bind10_cxx_flag=no])
275 276
  CXXFLAGS="$bind10_save_CXXFLAGS"

277 278 279 280 281 282
  if test "x$bind10_cxx_flag" = "xyes"; then
    ifelse([$2], , :, [$2])
  else
    ifelse([$3], , :, [$3])
  fi

283 284 285
  AC_MSG_RESULT([$bind10_cxx_flag])
])

286 287 288 289
# SunStudio compiler requires special compiler options for boost
# (http://blogs.sun.com/sga/entry/boost_mini_howto)
if test "$SUNCXX" = "yes"; then
CXXFLAGS="$CXXFLAGS -library=stlport4 -features=tmplife -features=tmplrefstatic"
290
MULTITHREADING_FLAG="-mt"
291 292
fi

293
BIND10_CXX_TRY_FLAG([-Wno-missing-field-initializers],
294 295 296
	[WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG="-Wno-missing-field-initializers"])
AC_SUBST(WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG)

297
# gcc specific settings:
298
if test "X$GXX" = "Xyes"; then
299
B10_CXXFLAGS="-Wall -Wextra -Wwrite-strings -Woverloaded-virtual -Wno-sign-compare"
300 301 302
case "$host" in
*-solaris*)
	MULTITHREADING_FLAG=-pthreads
303 304
	# In Solaris, IN6ADDR_ANY_INIT and IN6ADDR_LOOPBACK_INIT need -Wno-missing-braces
	B10_CXXFLAGS="$B10_CXXFLAGS -Wno-missing-braces"
305 306 307 308 309
	;;
*)
	MULTITHREADING_FLAG=-pthread
	;;
esac
310

311 312
# Don't use -Werror if configured not to
AC_ARG_WITH(werror,
313
    AC_HELP_STRING([--with-werror], [Compile using -Werror (default=yes)]),
314 315 316 317 318 319 320 321 322 323
    [
     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

324 325 326
# 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.
327 328 329 330 331 332
if test $with_werror = 1; then
   CXXFLAGS_SAVED="$CXXFLAGS"
   CXXFLAGS="$CXXFLAGS $B10_CXXFLAGS -Werror"
   AC_MSG_CHECKING(for in-TU anonymous namespace breakage)
   AC_TRY_COMPILE([namespace { class Foo {}; }
   namespace isc {class Bar {Foo foo_;};} ],,
333
	[AC_MSG_RESULT(no)
334 335
	 werror_ok=1
	 B10_CXXFLAGS="$B10_CXXFLAGS -Werror"],
336
	[AC_MSG_RESULT(yes)])
337 338
   CXXFLAGS="$CXXFLAGS_SAVED"
fi
339

340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368
# Python 3.2 has an unused parameter in one of its headers. This
# has been reported, but not fixed as of yet, so we check if we need
# to set -Wno-unused-parameter.
if test $werror_ok = 1; then
	CPPFLAGS_SAVED="$CPPFLAGS"
	CPPFLAGS=${PYTHON_INCLUDES}
	CXXFLAGS_SAVED="$CXXFLAGS"
	CXXFLAGS="$CXXFLAGS $B10_CXXFLAGS -Werror"
	AC_MSG_CHECKING([whether we need -Wno-unused-parameter for python])
	AC_TRY_COMPILE(
		[#include <Python.h>],
		[],
		[AC_MSG_RESULT(no)],
		[
		CXXFLAGS="$CXXFLAGS -Wno-unused-parameter"
		AC_TRY_COMPILE([#include <Python.h>],
		[],
		[AC_MSG_RESULT(yes)
		 PYTHON_CXXFLAGS="${PYTHON_CXXFLAGS} -Wno-unused-parameter"
		 AC_SUBST(PYTHON_CXXFLAGS)
		],
		[AC_MSG_ERROR([Can't compile against Python.h])]
                )
                ]
	)
	CXXFLAGS="$CXXFLAGS_SAVED"
	CPPFLAGS="$CPPFLAGS_SAVED"
fi

369
fi				dnl GXX = yes
370

371
AM_CONDITIONAL(GCC_WERROR_OK, test $werror_ok = 1)
372 373

# produce PIC unless we disable shared libraries. need this for python bindings.
374
if test $enable_shared != "no" -a "X$GXX" = "Xyes"; then
375
   B10_CXXFLAGS="$B10_CXXFLAGS -fPIC"
376 377
fi

378 379
AC_SUBST(B10_CXXFLAGS)

380 381
# Checks for libraries.

382 383
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
384
AC_SEARCH_LIBS(nanosleep, [rt])
385

386 387 388 389 390 391
# Checks for header files.

# Checks for typedefs, structures, and compiler characteristics.
AC_HEADER_STDBOOL
AC_TYPE_SIZE_T

392

393 394 395 396 397 398
# Detect OS type (it may be used to do OS-specific things, e.g.
# interface detection in DHCP)
AC_MSG_CHECKING(OS family)
system=`uname -s`
case $system in
    Linux)
399
      OS_TYPE="Linux"
400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415
      CPPFLAGS="$CPPFLAGS -DOS_LINUX"
      ;;
    Darwin | FreeBSD | NetBSD | OpenBSD)
      OS_TYPE="BSD"
      CPPFLAGS="$CPPFLAGS -DOS_BSD"
      ;;
    Solaris)
      OS_TYPE="Solaris"
      CPPFLAGS="$CPPFLAGS -DOS_SOLARIS"
      ;;
    *)
      OS_TYPE="Unknown"
      AC_MSG_WARN("Unsupported OS: uname returned $system")
      ;;
esac
AC_MSG_RESULT($OS_TYPE)
416 417 418

AM_CONDITIONAL(OS_LINUX, test $OS_TYPE = Linux)
AM_COND_IF([OS_LINUX], [AC_DEFINE([OS_LINUX], [1], [Running on Linux?])])
419
AM_CONDITIONAL(OS_BSD, test $OS_TYPE = BSD)
420
AM_COND_IF([OS_BSD], [AC_DEFINE([OS_BSD], [1], [Running on BSD?])])
421
AM_CONDITIONAL(OS_SOLARIS, test $OS_TYPE = Solaris)
422
AM_COND_IF([OS_SOLARIS], [AC_DEFINE([OS_SOLARIS], [1], [Running on Solaris?])])
423

424 425 426 427 428 429
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)
430
        AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
431 432
        AC_MSG_RESULT(no))

433 434
AC_ARG_WITH(pycoverage,
[  --with-pycoverage[=PROGRAM]         enable python code coverage using the specified coverage], pycoverage="$withval", pycoverage="no")
435 436 437 438 439 440 441 442
if test "$pycoverage" = "no" ; then
	# just run the tests normally with python
	PYCOVERAGE_RUN="${PYTHON}"
	USE_PYCOVERAGE="no"
elif test "$pycoverage" = "yes" ; then
	PYCOVERAGE="coverage"
	PYCOVERAGE_RUN="${PYCOVERAGE} run --branch --append"
	USE_PYCOVERAGE="yes"
443
else
444 445 446
	PYCOVERAGE="$pycoverage"
	PYCOVERAGE_RUN="${PYCOVERAGE} run --branch --append"
	USE_PYCOVERAGE="yes"
447
fi
448
AM_CONDITIONAL(ENABLE_PYTHON_COVERAGE, test x$USE_PYCOVERAGE != xno)
449
AC_SUBST(PYCOVERAGE)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
450
AC_SUBST(PYCOVERAGE_RUN)
451
AC_SUBST(USE_PYCOVERAGE)
452

453
AC_ARG_WITH(lcov,
454
[  --with-lcov[=PROGRAM]         enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
455

456
AC_ARG_WITH(gtest,
457
[  --with-gtest=PATH       specify a path to gtest header files (PATH/include) and library (PATH/lib)],
458
    gtest_path="$withval", gtest_path="no")
459 460 461 462 463

USE_LCOV="no"
if test "$lcov" != "no"; then
	# force gtest if not set
	if test "$gtest_path" = "no"; then
464 465
#		AC_MSG_ERROR("lcov needs gtest for test coverage report")
		AC_MSG_NOTICE([gtest support is now enabled, because used by coverage tests])
466 467 468
		gtest_path="yes"
	fi
	if test "$lcov" != "yes"; then
469
		LCOV=$lcov
470
	else
471
		AC_PATH_PROG([LCOV], [lcov])
472
	fi
473 474 475 476
	if test -x "${LCOV}"; then
		USE_LCOV="yes"
	else
		AC_MSG_ERROR([Cannot find lcov.])
477 478 479 480 481 482
	fi
	# is genhtml always in the same directory?
	GENHTML=`echo "$LCOV" | sed s/lcov$/genhtml/`
	if test ! -x $GENHTML; then
		AC_MSG_ERROR([genhtml not found, needed for lcov])
	fi
483
	# GCC specific?
484
	CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
485
	LIBS=" $LIBS -lgcov"
486 487 488 489 490 491 492
	AC_SUBST(CPPFLAGS)
	AC_SUBST(LIBS)
	AC_SUBST(LCOV)
	AC_SUBST(GENHTML)
fi
AC_SUBST(USE_LCOV)

493 494 495 496
# 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
497 498
# is set to that. If not, the value is untouched.
# Does not take absolute paths into account at this point,
499 500 501 502 503
# 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"
504
    IFS=${PATH_SEPARATOR}
505 506 507 508 509 510
    for cur_path in ${PATH} ; do
      if test -e "${cur_path}/$2" ; then
          RESULT="${cur_path}/$2"
      fi
    done
    if test "$RESULT" = "" ; then
511
        :
512 513 514 515 516 517 518 519
        m4_ifvaln([$3], [$1=$3])
    else
        $1=$RESULT
    fi
    IFS="$IFS_SAVED"
])

# Botan helper test function
520 521
# Tries to compile a botan program, given the output of the given
# config tool
522 523 524 525 526 527 528 529
# 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=""
530 531
    ACX_CHECK_PROG_NONCACHE([BOTAN_TOOL], [${TOOL}])
    AC_MSG_CHECKING([usability of ${TOOL} ${TOOL_ARG}])
532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551
    if test "$BOTAN_TOOL" != "" ; then
        if test -x ${BOTAN_TOOL}; then
            BOTAN_LIBS=`$BOTAN_TOOL $TOOL_ARG --libs`
            LIBS_SAVED=${LIBS}
            LIBS="$LIBS $BOTAN_LIBS"
            BOTAN_INCLUDES=`$BOTAN_TOOL $TOOL_ARG --cflags`
            CPPFLAGS_SAVED=${CPPFLAGS}
            CPPFLAGS="$BOTAN_INCLUDES $CPPFLAGS"
            #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
                ],
552
                [ AC_MSG_RESULT([not usable]) ]
553 554 555 556 557 558 559 560 561 562 563 564 565 566
            )
            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)
    ]
)

Jelte Jansen's avatar
Jelte Jansen committed
567
# Check for Botan
568 569 570 571 572 573 574 575 576 577 578 579 580 581 582
#
# 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).
#
583 584 585 586 587 588
botan_config="yes"
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
Jelte Jansen's avatar
Jelte Jansen committed
589
    AC_MSG_ERROR([Need botan for libcryptolink])
Jelte Jansen's avatar
Jelte Jansen committed
590
fi
591 592 593 594 595 596 597
if test "${botan_config}" != "yes" ; then
    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
Jelte Jansen's avatar
Jelte Jansen committed
598
    else
599
        AC_MSG_ERROR([--with-botan-config should point to a botan-config program and not a directory (${botan_config})])
Jelte Jansen's avatar
Jelte Jansen committed
600 601
    fi
else
602
    BOTAN_CONFIG=""
603
    # first try several possible names of the config script
604 605
    # (botan-config-1.8 is there just in case, the official name change
    # came later)
606 607
    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
608
        ACX_TRY_BOTAN_TOOL([$botan_config],,
609
                           [ BOTAN_CONFIG="$botan_config"  ]
610 611
                          )
        if test "$BOTAN_CONFIG" != "" ; then
612 613 614
            break
        fi
    done
615
    if test "$BOTAN_CONFIG" = "" ; then
616 617 618 619 620 621 622
        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
623
                ACX_TRY_BOTAN_TOOL([pkg-config], ["$version --silence-errors"],
624
                                   [ BOTAN_CONFIG="$PKG_CONFIG $version" ]
625 626
                                  )
            if test "$BOTAN_CONFIG" != "" ; then
627 628
                break
            fi
629 630
            done
        fi
631
    fi
Jelte Jansen's avatar
Jelte Jansen committed
632
fi
633

634 635 636 637 638 639 640 641 642 643 644 645 646 647 648
if test "x${BOTAN_CONFIG}" != "x"
then
    BOTAN_LIBS=`${BOTAN_CONFIG} --libs`
    BOTAN_INCLUDES=`${BOTAN_CONFIG} --cflags`

    # 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).
    # Same for BOTAN_INCLUDES (but using include instead of lib) below.
    if [ ${BOTAN_CONFIG} --prefix >/dev/null 2>&1 ] ; then
        echo ${BOTAN_LIBS} | grep -- -L > /dev/null || \
            BOTAN_LIBS="-L`${BOTAN_CONFIG} --prefix`/lib ${BOTAN_LIBS}"
        echo ${BOTAN_INCLUDES} | grep -- -I > /dev/null || \
            BOTAN_INCLUDES="-I`${BOTAN_CONFIG} --prefix`/include ${BOTAN_INCLUDES}"
    fi
Jelte Jansen's avatar
Jelte Jansen committed
649
fi
650 651 652 653 654 655 656 657 658
# botan-config script (and the way we call pkg-config) returns -L and -l
# as one string, but we need them in separate values
BOTAN_LDFLAGS=
BOTAN_NEWLIBS=
for flag in ${BOTAN_LIBS}; do
    BOTAN_LDFLAGS="${BOTAN_LDFLAGS} `echo $flag | sed -ne '/^\(\-L\)/p'`"
    BOTAN_LIBS="${BOTAN_LIBS} `echo $flag | sed -ne '/^\(\-l\)/p'`"
done

659
# See python_rpath for some info on why we do this
660
if test $rpath_flag != no; then
661
    BOTAN_RPATH=
662
    for flag in ${BOTAN_LIBS}; do
663
            BOTAN_RPATH="${BOTAN_RPATH} `echo $flag | sed -ne "s/^\(\-L\)/${rpath_flag}/p"`"
664 665 666 667 668 669 670 671 672 673 674 675 676 677
    done
AC_SUBST(BOTAN_RPATH)

# 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="$BOTAN_RPATH $LDFLAGS"
fi

AC_SUBST(BOTAN_LDFLAGS)
678
AC_SUBST(BOTAN_LIBS)
679
AC_SUBST(BOTAN_INCLUDES)
680

681 682 683
# 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.
684 685
CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$BOTAN_INCLUDES $CPPFLAGS"
686
LIBS_SAVED="$LIBS"
687
LIBS="$LIBS $BOTAN_LIBS"
Jelte Jansen's avatar
Jelte Jansen committed
688 689
AC_CHECK_HEADERS([botan/botan.h],,AC_MSG_ERROR([Missing required header files.]))
AC_LINK_IFELSE(
690 691 692
        [AC_LANG_PROGRAM([#include <botan/botan.h>
                          #include <botan/hash.h>
                         ],
Jelte Jansen's avatar
Jelte Jansen committed
693 694
                         [using namespace Botan;
                          LibraryInitializer::initialize();
695
                          HashFunction *h = get_hash("MD5");
Jelte Jansen's avatar
Jelte Jansen committed
696 697 698
                         ])],
        [AC_MSG_RESULT([checking for Botan library... yes])],
        [AC_MSG_RESULT([checking for Botan library... no])
699 700 701 702 703
         AC_MSG_ERROR([Needs Botan library 1.8 or higher. On some systems,
         the botan package has a few missing dependencies (libbz2 and
         libgmp), if libbotan has been installed and you see this error,
         try upgrading to a higher version of botan or installing libbz2
         and libgmp.])]
Jelte Jansen's avatar
Jelte Jansen committed
704
)
705
CPPFLAGS=$CPPFLAGS_SAVED
706
LIBS=$LIBS_SAVED
Jelte Jansen's avatar
Jelte Jansen committed
707

708 709 710 711 712 713
# 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"])
714
if test "${log4cplus_path}" = "no" ; then
715 716 717
    AC_MSG_ERROR([Need log4cplus])
elif test "${log4cplus_path}" != "yes" ; then
  LOG4CPLUS_INCLUDES="-I${log4cplus_path}/include"
718
  LOG4CPLUS_LIBS="-L${log4cplus_path}/lib"
719 720 721 722 723 724 725
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"
726
			LOG4CPLUS_LIBS="-L$d/lib"
727 728 729 730 731
			break
		fi
	done
fi

732
LOG4CPLUS_LIBS="$LOG4CPLUS_LIBS -llog4cplus $MULTITHREADING_FLAG"
733

734
AC_SUBST(LOG4CPLUS_LIBS)
735 736 737 738
AC_SUBST(LOG4CPLUS_INCLUDES)

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$LOG4CPLUS_INCLUDES $CPPFLAGS"
739
LIBS_SAVED="$LIBS"
740
LIBS="$LOG4CPLUS_LIBS $LIBS"
741 742 743 744 745 746 747 748 749 750 751 752 753 754

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])]
)

CPPFLAGS=$CPPFLAGS_SAVED
755
LIBS=$LIBS_SAVED
756

757 758 759 760
#
# Configure Boost header path
#
# If explicitly specified, use it.
761 762 763 764
AC_ARG_WITH([boost-include],
  AC_HELP_STRING([--with-boost-include=PATH],
    [specify exact directory for Boost headers]),
    [boost_include_path="$withval"])
765 766 767 768 769 770 771 772 773 774 775
# If not specified, try some common paths.
if test -z "$with_boost_include"; then
	boostdirs="/usr/local /usr/pkg /opt /opt/local"
	for d in $boostdirs
	do
		if test -f $d/include/boost/shared_ptr.hpp; then
			boost_include_path=$d/include
			break
		fi
	done
fi
776
CPPFLAGS_SAVES="$CPPFLAGS"
777
if test "${boost_include_path}" ; then
778 779
	BOOST_INCLUDES="-I${boost_include_path}"
	CPPFLAGS="$CPPFLAGS $BOOST_INCLUDES"
780
fi
781
AC_CHECK_HEADERS([boost/shared_ptr.hpp boost/foreach.hpp boost/interprocess/sync/interprocess_upgradable_mutex.hpp boost/date_time/posix_time/posix_time_types.hpp boost/bind.hpp boost/function.hpp],,
782
  AC_MSG_ERROR([Missing required header files.]))
783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798

# Detect whether Boost tries to use threads by default, and, if not,
# make it sure explicitly.  In some systems the automatic detection
# may depend on preceding header files, and if inconsistency happens
# it could lead to a critical disruption.
AC_MSG_CHECKING([whether Boost tries to use threads])
AC_TRY_COMPILE([
#include <boost/config.hpp>
#ifdef BOOST_HAS_THREADS
#error "boost will use threads"
#endif],,
[AC_MSG_RESULT(no)
 CPPFLAGS_BOOST_THREADCONF="-DBOOST_DISABLE_THREADS=1"],
[AC_MSG_RESULT(yes)])

CPPFLAGS="$CPPFLAGS_SAVES $CPPFLAGS_BOOST_THREADCONF"
799
AC_SUBST(BOOST_INCLUDES)
800

801 802 803 804 805 806 807
# I can't get some of the #include <asio.hpp> right without this
# TODO: find the real cause of asio/boost wanting pthreads
# (this currently only occurs for src/lib/cc/session_unittests)
PTHREAD_LDFLAGS=
AC_CHECK_LIB(pthread, pthread_create,[ PTHREAD_LDFLAGS=-lpthread ], [])
AC_SUBST(PTHREAD_LDFLAGS)
AC_SUBST(MULTITHREADING_FLAG)
808

809
#
810
# Check availability of gtest, which will be used for unit tests.
811
#
812
if test "$gtest_path" != "no"
813
then
814
	DISTCHECK_GTEST_CONFIGURE_FLAG="--with-gtest=\"$gtest_path\""
815 816
	if test "$gtest_path" != "yes"; then
		GTEST_PATHS=$gtest_path
817 818 819
		if test -x "${gtest_path}/bin/gtest-config" ; then
			GTEST_CONFIG="${gtest_path}/bin/gtest-config"
		fi
820
	else
821
		AC_PATH_PROG([GTEST_CONFIG], [gtest-config])
822
	fi
823 824 825 826 827 828 829 830 831 832
	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_FOUND="true"
	else
		AC_MSG_WARN([Unable to locate Google Test gtest-config.])
		if test -z "${GTEST_PATHS}" ; then
			GTEST_PATHS="/usr /usr/local"
833
		fi
834 835 836 837 838 839 840 841 842 843
		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"
844 845
				# There is no gtest-config script on this
				# system, which is supposed to inform us
Jeremy C. Reed's avatar
Jeremy C. Reed committed
846
				# whether we need pthreads as well (a
847 848
				# gtest compile-time option). So we still
				# need to test that manually.
849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885
				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
886 887 888 889 890
				break
			fi
		done
	fi
	if test "${GTEST_FOUND}" != "true"; then
891 892
		AC_MSG_ERROR([Cannot find gtest in: $GTEST_PATHS])
	fi
893
else
894 895 896
	GTEST_INCLUDES=
	GTEST_LDFLAGS=
	GTEST_LDADD=
897
	DISTCHECK_GTEST_CONFIGURE_FLAG=
898
fi
899
AM_CONDITIONAL(HAVE_GTEST, test $gtest_path != "no")
900
AC_SUBST(DISTCHECK_GTEST_CONFIGURE_FLAG)
901 902 903
AC_SUBST(GTEST_INCLUDES)
AC_SUBST(GTEST_LDFLAGS)
AC_SUBST(GTEST_LDADD)
904

905 906 907 908 909
dnl check for pkg-config itself so we don't try the m4 macro without pkg-config
AC_CHECK_PROG(HAVE_PKG_CONFIG, pkg-config, yes, no)
if test "x$HAVE_PKG_CONFIG" = "xno" ; then
  AC_MSG_ERROR(Please install pkg-config)
fi
910
PKG_CHECK_MODULES(SQLITE, sqlite3 >= 3.3.9, enable_features="$enable_features SQLite3")
911

912 913 914
#
# ASIO: we extensively use it as the C++ event management module.
#
915
# Use local ASIO headers from ext
916
#
917
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/asio"
918
#
919 920 921
# Use our 'coroutine' header from ext
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/coroutine"
#
922 923 924
# Disable threads: Currently we don't use them.
CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_THREADS=1"
#
925 926 927 928 929 930 931 932
# kqueue portability: ASIO uses kqueue by default if it's available (it's
# generally available in BSD variants).  Unfortunately, some public
# implementation of kqueue forces a conversion from a pointer to an integer,
# which is prohibited in C++ unless reinterpret_cast, C++'s most evil beast
# (and ASIO doesn't use it anyway) is used.  This will cause build error for
# some of our C++ files including ASIO header files.  The following check
# detects such cases and tells ASIO not to use kqueue if so.
AC_CHECK_FUNC(kqueue, ac_cv_have_kqueue=yes, ac_cv_have_kqueue=no)
933
if test "X$ac_cv_have_kqueue" = "Xyes"; then
934 935 936 937 938 939
	AC_MSG_CHECKING([whether kqueue EV_SET compiles in C++])
	AC_TRY_COMPILE([
#include <sys/types.h>
#include <sys/param.h>
#include <sys/event.h>],
[char* udata;
940 941
struct kevent kevent;
EV_SET(&kevent, 0, 0, 0, 0, 0, udata);],
942 943 944 945
	[AC_MSG_RESULT(yes)],
	[AC_MSG_RESULT([no, disable kqueue for ASIO])
	 CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_KQUEUE=1"
	])
946
fi
947

948
# Check for functions that are not available on all platforms
949 950
AC_CHECK_FUNCS([pselect])

951 952
# perfdhcp: If the clock_gettime() function does not exist on the system,
# use an alternative supplied in the code based on gettimeofday().
953 954 955 956
CLOCK_GETTIME_LDFLAGS=
AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_GETTIME_LDFLAGS=-lrt], [])
AC_SUBST([CLOCK_GETTIME_LDFLAGS])

957 958 959 960 961 962 963 964
# perfdhcp: if getifaddrs() does not exist, have the code output a message
# that it can't be run on this version of the operating system.  For the
# systems on which BIND 10 is built, this means Solaris 10. (Replacements
# for this function are long and involved, and the function is reported present
# on Solaris 11 and later, either in the libsocket or libnsl libraries.)
AC_SEARCH_LIBS([getifaddrs], [socket nsl],
               [AC_DEFINE([HAVE_GETIFADDRS], [1], [getifaddrs() present])])

965 966 967 968
# /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
969
# gcc don't provide an option to selectively suppress this warning.
970 971 972
# 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
Jeremy C. Reed's avatar
Jeremy C. Reed committed
973
# run time performance.  Hopefully we can find a better solution or the ASIO
974 975
# 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)
976
if test "X$ac_cv_have_devpoll" = "Xyes" -a "X$GXX" = "Xyes"; then
977 978
	CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_DEV_POLL=1"
fi
979

980 981 982 983 984
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)
985 986
AC_PATH_PROGS(AWK, gawk awk)
AC_SUBST(AWK)
987

988
AC_ARG_ENABLE(man, [AC_HELP_STRING([--enable-man],
989
  [regenerate man pages [default=no]])], enable_man=$enableval, enable_man=no)
990 991

AM_CONDITIONAL(ENABLE_MAN, test x$enable_man != xno)
992

993 994 995
AC_ARG_ENABLE(install-configurations,
  [AC_HELP_STRING([--disable-install-configurations],
  [do not install configuration])], install_configurations=$enableval, install_configurations=yes)
996

997
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
998

999
AC_CONFIG_FILES([Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1000
                 doc/Makefile
1001
                 doc/guide/Makefile
1002
                 compatcheck/Makefile
1003
                 src/Makefile
1004
                 src/bin/Makefile
1005
                 src/bin/bind10/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1006
                 src/bin/bind10/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1007
                 src/bin/cmdctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1008
                 src/bin/cmdctl/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1009
                 src/bin/bindctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1010
                 src/bin/bindctl/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1011
                 src/bin/cfgmgr/Makefile
1012
                 src/bin/cfgmgr/plugins/Makefile
1013
                 src/bin/cfgmgr/plugins/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1014
                 src/bin/cfgmgr/tests/Makefile
1015
                 src/bin/host/Makefile
Evan Hunt's avatar
Evan Hunt committed
1016
                 src/bin/loadzone/Makefile
1017 1018
                 src/bin/loadzone/tests/correct/Makefile
                 src/bin/loadzone/tests/error/Makefile
1019
                 src/bin/msgq/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1020
                 src/bin/msgq/tests/Makefile
1021
                 src/bin/auth/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1022
                 src/bin/auth/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1023
                 src/bin/auth/benchmarks/Makefile
1024 1025
                 src/bin/ddns/Makefile
                 src/bin/ddns/tests/Makefile
1026
                 src/bin/dhcp6/Makefile
1027
                 src/bin/dhcp6/tests/Makefile
1028 1029
		 src/bin/dhcp4/Makefile
		 src/bin/dhcp4/tests/Makefile
1030 1031
                 src/bin/resolver/Makefile
                 src/bin/resolver/tests/Makefile
1032 1033
                 src/bin/sockcreator/Makefile
                 src/bin/sockcreator/tests/Makefile
Likun Zhang's avatar
Likun Zhang committed
1034
                 src/bin/xfrin/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1035
                 src/bin/xfrin/tests/Makefile
1036
                 src/bin/xfrin/tests/testdata/Makefile
1037
                 src/bin/xfrout/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1038
                 src/bin/xfrout/tests/Makefile
1039 1040
                 src/bin/zonemgr/Makefile
                 src/bin/zonemgr/tests/Makefile
1041 1042
                 src/bin/stats/Makefile
                 src/bin/stats/tests/Makefile
1043
                 src/bin/usermgr/Makefile
Michal Vaner's avatar
Michal Vaner committed
1044
                 src/bin/tests/Makefile
1045
                 src/lib/Makefile
1046 1047
                 src/lib/asiolink/Makefile
                 src/lib/asiolink/tests/Makefile
Ocean Wang's avatar
Ocean Wang committed
1048
                 src/lib/asiodns/Makefile
1049
                 src/lib/asiodns/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1050 1051 1052
                 src/lib/bench/Makefile
                 src/lib/bench/example/Makefile
                 src/lib/bench/tests/Makefile
1053
                 src/lib/cc/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1054
                 src/lib/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1055 1056
                 src/lib/python/Makefile
                 src/lib/python/isc/Makefile
1057 1058
                 src/lib/python/isc/acl/Makefile
                 src/lib/python/isc/acl/tests/Makefile
1059 1060
                 src/lib/python/isc/util/Makefile
                 src/lib/python/isc/util/tests/Makefile
Michal 'vorner' Vaner's avatar
Michal 'vorner' Vaner committed
1061