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

4
AC_PREREQ([2.59])
5
AC_INIT(bind10-devel, 20111129, bind10-dev@isc.org)
6 7 8 9 10 11
AC_CONFIG_SRCDIR(README)
AM_INIT_AUTOMAKE
AC_CONFIG_HEADERS([config.h])

# Checks for programs.
AC_PROG_CXX
12 13 14

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

# 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

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

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

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

49 50 51 52 53 54 55 56 57 58 59 60 61 62
# Linker options

# check -R rather than gcc specific -rpath to be as portable as possible.
AC_MSG_CHECKING([whether -R flag is available in linker])
LDFLAGS_SAVED="$LDFLAGS"
LDFLAGS="$LDFLAGS -R/usr/lib"
AC_TRY_LINK([],[],
	[ AC_MSG_RESULT(yes)
		rpath_available=yes
	],[ AC_MSG_RESULT(no)
	rpath_available=no
	])
LDFLAGS=$LDFLAGS_SAVED

JINMEI Tatuya's avatar
JINMEI Tatuya committed
63 64 65 66 67 68 69 70
# 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
71 72 73 74 75 76 77 78
# 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

79 80 81 82 83
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
84 85 86 87 88 89
# 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)

90 91 92 93
# OS dependent configuration
SET_ENV_LIBRARY_PATH=no
ENV_LIBRARY_PATH=LD_LIBRARY_PATH

94
case "$host" in
95 96 97 98
*-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
99 100
	# "now" binding is necessary to prevent deadlocks in C++ static initialization code
	LDFLAGS="$LDFLAGS -z now"
101
	;;
102
*-apple-darwin*)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
103
	# libtool doesn't work perfectly with Darwin: libtool embeds the
104 105 106 107 108 109 110 111
	# 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
	;;
112 113 114
*-freebsd*)
	SET_ENV_LIBRARY_PATH=yes
	;;
115 116 117
*-netbsd*)
	SET_ENV_LIBRARY_PATH=yes
	;;
118
esac
119 120 121
AM_CONDITIONAL(SET_ENV_LIBRARY_PATH, test $SET_ENV_LIBRARY_PATH = yes)
AC_SUBST(SET_ENV_LIBRARY_PATH)
AC_SUBST(ENV_LIBRARY_PATH)
122

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

156 157 158 159 160 161 162 163 164 165
# 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)

166
# This will be commonly used in various Makefile.am's that need to generate
167 168 169 170 171 172 173 174 175
# 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)

176 177 178
# Check for python development environments
if test -x ${PYTHON}-config; then
	PYTHON_INCLUDES=`${PYTHON}-config --includes`
179

180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196
	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.])
197 198
	fi
fi
199

200 201 202 203
# 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
204
# it's stored in a common "hint" file) for simplicity.
205 206 207
if test $rpath_available = yes; then
	python_rpath=
	for flag in ${PYTHON_LDFLAGS}; do
208
		python_rpath="${python_rpath} `echo $flag | sed -ne 's/^\(\-L\)/-R/p'`"
209 210 211 212
	done
	PYTHON_LDFLAGS="${PYTHON_LDFLAGS} ${python_rpath}"
fi

213 214 215
AC_SUBST(PYTHON_INCLUDES)
AC_SUBST(PYTHON_LDFLAGS)

216 217 218 219 220
CPPFLAGS_SAVED="$CPPFLAGS"
CPPFLAGS="$CPPFLAGS ${PYTHON_INCLUDES}"
AC_CHECK_HEADERS([Python.h],, AC_MSG_ERROR([Missing Python.h]))
CPPFLAGS="$CPPFLAGS_SAVED"

221
# Check for python library.  Needed for Python-wrapper libraries.
222 223 224 225 226 227 228 229
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)
230
LDFLAGS=$LDFLAGS_SAVED
231

Michal Vaner's avatar
Michal Vaner committed
232 233 234 235 236 237 238
# 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)
239 240 241
        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
242 243 244
    fi
fi

245 246
# TODO: check for _sqlite3.py module

247 248
# 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
249
# used as the default value for each specific AM_CXXFLAGS:
250 251 252 253 254 255 256 257
# 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.

