configure.ac 48.4 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, 20120127, 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

88 89 90 91 92
AC_ARG_ENABLE(boost-threads,
AC_HELP_STRING([--enable-boost-threads],
  [use boost threads. Currently this only means using its locks instead of dummy locks, in the cache and NSAS]),
  use_boost_threads=$enableval, use_boost_threads=no)

Michal Vaner's avatar
Michal Vaner committed
93 94 95 96 97 98
# 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)

99 100 101 102
# OS dependent configuration
SET_ENV_LIBRARY_PATH=no
ENV_LIBRARY_PATH=LD_LIBRARY_PATH

103
case "$host" in
104 105 106 107
*-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
108 109
	# "now" binding is necessary to prevent deadlocks in C++ static initialization code
	LDFLAGS="$LDFLAGS -z now"
110
	;;
111
*-apple-darwin*)
112 113 114 115
	# 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
116
	# libtool doesn't work perfectly with Darwin: libtool embeds the
117 118 119 120 121 122 123 124
	# 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
	;;
125 126 127
*-freebsd*)
	SET_ENV_LIBRARY_PATH=yes
	;;
128 129 130
*-netbsd*)
	SET_ENV_LIBRARY_PATH=yes
	;;
131
esac
132 133 134
AM_CONDITIONAL(SET_ENV_LIBRARY_PATH, test $SET_ENV_LIBRARY_PATH = yes)
AC_SUBST(SET_ENV_LIBRARY_PATH)
AC_SUBST(ENV_LIBRARY_PATH)
135

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

169 170 171 172 173 174 175 176 177 178
# 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)

179
# This will be commonly used in various Makefile.am's that need to generate
180 181 182 183 184 185 186 187 188
# 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)

189 190 191
# Check for python development environments
if test -x ${PYTHON}-config; then
	PYTHON_INCLUDES=`${PYTHON}-config --includes`
192

193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209
	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.])
210 211
	fi
fi
212

213 214 215 216
# 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
217
# it's stored in a common "hint" file) for simplicity.
218
if test $rpath_flag != no; then
219 220
	python_rpath=
	for flag in ${PYTHON_LDFLAGS}; do
221
		python_rpath="${python_rpath} `echo $flag | sed -ne "s/^\(\-L\)/${rpath_flag}/p"`"
222 223 224 225
	done
	PYTHON_LDFLAGS="${PYTHON_LDFLAGS} ${python_rpath}"
fi

226 227 228
AC_SUBST(PYTHON_INCLUDES)
AC_SUBST(PYTHON_LDFLAGS)

229 230 231 232 233
CPPFLAGS_SAVED="$CPPFLAGS"
CPPFLAGS="$CPPFLAGS ${PYTHON_INCLUDES}"
AC_CHECK_HEADERS([Python.h],, AC_MSG_ERROR([Missing Python.h]))
CPPFLAGS="$CPPFLAGS_SAVED"

234
# Check for python library.  Needed for Python-wrapper libraries.
235 236 237 238 239 240 241 242
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)
243
LDFLAGS=$LDFLAGS_SAVED
244

Michal Vaner's avatar
Michal Vaner committed
245 246 247 248 249 250 251
# 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)
252 253 254
        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
255 256 257
    fi
fi

258 259
# TODO: check for _sqlite3.py module

260 261
# 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
262
# used as the default value for each specific AM_CXXFLAGS:
263 264 265 266 267 268 269 270
# 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.

271
# This may be used to try linker flags.
272 273 274 275 276 277
AC_DEFUN([BIND10_CXX_TRY_FLAG], [
  AC_MSG_CHECKING([whether $CXX supports $1])

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

278
  AC_LINK_IFELSE([int main(void){ return 0;}],
279
                 [bind10_cxx_flag=yes], [bind10_cxx_flag=no])
280 281
  CXXFLAGS="$bind10_save_CXXFLAGS"

282 283 284 285 286 287
  if test "x$bind10_cxx_flag" = "xyes"; then
    ifelse([$2], , :, [$2])
  else
    ifelse([$3], , :, [$3])
  fi

288 289 290
  AC_MSG_RESULT([$bind10_cxx_flag])
])

291 292 293 294
# 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"
295
MULTITHREADING_FLAG="-mt"
296 297
fi