258
# This may be used to try linker flags.
259 260 261 262 263 264
AC_DEFUN([BIND10_CXX_TRY_FLAG], [
  AC_MSG_CHECKING([whether $CXX supports $1])

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

265 266
  AC_LINK_IFELSE([int main(void){ return 0;} ],
                 [bind10_cxx_flag=yes], [bind10_cxx_flag=no])
267 268
  CXXFLAGS="$bind10_save_CXXFLAGS"

269 270 271 272 273 274
  if test "x$bind10_cxx_flag" = "xyes"; then
    ifelse([$2], , :, [$2])
  else
    ifelse([$3], , :, [$3])
  fi

275 276 277
  AC_MSG_RESULT([$bind10_cxx_flag])
])

278
werror_ok=0
279 280 281 282 283

# 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"
284
MULTITHREADING_FLAG="-mt"
285 286
fi

287 288 289 290
BIND10_CXX_TRY_FLAG(-Wno-missing-field-initializers,
	[WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG="-Wno-missing-field-initializers"])
AC_SUBST(WARNING_NO_MISSING_FIELD_INITIALIZERS_CFLAG)

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

# 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.
CXXFLAGS_SAVED="$CXXFLAGS"
309
CXXFLAGS="$CXXFLAGS $B10_CXXFLAGS -Werror"
310 311 312 313
AC_MSG_CHECKING(for in-TU anonymous namespace breakage)
AC_TRY_COMPILE([namespace { class Foo {}; }
namespace isc {class Bar {Foo foo_;};} ],,
	[AC_MSG_RESULT(no)
314 315
	 werror_ok=1
	 B10_CXXFLAGS="$B10_CXXFLAGS -Werror"],
316 317
	[AC_MSG_RESULT(yes)])
CXXFLAGS="$CXXFLAGS_SAVED"
318

319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347
# 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

348
fi				dnl GXX = yes
349

350
AM_CONDITIONAL(GCC_WERROR_OK, test $werror_ok = 1)
351 352

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

357 358
AC_SUBST(B10_CXXFLAGS)

359 360
# Checks for libraries.

361 362
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
363
AC_SEARCH_LIBS(nanosleep, [rt])
364

365 366 367 368 369 370
# Checks for header files.

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

371 372


373 374 375 376 377 378
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)
379
        AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
380 381
        AC_MSG_RESULT(no))

382 383
AC_ARG_WITH(pycoverage,
[  --with-pycoverage[=PROGRAM]         enable python code coverage using the specified coverage], pycoverage="$withval", pycoverage="no")
384 385 386 387 388 389 390 391
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"
392
else
393 394 395
	PYCOVERAGE="$pycoverage"
	PYCOVERAGE_RUN="${PYCOVERAGE} run --branch --append"
	USE_PYCOVERAGE="yes"
396
fi
397
AM_CONDITIONAL(ENABLE_PYTHON_COVERAGE, test x$USE_PYCOVERAGE != xno)
398
AC_SUBST(PYCOVERAGE)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
399
AC_SUBST(PYCOVERAGE_RUN)
400
AC_SUBST(USE_PYCOVERAGE)
401

402
AC_ARG_WITH(lcov,
403
[  --with-lcov[=PROGRAM]         enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
404

405
AC_ARG_WITH(gtest,
406
[  --with-gtest=PATH       specify a path to gtest header files (PATH/include) and library (PATH/lib)],
407
    gtest_path="$withval", gtest_path="no")
408 409 410 411 412

USE_LCOV="no"
if test "$lcov" != "no"; then
	# force gtest if not set
	if test "$gtest_path" = "no"; then
413 414
#		AC_MSG_ERROR("lcov needs gtest for test coverage report")
		AC_MSG_NOTICE([gtest support is now enabled, because used by coverage tests])
415 416 417
		gtest_path="yes"
	fi
	if test "$lcov" != "yes"; then
418
		LCOV=$lcov
419
	else
420
		AC_PATH_PROG([LCOV], [lcov])
421
	fi
422 423 424 425
	if test -x "${LCOV}"; then
		USE_LCOV="yes"
	else
		AC_MSG_ERROR([Cannot find lcov.])
426 427 428 429 430 431
	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
432
	# GCC specific?
433
	CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
434
	LIBS=" $LIBS -lgcov"
435 436 437 438 439 440 441
	AC_SUBST(CPPFLAGS)
	AC_SUBST(LIBS)
	AC_SUBST(LCOV)
	AC_SUBST(GENHTML)
fi
AC_SUBST(USE_LCOV)

Jelte Jansen's avatar
Jelte Jansen committed
442
# Check for Botan
Jelte Jansen's avatar
Jelte Jansen committed
443
botan_path="yes"
Jelte Jansen's avatar
Jelte Jansen committed
444 445 446 447
AC_ARG_WITH([botan],
  AC_HELP_STRING([--with-botan=PATH],
    [specify exact directory of Botan library]),
    [botan_path="$withval"])
448
if test "${botan_path}" = "no" ; then
Jelte Jansen's avatar
Jelte Jansen committed
449
    AC_MSG_ERROR([Need botan for libcryptolink])
Jelte Jansen's avatar
Jelte Jansen committed
450
fi
Jelte Jansen's avatar
Jelte Jansen committed
451 452 453 454 455 456 457
if test "${botan_path}" != "yes" ; then
    if test -x "${botan_path}/bin/botan-config" ; then
        BOTAN_CONFIG="${botan_path}/bin/botan-config"
    else
        AC_MSG_ERROR([${botan_path}/bin/botan-config not found])
    fi
else
458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478
    # First see if pkg-config knows of it.
    # Unfortunately, the botan.pc files have their minor version in them
    # too, so we need to try them one by one
    BOTAN_CONFIG=""
    AC_PATH_PROG([PKG_CONFIG], [pkg-config])
    if test "$PKG_CONFIG" != "" ; then
        BOTAN_VERSIONS="botan-1.10 botan-1.9 botan-1.8"
        for version in $BOTAN_VERSIONS; do
            AC_MSG_CHECKING([Checking botan version with pkg-config $version])
            
            if [ $PKG_CONFIG --exists ${version} ]; then
                AC_MSG_RESULT([found])
                BOTAN_CONFIG="$PKG_CONFIG ${version}"
                break
            else
                AC_MSG_RESULT([not found])
            fi
        done
    fi
    # If we had no pkg-config, or it didn't know about botan, use botan-config
    if test "$BOTAN_CONFIG" = "" ; then
Jelte Jansen's avatar
Jelte Jansen committed
479
        AC_PATH_PROG([BOTAN_CONFIG], [botan-config])
480
    fi
Jelte Jansen's avatar
Jelte Jansen committed
481 482
fi

483 484 485 486 487 488 489
BOTAN_LDFLAGS=`${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.  Same for BOTAN_INCLUDES
# (but using include instead of lib) below.
reed's avatar
reed committed
490
if [ $BOTAN_CONFIG --prefix >/dev/null 2>&1 ] ; then
491
    echo ${BOTAN_LDFLAGS} | grep -- -L > /dev/null || \
492
        BOTAN_LDFLAGS="-L`${BOTAN_CONFIG} --prefix`/lib ${BOTAN_LDFLAGS}"
493
    echo ${BOTAN_INCLUDES} | grep -- -I > /dev/null || \
494
        BOTAN_INCLUDES="-I`${BOTAN_CONFIG} --prefix`/include ${BOTAN_INCLUDES}"
Jelte Jansen's avatar
Jelte Jansen committed
495
fi
496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515
# See python_rpath for some info on why we do this
if test $rpath_available = yes; then
    BOTAN_RPATH=
    for flag in ${BOTAN_LDFLAGS}; do
            BOTAN_RPATH="${BOTAN_RPATH} `echo $flag | sed -ne 's/^\(\-L\)/-R/p'`"
    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)
AC_SUBST(BOTAN_INCLUDES)
516 517 518

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$BOTAN_INCLUDES $CPPFLAGS"
519 520
LIBS_SAVED="$LIBS"
LIBS="$LIBS $BOTAN_LDFLAGS"
Jelte Jansen's avatar
Jelte Jansen committed
521 522
AC_CHECK_HEADERS([botan/botan.h],,AC_MSG_ERROR([Missing required header files.]))
AC_LINK_IFELSE(
523 524 525
        [AC_LANG_PROGRAM([#include <botan/botan.h>
                          #include <botan/hash.h>
                         ],
Jelte Jansen's avatar
Jelte Jansen committed
526 527
                         [using namespace Botan;
                          LibraryInitializer::initialize();
528
                          HashFunction *h = get_hash("MD5");
Jelte Jansen's avatar
Jelte Jansen committed
529 530 531
                         ])],
        [AC_MSG_RESULT([checking for Botan library... yes])],
        [AC_MSG_RESULT([checking for Botan library... no])
532
         AC_MSG_ERROR([Needs Botan library 1.8 or higher])]
Jelte Jansen's avatar
Jelte Jansen committed
533
)
534
CPPFLAGS=$CPPFLAGS_SAVED
535
LIBS=$LIBS_SAVED
Jelte Jansen's avatar
Jelte Jansen committed
536

537 538 539 540 541 542
# 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"])
543
if test "${log4cplus_path}" = "no" ; then
544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567
    AC_MSG_ERROR([Need log4cplus])
elif test "${log4cplus_path}" != "yes" ; then
  LOG4CPLUS_INCLUDES="-I${log4cplus_path}/include"
  LOG4CPLUS_LDFLAGS="-L${log4cplus_path}/lib"
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"
			LOG4CPLUS_LDFLAGS="-L$d/lib"
			break
		fi
	done
fi

LOG4CPLUS_LDFLAGS="$LOG4CPLUS_LDFLAGS -llog4cplus $MULTITHREADING_FLAG"

AC_SUBST(LOG4CPLUS_LDFLAGS)
AC_SUBST(LOG4CPLUS_INCLUDES)

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$LOG4CPLUS_INCLUDES $CPPFLAGS"
568 569
LIBS_SAVED="$LIBS"
LIBS="$LOG4CPLUS_LDFLAGS $LIBS"
570 571 572 573 574 575 576 577 578 579 580 581 582 583

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
584
LIBS=$LIBS_SAVED
585

586 587 588 589
#
# Configure Boost header path
#
# If explicitly specified, use it.
590 591 592 593
AC_ARG_WITH([boost-include],
  AC_HELP_STRING([--with-boost-include=PATH],
    [specify exact directory for Boost headers]),
    [boost_include_path="$withval"])
594 595 596 597 598 599 600 601 602 603 604
# 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
605
CPPFLAGS_SAVES="$CPPFLAGS"
606
if test "${boost_include_path}" ; then
607 608
	BOOST_INCLUDES="-I${boost_include_path}"
	CPPFLAGS="$CPPFLAGS $BOOST_INCLUDES"
609
fi
610
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],,
611
  AC_MSG_ERROR([Missing required header files.]))
612
CPPFLAGS="$CPPFLAGS_SAVES"
613
AC_SUBST(BOOST_INCLUDES)
614

615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674

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")
675
fi
676

677 678 679 680 681 682 683
# 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)
684

685
#
686
# Check availability of gtest, which will be used for unit tests.
687
#
688
if test "$gtest_path" != "no"
689
then
690
	DISTCHECK_GTEST_CONFIGURE_FLAG="--with-gtest=\"$gtest_path\""
691 692
	if test "$gtest_path" != "yes"; then
		GTEST_PATHS=$gtest_path
693 694 695
		if test -x "${gtest_path}/bin/gtest-config" ; then
			GTEST_CONFIG="${gtest_path}/bin/gtest-config"
		fi
696
	else
697
		AC_PATH_PROG([GTEST_CONFIG], [gtest-config])
698
	fi
699 700 701 702 703 704 705 706 707 708
	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"
709
		fi
710 711 712 713 714 715 716 717 718 719 720 721 722 723 724
		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"
				break
			fi
		done
	fi
	if test "${GTEST_FOUND}" != "true"; then
725 726
		AC_MSG_ERROR([Cannot find gtest in: $GTEST_PATHS])
	fi
727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757
	# On some systems, there is no gtest-config script, which is supposed
	# to inform us whether we need -lpthread as well (a gtest compile-time
	# option). So we still need to test that manually
	LIBS_SAVED=$LIBS
	LIBS="$LIBS $GTEST_LDADD"
	AC_MSG_CHECKING([Checking whether gtest tests need -lpthread])
	AC_TRY_LINK([
		#include <gtest/gtest.h>
		],[
			int i = 0;
			char* c = NULL;
			::testing::InitGoogleTest(&i, &c);
			return (0);
		],
		[ AC_MSG_RESULT(no) ],
		[
			LIBS="$LIBS $GTEST_LDADD $PTHREAD_LDFLAGS"
			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"
				],
				[ AC_MSG_ERROR(unable to compile with gtest) ])
	])
	LIBS=$LIBS_SAVED
758
else
759 760 761
	GTEST_INCLUDES=
	GTEST_LDFLAGS=
	GTEST_LDADD=
762
	DISTCHECK_GTEST_CONFIGURE_FLAG=
763
fi
764
AM_CONDITIONAL(HAVE_GTEST, test $gtest_path != "no")
765
AC_SUBST(DISTCHECK_GTEST_CONFIGURE_FLAG)
766 767 768
AC_SUBST(GTEST_INCLUDES)
AC_SUBST(GTEST_LDFLAGS)
AC_SUBST(GTEST_LDADD)
769

770 771 772 773 774
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
775
PKG_CHECK_MODULES(SQLITE, sqlite3 >= 3.3.9, enable_features="$enable_features SQLite3")
776

777 778 779
#
# ASIO: we extensively use it as the C++ event management module.
#
780
# Use local ASIO headers from ext
781
#
782
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/asio"
783
#
784 785 786
# Use our 'coroutine' header from ext
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/coroutine"
#
787 788 789
# Disable threads: Currently we don't use them.
CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_THREADS=1"
#
790 791 792 793 794 795 796 797
# 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)
798
if test "X$ac_cv_have_kqueue" = "Xyes"; then
799 800 801 802 803 804 805 806 807 808 809
	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"
	])
810
fi
811 812 813 814 815

# /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
816
# gcc don't provide an option to selectively suppress this warning.
817 818 819
# 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
820
# run time performance.  Hopefully we can find a better solution or the ASIO
821 822
# 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)
823
if test "X$ac_cv_have_devpoll" = "Xyes" -a "X$GXX" = "Xyes"; then
824 825
	CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_DEV_POLL=1"
fi
826

827 828 829 830 831
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)
832 833
AC_PATH_PROGS(AWK, gawk awk)
AC_SUBST(AWK)
834

835
AC_ARG_ENABLE(man, [AC_HELP_STRING([--enable-man],
836
  [regenerate man pages [default=no]])], enable_man=yes, enable_man=no)
837 838

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

840 841 842
AC_ARG_ENABLE(install-configurations,
  [AC_HELP_STRING([--disable-install-configurations],
  [do not install configuration])], install_configurations=$enableval, install_configurations=yes)
843

844
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
845

846
AC_CONFIG_FILES([Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
847
                 doc/Makefile
848
                 doc/guide/Makefile
849
                 compatcheck/Makefile
850
                 src/Makefile
851
                 src/bin/Makefile
852
                 src/bin/bind10/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
853
                 src/bin/bind10/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
854
                 src/bin/cmdctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
855
                 src/bin/cmdctl/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
856
                 src/bin/bindctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
857
                 src/bin/bindctl/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
858
                 src/bin/cfgmgr/Makefile
859
                 src/bin/cfgmgr/plugins/Makefile
860
                 src/bin/cfgmgr/plugins/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
861
                 src/bin/cfgmgr/tests/Makefile
862
                 src/bin/host/Makefile
Evan Hunt's avatar
Evan Hunt committed
863
                 src/bin/loadzone/Makefile
864 865
                 src/bin/loadzone/tests/correct/Makefile
                 src/bin/loadzone/tests/error/Makefile
866
                 src/bin/msgq/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
867
                 src/bin/msgq/tests/Makefile
868
                 src/bin/auth/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
869
                 src/bin/auth/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
870
                 src/bin/auth/benchmarks/Makefile
871
                 src/bin/dhcp6/Makefile
872
                 src/bin/dhcp6/tests/Makefile
873 874
                 src/bin/resolver/Makefile
                 src/bin/resolver/tests/Makefile
875 876
                 src/bin/sockcreator/Makefile
                 src/bin/sockcreator/tests/Makefile
Likun Zhang's avatar
Likun Zhang committed
877
                 src/bin/xfrin/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
878
                 src/bin/xfrin/tests/Makefile
879
                 src/bin/xfrin/tests/testdata/Makefile
880
                 src/bin/xfrout/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
881
                 src/bin/xfrout/tests/Makefile
882 883
                 src/bin/zonemgr/Makefile
                 src/bin/zonemgr/tests/Makefile
884 885
                 src/bin/stats/Makefile
                 src/bin/stats/tests/Makefile
886
                 src/bin/usermgr/Makefile
Michal Vaner's avatar
Michal Vaner committed
887
                 src/bin/tests/Makefile
888
                 src/lib/Makefile
889 890
                 src/lib/asiolink/Makefile
                 src/lib/asiolink/tests/Makefile
Ocean Wang's avatar
Ocean Wang committed
891
                 src/lib/asiodns/Makefile
892
                 src/lib/asiodns/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
893 894 895
                 src/lib/bench/Makefile
                 src/lib/bench/example/Makefile
                 src/lib/bench/tests/Makefile
896
                 src/lib/cc/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
897
                 src/lib/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
898 899
                 src/lib/python/Makefile
                 src/lib/python/isc/Makefile
900 901
                 src/lib/python/isc/acl/Makefile
                 src/lib/python/isc/acl/tests/Makefile
902 903
                 src/lib/python/isc/util/Makefile
                 src/lib/python/isc/util/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
904
                 src/lib/python/isc/datasrc/Makefile
905
                 src/lib/python/isc/datasrc/tests/Makefile
906
                 src/lib/python/isc/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
907
                 src/lib/python/isc/cc/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
908
                 src/lib/python/isc/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
909
                 src/lib/python/isc/config/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
910
                 src/lib/python/isc/config/tests/Makefile
911 912
                 src/lib/python/isc/log/Makefile
                 src/lib/python/isc/log/tests/Makefile
913 914
                 src/lib/python/isc/log_messages/Makefile
                 src/lib/python/isc/log_messages/work/Makefile
915
                 src/lib/python/isc/net/Makefile
Michal Vaner's avatar
Michal Vaner committed
916
                 src/lib/python/isc/net/tests/Makefile
917 918
                 src/lib/python/isc/notify/Makefile
                 src/lib/python/isc/notify/tests/Makefile
919
                 src/lib/python/isc/testutils/Makefile
920 921
                 src/lib/python/isc/bind10/Makefile
                 src/lib/python/isc/bind10/tests/Makefile
922 923
                 src/lib/python/isc/xfrin/Makefile
                 src/lib/python/isc/xfrin/tests/Makefile
924
                 src/lib/config/Makefile
925
                 src/lib/config/tests/Makefile
926
                 src/lib/config/tests/testdata/Makefile
927 928
                 src/lib/cryptolink/Makefile
                 src/lib/cryptolink/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
929
                 src/lib/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
930
                 src/lib/dns/tests/Makefile
931
                 src/lib/dns/tests/testdata/Makefile
932
                 src/lib/dns/python/Makefile
933
                 src/lib/dns/python/tests/Makefile
934
                 src/lib/dns/benchmarks/Makefile
935 936
                 src/lib/dhcp/Makefile
                 src/lib/dhcp/tests/Makefile
937
                 src/lib/exceptions/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
938
                 src/lib/exceptions/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
939 940
                 src/lib/datasrc/Makefile
                 src/lib/datasrc/tests/Makefile
941
                 src/lib/datasrc/tests/testdata/Makefile
942
                 src/lib/xfr/Makefile
943
                 src/lib/log/Makefile
944
                 src/lib/log/compiler/Makefile
945
                 src/lib/log/tests/Makefile
946 947
                 src/lib/resolve/Makefile
                 src/lib/resolve/tests/Makefile
948
                 src/lib/testutils/Makefile
Michal Vaner's avatar
Michal Vaner committed
949
                 src/lib/testutils/testdata/Makefile
950 951
                 src/lib/nsas/Makefile
                 src/lib/nsas/tests/Makefile
952 953
                 src/lib/cache/Makefile
                 src/lib/cache/tests/Makefile
954 955
                 src/lib/server_common/Makefile
                 src/lib/server_common/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
956 957 958
                 src/lib/util/Makefile
                 src/lib/util/io/Makefile
                 src/lib/util/unittests/Makefile
959
                 src/lib/util/python/Makefile
960
                 src/lib/util/pyunittests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
961
                 src/lib/util/tests/Makefile
962 963
                 src/lib/acl/Makefile
                 src/lib/acl/tests/Makefile
964 965
                 tests/Makefile
                 tests/system/Makefile
Stephen Morris's avatar
Stephen Morris committed
966 967 968
                 tests/tools/Makefile
                 tests/tools/badpacket/Makefile
                 tests/tools/badpacket/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
969
               ])
970
AC_OUTPUT([doc/version.ent
971
           compatcheck/sqlite3-difftbl-check.py
972
           src/bin/cfgmgr/b10-cfgmgr.py
Jelte Jansen's avatar
Jelte Jansen committed
973
           src/bin/cfgmgr/tests/b10-cfgmgr_test.py
974
           src/bin/cmdctl/cmdctl.py
975
           src/bin/cmdctl/run_b10-cmdctl.sh
976
           src/bin/cmdctl/tests/cmdctl_test
Likun Zhang's avatar
 
Likun Zhang committed
977
           src/bin/cmdctl/cmdctl.spec.pre
978
           src/bin/xfrin/tests/xfrin_test
Likun Zhang's avatar
Likun Zhang committed
979 980
           src/bin/xfrin/xfrin.py
           src/bin/xfrin/run_b10-xfrin.sh
981
           src/bin/xfrout/xfrout.py
982
           src/bin/xfrout/xfrout.spec.pre
Likun Zhang's avatar
Likun Zhang committed
983
           src/bin/xfrout/tests/xfrout_test
984
           src/bin/xfrout/tests/xfrout_test.py
985
           src/bin/xfrout/run_b10-xfrout.sh
986 987
           src/bin/resolver/resolver.spec.pre
           src/bin/resolver/spec_config.h.pre
988 989 990 991
           src/bin/zonemgr/zonemgr.py
           src/bin/zonemgr/zonemgr.spec.pre
           src/bin/zonemgr/tests/zonemgr_test
           src/bin/zonemgr/run_b10-zonemgr.sh
992
           src/bin/stats/stats.py
Naoki Kambe's avatar
Naoki Kambe committed
993
           src/bin/stats/stats_httpd.py
994
           src/bin/bind10/bind10_src.py
995
           src/bin/bind10/run_bind10.sh
996
           src/bin/bind10/tests/bind10_test.py
997
           src/bin/bindctl/run_bindctl.sh
998
           src/bin/bindctl/bindctl_main.py
999
           src/bin/bindctl/tests/bindctl_test
1000
           src/bin/loadzone/run_loadzone.sh
1001 1002
           src/bin/loadzone/tests/correct/correct_test.sh
           src/bin/loadzone/tests/error/error_test.sh
Evan Hunt's avatar
Evan Hunt committed
1003
           src/bin/loadzone/b10-loadzone.py
1004 1005
           src/bin/usermgr/run_b10-cmdctl-usermgr.sh
           src/bin/usermgr/b10-cmdctl-usermgr.py
1006
           src/bin/msgq/msgq.py
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1007
           src/bin/msgq/tests/msgq_test
1008
           src/bin/msgq/run_msgq.sh
1009
           src/bin/auth/auth.spec.pre
1010
           src/bin/auth/spec_config.h.pre
1011
           src/bin/dhcp6/spec_config.h.pre
Michal Vaner's avatar
Michal Vaner committed
1012
           src/bin/tests/process_rename_test.py
1013 1014
           src/lib/config/tests/data_def_unittests_config.h
           src/lib/python/isc/config/tests/config_test
1015
           src/lib/python/isc/cc/tests/cc_test
1016
           src/lib/python/isc/notify/tests/notify_out_test