298
BIND10_CXX_TRY_FLAG([-Wno-missing-field-initializers],
299 300 301
	[WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG="-Wno-missing-field-initializers"])
AC_SUBST(WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG)

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

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

329 330 331
# 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.
332 333 334 335 336 337
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_;};} ],,
338
	[AC_MSG_RESULT(no)
339 340
	 werror_ok=1
	 B10_CXXFLAGS="$B10_CXXFLAGS -Werror"],
341
	[AC_MSG_RESULT(yes)])
342 343
   CXXFLAGS="$CXXFLAGS_SAVED"
fi
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 369 370 371 372 373
# 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

374
fi				dnl GXX = yes
375

376
AM_CONDITIONAL(GCC_WERROR_OK, test $werror_ok = 1)
377 378

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

383 384
AC_SUBST(B10_CXXFLAGS)

385 386
# Checks for libraries.

387 388
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
389
AC_SEARCH_LIBS(nanosleep, [rt])
390

391 392 393 394 395 396
# Checks for header files.

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

397

398 399 400 401 402 403
# 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)
404
      OS_TYPE="Linux"
405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420
      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)
421 422 423

AM_CONDITIONAL(OS_LINUX, test $OS_TYPE = Linux)
AM_COND_IF([OS_LINUX], [AC_DEFINE([OS_LINUX], [1], [Running on Linux?])])
424
AM_CONDITIONAL(OS_BSD, test $OS_TYPE = BSD)
425
AM_COND_IF([OS_BSD], [AC_DEFINE([OS_BSD], [1], [Running on BSD?])])
426
AM_CONDITIONAL(OS_SOLARIS, test $OS_TYPE = Solaris)
427
AM_COND_IF([OS_SOLARIS], [AC_DEFINE([OS_SOLARIS], [1], [Running on Solaris?])])
428

429 430 431 432 433 434
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)
435
        AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
436 437
        AC_MSG_RESULT(no))

438 439
AC_ARG_WITH(pycoverage,
[  --with-pycoverage[=PROGRAM]         enable python code coverage using the specified coverage], pycoverage="$withval", pycoverage="no")
440 441 442 443 444 445 446 447
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"
448
else
449 450 451
	PYCOVERAGE="$pycoverage"
	PYCOVERAGE_RUN="${PYCOVERAGE} run --branch --append"
	USE_PYCOVERAGE="yes"
452
fi
453
AM_CONDITIONAL(ENABLE_PYTHON_COVERAGE, test x$USE_PYCOVERAGE != xno)
454
AC_SUBST(PYCOVERAGE)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
455
AC_SUBST(PYCOVERAGE_RUN)
456
AC_SUBST(USE_PYCOVERAGE)
457

458
AC_ARG_WITH(lcov,
459
[  --with-lcov[=PROGRAM]         enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
460

461
AC_ARG_WITH(gtest,
462
[  --with-gtest=PATH       specify a path to gtest header files (PATH/include) and library (PATH/lib)],
463
    gtest_path="$withval", gtest_path="no")
464 465 466 467 468

USE_LCOV="no"
if test "$lcov" != "no"; then
	# force gtest if not set
	if test "$gtest_path" = "no"; then
469 470
#		AC_MSG_ERROR("lcov needs gtest for test coverage report")
		AC_MSG_NOTICE([gtest support is now enabled, because used by coverage tests])
471 472 473
		gtest_path="yes"
	fi
	if test "$lcov" != "yes"; then
474
		LCOV=$lcov
475
	else
476
		AC_PATH_PROG([LCOV], [lcov])
477
	fi
478 479 480 481
	if test -x "${LCOV}"; then
		USE_LCOV="yes"
	else
		AC_MSG_ERROR([Cannot find lcov.])
482 483 484 485 486 487
	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
488
	# GCC specific?
489
	CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
490
	LIBS=" $LIBS -lgcov"
491 492 493 494 495 496 497
	AC_SUBST(CPPFLAGS)
	AC_SUBST(LIBS)
	AC_SUBST(LCOV)
	AC_SUBST(GENHTML)
fi
AC_SUBST(USE_LCOV)

498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574
# 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
# is set to that.
# Does not take full paths into account at this point,
# 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"
    IFS=":"
    for cur_path in ${PATH} ; do
      if test -e "${cur_path}/$2" ; then
          RESULT="${cur_path}/$2"
      fi
    done
    if test "$RESULT" = "" ; then
        m4_ifvaln([$3], [$1=$3])
    else
        $1=$RESULT
    fi
    IFS="$IFS_SAVED"
])

# Botan helper test function
# Tries to compile a program, given the output of the given
# Arguments:
# - name of tool (checked for path), must support --libs and --cflags
# - fixed argument(s) for tool
# - action if successful
# - action if failed
AC_DEFUN([ACX_TRY_BOTAN_TOOL], [
    TOOL=$1
    TOOL_ARG=$2
    BOTAN_TOOL=""
    ACX_CHECK_PROG_NONCACHE([BOTAN_TOOL], [${TOOL}], [""])
    AC_MSG_CHECKING([for usability of ${TOOL} ${TOOL_ARG}])
    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
                ],
                [ AC_MSG_RESULT([not usable])
                  $4
                ]
            )
            LIBS=${LIBS_SAVED}
            CPPFLAGS=${CPPFLAGS_SAVED}
        else
            AC_MSG_RESULT([not executable])
            $4
        fi
    else
        AC_MSG_RESULT([not found])
        $4
    fi
    BOTAN_TOOL=""
    AC_SUBST(BOTAN_TOOL)
    ]
)

Jelte Jansen's avatar
Jelte Jansen committed
575
# Check for Botan
576 577 578 579 580 581
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
582
    AC_MSG_ERROR([Need botan for libcryptolink])
Jelte Jansen's avatar
Jelte Jansen committed
583
fi
584 585 586 587 588 589 590
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
591
    else
592
            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
593 594
    fi
else
595
    BOTAN_CONFIG=""
596 597 598 599
    # first try several possible names of the config script
    # (1.8 is there just in case)
    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
600 601 602 603 604
        ACX_TRY_BOTAN_TOOL([$botan_config],,
                           [ BOTAN_CONFIG="$botan_config"  ],
                           []
                          )
        if test "$BOTAN_CONFIG" != "" ; then
605 606 607
            break
        fi
    done
608
    if test "$BOTAN_CONFIG" = "" ; then
609 610 611 612 613 614 615
        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
616 617 618 619 620 621 622
                ACX_TRY_BOTAN_TOOL([pkg-config], ["$version --silence-errors"],
                                   [ BOTAN_CONFIG="$PKG_CONFIG $version" ],
                                   []
                                  )
            if test "$BOTAN_CONFIG" != "" ; then
                break
            fi
623 624
            done
        fi
625
    fi
Jelte Jansen's avatar
Jelte Jansen committed
626
fi
627

628 629 630 631 632 633 634 635 636 637 638 639 640 641 642
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
643
fi
644 645 646 647 648 649 650 651 652
# 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

653
# See python_rpath for some info on why we do this
654
if test $rpath_flag != no; then
655
    BOTAN_RPATH=
656
    for flag in ${BOTAN_LIBS}; do
657
            BOTAN_RPATH="${BOTAN_RPATH} `echo $flag | sed -ne "s/^\(\-L\)/${rpath_flag}/p"`"
658 659 660 661 662 663 664 665 666 667 668 669 670 671
    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)
672
AC_SUBST(BOTAN_LIBS)
673
AC_SUBST(BOTAN_INCLUDES)
674

675 676 677
# 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.
678 679
CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$BOTAN_INCLUDES $CPPFLAGS"
680
LIBS_SAVED="$LIBS"
681
LIBS="$LIBS $BOTAN_LIBS"
Jelte Jansen's avatar
Jelte Jansen committed
682 683
AC_CHECK_HEADERS([botan/botan.h],,AC_MSG_ERROR([Missing required header files.]))
AC_LINK_IFELSE(
684 685 686
        [AC_LANG_PROGRAM([#include <botan/botan.h>
                          #include <botan/hash.h>
                         ],
Jelte Jansen's avatar
Jelte Jansen committed
687 688
                         [using namespace Botan;
                          LibraryInitializer::initialize();
689
                          HashFunction *h = get_hash("MD5");
Jelte Jansen's avatar
Jelte Jansen committed
690 691 692
                         ])],
        [AC_MSG_RESULT([checking for Botan library... yes])],
        [AC_MSG_RESULT([checking for Botan library... no])
693 694 695 696 697
         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
698
)
699
CPPFLAGS=$CPPFLAGS_SAVED
700
LIBS=$LIBS_SAVED
Jelte Jansen's avatar
Jelte Jansen committed
701

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

726
LOG4CPLUS_LIBS="$LOG4CPLUS_LIBS -llog4cplus $MULTITHREADING_FLAG"
727

728
AC_SUBST(LOG4CPLUS_LIBS)
729 730 731 732
AC_SUBST(LOG4CPLUS_INCLUDES)

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$LOG4CPLUS_INCLUDES $CPPFLAGS"
733
LIBS_SAVED="$LIBS"
734
LIBS="$LOG4CPLUS_LIBS $LIBS"
735 736 737 738 739 740 741 742 743 744 745 746 747 748

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
749
LIBS=$LIBS_SAVED
750

751 752 753 754
#
# Configure Boost header path
#
# If explicitly specified, use it.
755 756 757 758
AC_ARG_WITH([boost-include],
  AC_HELP_STRING([--with-boost-include=PATH],
    [specify exact directory for Boost headers]),
    [boost_include_path="$withval"])
759 760 761 762 763 764 765 766 767 768 769
# 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
770
CPPFLAGS_SAVES="$CPPFLAGS"
771
if test "${boost_include_path}" ; then
772 773
	BOOST_INCLUDES="-I${boost_include_path}"
	CPPFLAGS="$CPPFLAGS $BOOST_INCLUDES"
774
fi
775
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],,
776
  AC_MSG_ERROR([Missing required header files.]))
777
CPPFLAGS="$CPPFLAGS_SAVES"
778
AC_SUBST(BOOST_INCLUDES)
779

780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839

if test "${use_boost_threads}" = "yes" ; then
    AC_DEFINE([USE_BOOST_THREADS], [], [Use boost threads])

    # Using boost::mutex can result in requiring libboost_thread with older
    # versions of Boost.  We'd like to avoid relying on a compiled Boost library
    # whenever possible, so we need to check for it step by step.
    #
    # NOTE: another fix of this problem is to simply require newer versions of
    # boost.  If we choose that solution we should simplify the following tricky
    # checks accordingly and all Makefile.am's that refer to NEED_LIBBOOST_THREAD.
    AC_MSG_CHECKING(for boost::mutex)
    CPPFLAGS_SAVES="$CPPFLAGS"
    LIBS_SAVES="$LIBS"
    CPPFLAGS="$BOOST_INCLUDES $CPPFLAGS $MULTITHREADING_FLAG"
    need_libboost_thread=0
    need_sunpro_workaround=0
    AC_TRY_LINK([
    #include <boost/thread.hpp>
    ],[
    boost::mutex m;
    ],
        [ AC_MSG_RESULT(yes (without libboost_thread)) ],
        # there is one specific problem with SunStudio 5.10
        # where including boost/thread causes a compilation failure
        # There is a workaround in boost but it checks the version not being 5.10
        # This will probably be fixed in the future, in which case this
        # is only a temporary workaround
        [ AC_TRY_LINK([
    #if defined(__SUNPRO_CC) && __SUNPRO_CC == 0x5100
    #undef __SUNPRO_CC
    #define __SUNPRO_CC 0x5090
    #endif
    #include <boost/thread.hpp>
    ],[
    boost::mutex m;
    ],
        [ AC_MSG_RESULT(yes (with SUNOS workaround))
          need_sunpro_workaround=1 ],
            [ LIBS=" $LIBS -lboost_thread"
          AC_TRY_LINK([
    #include <boost/thread.hpp>
    ],[
    boost::mutex m;
    ],
              [ AC_MSG_RESULT(yes (with libboost_thread))
                need_libboost_thread=1 ],
              [ AC_MSG_RESULT(no)
                AC_MSG_ERROR([boost::mutex cannot be linked in this build environment.
    Perhaps you are using an older version of Boost that requires libboost_thread for the mutex support, which does not appear to be available.
    You may want to check the availability of the library or to upgrade Boost.])
              ])])])
    CPPFLAGS="$CPPFLAGS_SAVES"
    LIBS="$LIBS_SAVES"
    AM_CONDITIONAL(NEED_LIBBOOST_THREAD, test $need_libboost_thread = 1)
    if test $need_sunpro_workaround = 1; then
        AC_DEFINE([NEED_SUNPRO_WORKAROUND], [], [Need boost sunstudio workaround])
    fi
else
    AM_CONDITIONAL(NEED_LIBBOOST_THREAD, test "${use_boost_threads}" = "yes")
840
fi
841

842 843 844 845 846 847 848
# 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)
849

850
#
851
# Check availability of gtest, which will be used for unit tests.
852
#
853
if test "$gtest_path" != "no"
854
then
855
	DISTCHECK_GTEST_CONFIGURE_FLAG="--with-gtest=\"$gtest_path\""
856 857
	if test "$gtest_path" != "yes"; then
		GTEST_PATHS=$gtest_path
858 859 860
		if test -x "${gtest_path}/bin/gtest-config" ; then
			GTEST_CONFIG="${gtest_path}/bin/gtest-config"
		fi
861
	else
862
		AC_PATH_PROG([GTEST_CONFIG], [gtest-config])
863
	fi
864 865 866 867 868 869 870 871 872 873
	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"
874
		fi
875 876 877 878 879 880 881 882 883 884
		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"
885 886
				# There is no gtest-config script on this
				# system, which is supposed to inform us
Jeremy C. Reed's avatar
Jeremy C. Reed committed
887
				# whether we need pthreads as well (a
888 889
				# gtest compile-time option). So we still
				# need to test that manually.
890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926
				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
927 928 929 930 931
				break
			fi
		done
	fi
	if test "${GTEST_FOUND}" != "true"; then
932 933
		AC_MSG_ERROR([Cannot find gtest in: $GTEST_PATHS])
	fi
934
else
935 936 937
	GTEST_INCLUDES=
	GTEST_LDFLAGS=
	GTEST_LDADD=
938
	DISTCHECK_GTEST_CONFIGURE_FLAG=
939
fi
940
AM_CONDITIONAL(HAVE_GTEST, test $gtest_path != "no")
941
AC_SUBST(DISTCHECK_GTEST_CONFIGURE_FLAG)
942 943 944
AC_SUBST(GTEST_INCLUDES)
AC_SUBST(GTEST_LDFLAGS)
AC_SUBST(GTEST_LDADD)
945

946 947 948 949 950
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
951
PKG_CHECK_MODULES(SQLITE, sqlite3 >= 3.3.9, enable_features="$enable_features SQLite3")
952

953 954 955
#
# ASIO: we extensively use it as the C++ event management module.
#
956
# Use local ASIO headers from ext
957
#
958
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/asio"
959
#
960 961 962
# Use our 'coroutine' header from ext
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/coroutine"
#
963 964 965
# Disable threads: Currently we don't use them.
CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_THREADS=1"
#
966 967 968 969 970 971 972 973
# 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)
974
if test "X$ac_cv_have_kqueue" = "Xyes"; then
975 976 977 978 979 980 981 982 983 984 985
	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;
EV_SET(NULL, 0, 0, 0, 0, 0, udata);],
	[AC_MSG_RESULT(yes)],
	[AC_MSG_RESULT([no, disable kqueue for ASIO])
	 CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_KQUEUE=1"
	])
986
fi
987

988 989
# perfdhcp: If the clock_gettime() function does not exist on the system,
# use an alternative supplied in the code based on gettimeofday().
990 991 992 993
CLOCK_GETTIME_LDFLAGS=
AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_GETTIME_LDFLAGS=-lrt], [])
AC_SUBST([CLOCK_GETTIME_LDFLAGS])

994 995 996 997 998 999 1000 1001
# 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])])

1002 1003 1004 1005
# /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
1006
# gcc don't provide an option to selectively suppress this warning.
1007 1008 1009
# 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
1010
# run time performance.  Hopefully we can find a better solution or the ASIO
1011 1012
# 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)
1013
if test "X$ac_cv_have_devpoll" = "Xyes" -a "X$GXX" = "Xyes"; then
1014 1015
	CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_DEV_POLL=1"
fi
1016

1017 1018 1019 1020 1021
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)
1022 1023
AC_PATH_PROGS(AWK, gawk awk)
AC_SUBST(AWK)
1024

1025
AC_ARG_ENABLE(man, [AC_HELP_STRING([--enable-man],
1026
  [regenerate man pages [default=no]])], enable_man=$enableval, enable_man=no)
1027 1028

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

1030 1031 1032
AC_ARG_ENABLE(install-configurations,
  [AC_HELP_STRING([--disable-install-configurations],
  [do not install configuration])], install_configurations=$enableval, install_configurations=yes)
1033

1034
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
1035

1036
AC_CONFIG_FILES([Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1037
                 doc/Makefile
1038
                 doc/guide/Makefile
1039
                 compatcheck/Makefile
1040
                 src/Makefile
1041
                 src/bin/Makefile
1042
                 src/bin/bind10/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1043
                 src/bin/bind10/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1044
                 src/bin/cmdctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1045
                 src/bin/cmdctl/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1046
                 src/bin/bindctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1047
                 src/bin/bindctl/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1048
                 src/bin/cfgmgr/Makefile
1049
                 src/bin/cfgmgr/plugins/Makefile
1050
                 src/bin/cfgmgr/plugins/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1051
                 src/bin/cfgmgr/tests/Makefile
1052
                 src/bin/host/Makefile
Evan Hunt's avatar
Evan Hunt committed
1053
                 src/bin/loadzone/Makefile
1054 1055
                 src/bin/loadzone/tests/correct/Makefile
                 src/bin/loadzone/tests/error/Makefile
1056
                 src/bin/msgq/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1057
                 src/bin/msgq/tests/Makefile
1058
                 src/bin/auth/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1059
                 src/bin/auth/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1060
                 src/bin/auth/benchmarks/Makefile
1061 1062
                 src/bin/ddns/Makefile
                 src/bin/ddns/tests/Makefile
1063
                 src/bin/dhcp6/Makefile
1064
                 src/bin/dhcp6/tests/Makefile
1065 1066
		 src/bin/dhcp4/Makefile
		 src/bin/dhcp4/tests/Makefile
1067 1068
                 src/bin/resolver/Makefile
                 src/bin/resolver/tests/Makefile
1069 1070
                 src/bin/sockcreator/Makefile
                 src/bin/sockcreator/tests/Makefile
Likun Zhang's avatar
Likun Zhang committed
1071
                 src/bin/xfrin/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1072
                 src/bin/xfrin/tests/Makefile
1073
                 src/bin/xfrin/tests/testdata/Makefile
1074
                 src/bin/xfrout/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1075
                 src/bin/xfrout/tests/Makefile
1076 1077
                 src/bin/zonemgr/Makefile
                 src/bin/zonemgr/tests/Makefile
1078 1079
                 src/bin/stats/Makefile
                 src/bin/stats/tests/Makefile
1080
                 src/bin/usermgr/Makefile
Michal Vaner's avatar
Michal Vaner committed
1081
                 src/bin/tests/Makefile
1082
                 src/lib/Makefile
1083 1084
                 src/lib/asiolink/Makefile
                 src/lib/asiolink/tests/Makefile
Ocean Wang's avatar
Ocean Wang committed
1085
                 src/lib/asiodns/Makefile
1086
                 src/lib/asiodns/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1087 1088 1089
                 src/lib/bench/Makefile
                 src/lib/bench/example/Makefile
                 src/lib/bench/tests/Makefile
1090
                 src/lib/cc/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1091
                 src/lib/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1092 1093
                 src/lib/python/Makefile
                 src/lib/python/isc/Makefile
1094 1095
                 src/lib/python/isc/acl/Makefile
                 src/lib/python/isc/acl/tests/Makefile
1096 1097
                 src/lib/python/isc/util/Makefile
                 src/lib/python/isc/util/tests/Makefile
Michal 'vorner' Vaner's avatar
Michal 'vorner' Vaner committed
1098 1099
                 src/lib/python/isc/util/cio/Makefile
                 src/lib/python/isc/util/cio/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
1100
                 src/lib/python/isc/datasrc/Makefile
1101
                 src/lib/python/isc/datasrc/tests/Makefile
1102
                 src/lib/python/isc/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1103
                 src/lib/python/isc/cc/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1104
                 src/lib/python/isc/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1105
                 src/lib/python/isc/config/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1106
                 src/lib/python/isc/config/tests/Makefile
1107 1108
                 src/lib/python/isc/log/Makefile