configure.ac 44.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 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
# Linker options

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

JINMEI Tatuya's avatar
JINMEI Tatuya committed
71 72 73 74 75 76 77 78
# 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
79 80 81 82 83 84 85 86
# 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

87 88 89 90 91
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
92 93 94 95 96 97
# 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)

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

102
case "$host" in
103 104 105 106
*-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
107 108
	# "now" binding is necessary to prevent deadlocks in C++ static initialization code
	LDFLAGS="$LDFLAGS -z now"
109
	;;
110
*-apple-darwin*)
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([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
werror_ok=0
287 288 289 290 291

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

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

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

# 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"
317
CXXFLAGS="$CXXFLAGS $B10_CXXFLAGS -Werror"
318 319 320 321
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)
322 323
	 werror_ok=1
	 B10_CXXFLAGS="$B10_CXXFLAGS -Werror"],
324 325
	[AC_MSG_RESULT(yes)])
CXXFLAGS="$CXXFLAGS_SAVED"
326

327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355
# 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

356
fi				dnl GXX = yes
357

358
AM_CONDITIONAL(GCC_WERROR_OK, test $werror_ok = 1)
359 360

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

365 366
AC_SUBST(B10_CXXFLAGS)

367 368
# Checks for libraries.

369 370
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
371
AC_SEARCH_LIBS(nanosleep, [rt])
372

373 374 375 376 377 378
# Checks for header files.

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

379

380 381 382 383 384 385
# 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)
386
      OS_TYPE="Linux"
387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402
      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)
403 404 405

AM_CONDITIONAL(OS_LINUX, test $OS_TYPE = Linux)
AM_COND_IF([OS_LINUX], [AC_DEFINE([OS_LINUX], [1], [Running on Linux?])])
406
AM_CONDITIONAL(OS_BSD, test $OS_TYPE = BSD)
407
AM_COND_IF([OS_BSD], [AC_DEFINE([OS_BSD], [1], [Running on BSD?])])
408
AM_CONDITIONAL(OS_SOLARIS, test $OS_TYPE = Solaris)
409
AM_COND_IF([OS_SOLARIS], [AC_DEFINE([OS_SOLARIS], [1], [Running on Solaris?])])
410

411 412 413 414 415 416
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)
417
        AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
418 419
        AC_MSG_RESULT(no))

420 421
AC_ARG_WITH(pycoverage,
[  --with-pycoverage[=PROGRAM]         enable python code coverage using the specified coverage], pycoverage="$withval", pycoverage="no")
422 423 424 425 426 427 428 429
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"
430
else
431 432 433
	PYCOVERAGE="$pycoverage"
	PYCOVERAGE_RUN="${PYCOVERAGE} run --branch --append"
	USE_PYCOVERAGE="yes"
434
fi
435
AM_CONDITIONAL(ENABLE_PYTHON_COVERAGE, test x$USE_PYCOVERAGE != xno)
436
AC_SUBST(PYCOVERAGE)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
437
AC_SUBST(PYCOVERAGE_RUN)
438
AC_SUBST(USE_PYCOVERAGE)
439

440
AC_ARG_WITH(lcov,
441
[  --with-lcov[=PROGRAM]         enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
442

443
AC_ARG_WITH(gtest,
444
[  --with-gtest=PATH       specify a path to gtest header files (PATH/include) and library (PATH/lib)],
445
    gtest_path="$withval", gtest_path="no")
446 447 448 449 450

USE_LCOV="no"
if test "$lcov" != "no"; then
	# force gtest if not set
	if test "$gtest_path" = "no"; then
451 452
#		AC_MSG_ERROR("lcov needs gtest for test coverage report")
		AC_MSG_NOTICE([gtest support is now enabled, because used by coverage tests])
453 454 455
		gtest_path="yes"
	fi
	if test "$lcov" != "yes"; then
456
		LCOV=$lcov
457
	else
458
		AC_PATH_PROG([LCOV], [lcov])
459
	fi
460 461 462 463
	if test -x "${LCOV}"; then
		USE_LCOV="yes"
	else
		AC_MSG_ERROR([Cannot find lcov.])
464 465 466 467 468 469
	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
470
	# GCC specific?
471
	CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
472
	LIBS=" $LIBS -lgcov"
473 474 475 476 477 478 479
	AC_SUBST(CPPFLAGS)
	AC_SUBST(LIBS)
	AC_SUBST(LCOV)
	AC_SUBST(GENHTML)
fi
AC_SUBST(USE_LCOV)

Jelte Jansen's avatar
Jelte Jansen committed
480
# Check for Botan
Jelte Jansen's avatar
Jelte Jansen committed
481
botan_path="yes"
Jelte Jansen's avatar
Jelte Jansen committed
482 483
AC_ARG_WITH([botan],
  AC_HELP_STRING([--with-botan=PATH],
484
    [specify the path to botan-config (PATH/bin/botan-config will be used)]),
Jelte Jansen's avatar
Jelte Jansen committed
485
    [botan_path="$withval"])
486
if test "${botan_path}" = "no" ; then
Jelte Jansen's avatar
Jelte Jansen committed
487
    AC_MSG_ERROR([Need botan for libcryptolink])
Jelte Jansen's avatar
Jelte Jansen committed
488
fi
Jelte Jansen's avatar
Jelte Jansen committed
489 490 491 492 493 494 495
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
496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516
    # 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
517
        AC_PATH_PROG([BOTAN_CONFIG], [botan-config])
518
    fi
Jelte Jansen's avatar
Jelte Jansen committed
519
fi
520 521 522 523 524 525 526 527 528 529 530 531 532 533 534
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
535
fi
536 537 538 539 540 541 542 543 544
# 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

545
# See python_rpath for some info on why we do this
546
if test $rpath_flag != no; then
547
    BOTAN_RPATH=
548
    for flag in ${BOTAN_LIBS}; do
549
            BOTAN_RPATH="${BOTAN_RPATH} `echo $flag | sed -ne "s/^\(\-L\)/${rpath_flag}/p"`"
550 551 552 553 554 555 556 557 558 559 560 561 562 563
    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)
564
AC_SUBST(BOTAN_LIBS)
565
AC_SUBST(BOTAN_INCLUDES)
566 567 568

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$BOTAN_INCLUDES $CPPFLAGS"
569
LIBS_SAVED="$LIBS"
570
LIBS="$LIBS $BOTAN_LIBS"
Jelte Jansen's avatar
Jelte Jansen committed
571 572
AC_CHECK_HEADERS([botan/botan.h],,AC_MSG_ERROR([Missing required header files.]))
AC_LINK_IFELSE(
573 574 575
        [AC_LANG_PROGRAM([#include <botan/botan.h>
                          #include <botan/hash.h>
                         ],
Jelte Jansen's avatar
Jelte Jansen committed
576 577
                         [using namespace Botan;
                          LibraryInitializer::initialize();
578
                          HashFunction *h = get_hash("MD5");
Jelte Jansen's avatar
Jelte Jansen committed
579 580 581
                         ])],
        [AC_MSG_RESULT([checking for Botan library... yes])],
        [AC_MSG_RESULT([checking for Botan library... no])
582
         AC_MSG_ERROR([Needs Botan library 1.8 or higher])]
Jelte Jansen's avatar
Jelte Jansen committed
583
)
584
CPPFLAGS=$CPPFLAGS_SAVED
585
LIBS=$LIBS_SAVED
Jelte Jansen's avatar
Jelte Jansen committed
586

587 588 589 590 591 592
# 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"])
593
if test "${log4cplus_path}" = "no" ; then
594 595 596
    AC_MSG_ERROR([Need log4cplus])
elif test "${log4cplus_path}" != "yes" ; then
  LOG4CPLUS_INCLUDES="-I${log4cplus_path}/include"
597
  LOG4CPLUS_LIBS="-L${log4cplus_path}/lib"
598 599 600 601 602 603 604
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"
605
			LOG4CPLUS_LIBS="-L$d/lib"
606 607 608 609 610
			break
		fi
	done
fi

611
LOG4CPLUS_LIBS="$LOG4CPLUS_LIBS -llog4cplus $MULTITHREADING_FLAG"
612

613
AC_SUBST(LOG4CPLUS_LIBS)
614 615 616 617
AC_SUBST(LOG4CPLUS_INCLUDES)

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$LOG4CPLUS_INCLUDES $CPPFLAGS"
618
LIBS_SAVED="$LIBS"
619
LIBS="$LOG4CPLUS_LIBS $LIBS"
620 621 622 623 624 625 626 627 628 629 630 631 632 633

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
634
LIBS=$LIBS_SAVED
635

636 637 638 639
#
# Configure Boost header path
#
# If explicitly specified, use it.
640 641 642 643
AC_ARG_WITH([boost-include],
  AC_HELP_STRING([--with-boost-include=PATH],
    [specify exact directory for Boost headers]),
    [boost_include_path="$withval"])
644 645 646 647 648 649 650 651 652 653 654
# 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
655
CPPFLAGS_SAVES="$CPPFLAGS"
656
if test "${boost_include_path}" ; then
657 658
	BOOST_INCLUDES="-I${boost_include_path}"
	CPPFLAGS="$CPPFLAGS $BOOST_INCLUDES"
659
fi
660
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],,
661
  AC_MSG_ERROR([Missing required header files.]))
662
CPPFLAGS="$CPPFLAGS_SAVES"
663
AC_SUBST(BOOST_INCLUDES)
664

665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724

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")
725
fi
726

727 728 729 730 731 732 733
# 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)
734

735
#
736
# Check availability of gtest, which will be used for unit tests.
737
#
738
if test "$gtest_path" != "no"
739
then
740
	DISTCHECK_GTEST_CONFIGURE_FLAG="--with-gtest=\"$gtest_path\""
741 742
	if test "$gtest_path" != "yes"; then
		GTEST_PATHS=$gtest_path
743 744 745
		if test -x "${gtest_path}/bin/gtest-config" ; then
			GTEST_CONFIG="${gtest_path}/bin/gtest-config"
		fi
746
	else
747
		AC_PATH_PROG([GTEST_CONFIG], [gtest-config])
748
	fi
749 750 751 752 753 754 755 756 757 758
	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"
759
		fi
760 761 762 763 764 765 766 767 768 769
		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"
770 771
				# There is no gtest-config script on this
				# system, which is supposed to inform us
Jeremy C. Reed's avatar
Jeremy C. Reed committed
772
				# whether we need pthreads as well (a
773 774
				# gtest compile-time option). So we still
				# need to test that manually.
775 776 777 778 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
				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
812 813 814 815 816
				break
			fi
		done
	fi
	if test "${GTEST_FOUND}" != "true"; then
817 818
		AC_MSG_ERROR([Cannot find gtest in: $GTEST_PATHS])
	fi
819
else
820 821 822
	GTEST_INCLUDES=
	GTEST_LDFLAGS=
	GTEST_LDADD=
823
	DISTCHECK_GTEST_CONFIGURE_FLAG=
824
fi
825
AM_CONDITIONAL(HAVE_GTEST, test $gtest_path != "no")
826
AC_SUBST(DISTCHECK_GTEST_CONFIGURE_FLAG)
827 828 829
AC_SUBST(GTEST_INCLUDES)
AC_SUBST(GTEST_LDFLAGS)
AC_SUBST(GTEST_LDADD)
830

831 832 833 834 835
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
836
PKG_CHECK_MODULES(SQLITE, sqlite3 >= 3.3.9, enable_features="$enable_features SQLite3")
837

838 839 840
#
# ASIO: we extensively use it as the C++ event management module.
#
841
# Use local ASIO headers from ext
842
#
843
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/asio"
844
#
845 846 847
# Use our 'coroutine' header from ext
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/coroutine"
#
848 849 850
# Disable threads: Currently we don't use them.
CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_THREADS=1"
#
851 852 853 854 855 856 857 858
# 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)
859
if test "X$ac_cv_have_kqueue" = "Xyes"; then
860 861 862 863 864 865 866 867 868 869 870
	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"
	])
871
fi
872

873 874
# perfdhcp: If the clock_gettime() function does not exist on the system,
# use an alternative supplied in the code based on gettimeofday().
875 876 877 878
CLOCK_GETTIME_LDFLAGS=
AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_GETTIME_LDFLAGS=-lrt], [])
AC_SUBST([CLOCK_GETTIME_LDFLAGS])

879 880 881 882 883 884 885 886
# 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])])

887 888 889 890
# /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
891
# gcc don't provide an option to selectively suppress this warning.
892 893 894
# 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
895
# run time performance.  Hopefully we can find a better solution or the ASIO
896 897
# 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)
898
if test "X$ac_cv_have_devpoll" = "Xyes" -a "X$GXX" = "Xyes"; then
899 900
	CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_DEV_POLL=1"
fi
901

902 903 904 905 906
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)
907 908
AC_PATH_PROGS(AWK, gawk awk)
AC_SUBST(AWK)
909

910
AC_ARG_ENABLE(man, [AC_HELP_STRING([--enable-man],
911
  [regenerate man pages [default=no]])], enable_man=yes, enable_man=no)
912 913

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

915 916 917
AC_ARG_ENABLE(install-configurations,
  [AC_HELP_STRING([--disable-install-configurations],
  [do not install configuration])], install_configurations=$enableval, install_configurations=yes)
918

919
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
920

921
AC_CONFIG_FILES([Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
922
                 doc/Makefile
923
                 doc/guide/Makefile
924
                 compatcheck/Makefile
925
                 src/Makefile
926
                 src/bin/Makefile
927
                 src/bin/bind10/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
928
                 src/bin/bind10/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
929
                 src/bin/cmdctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
930
                 src/bin/cmdctl/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
931
                 src/bin/bindctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
932
                 src/bin/bindctl/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
933
                 src/bin/cfgmgr/Makefile
934
                 src/bin/cfgmgr/plugins/Makefile
935
                 src/bin/cfgmgr/plugins/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
936
                 src/bin/cfgmgr/tests/Makefile
937
                 src/bin/host/Makefile
Evan Hunt's avatar
Evan Hunt committed
938
                 src/bin/loadzone/Makefile
939 940
                 src/bin/loadzone/tests/correct/Makefile
                 src/bin/loadzone/tests/error/Makefile
941
                 src/bin/msgq/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
942
                 src/bin/msgq/tests/Makefile
943
                 src/bin/auth/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
944
                 src/bin/auth/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
945
                 src/bin/auth/benchmarks/Makefile
946 947
                 src/bin/ddns/Makefile
                 src/bin/ddns/tests/Makefile
948
                 src/bin/dhcp6/Makefile
949
                 src/bin/dhcp6/tests/Makefile
950 951
		 src/bin/dhcp4/Makefile
		 src/bin/dhcp4/tests/Makefile
952 953
                 src/bin/resolver/Makefile
                 src/bin/resolver/tests/Makefile
954 955
                 src/bin/sockcreator/Makefile
                 src/bin/sockcreator/tests/Makefile
Likun Zhang's avatar
Likun Zhang committed
956
                 src/bin/xfrin/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
957
                 src/bin/xfrin/tests/Makefile
958
                 src/bin/xfrin/tests/testdata/Makefile
959
                 src/bin/xfrout/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
960
                 src/bin/xfrout/tests/Makefile
961 962
                 src/bin/zonemgr/Makefile
                 src/bin/zonemgr/tests/Makefile
963 964
                 src/bin/stats/Makefile
                 src/bin/stats/tests/Makefile
965
                 src/bin/usermgr/Makefile
Michal Vaner's avatar
Michal Vaner committed
966
                 src/bin/tests/Makefile
967
                 src/lib/Makefile
968 969
                 src/lib/asiolink/Makefile
                 src/lib/asiolink/tests/Makefile
Ocean Wang's avatar
Ocean Wang committed
970
                 src/lib/asiodns/Makefile
971
                 src/lib/asiodns/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
972 973 974
                 src/lib/bench/Makefile
                 src/lib/bench/example/Makefile
                 src/lib/bench/tests/Makefile
975
                 src/lib/cc/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
976
                 src/lib/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
977 978
                 src/lib/python/Makefile
                 src/lib/python/isc/Makefile
979 980
                 src/lib/python/isc/acl/Makefile
                 src/lib/python/isc/acl/tests/Makefile
981 982
                 src/lib/python/isc/util/Makefile
                 src/lib/python/isc/util/tests/Makefile
Michal 'vorner' Vaner's avatar
Michal 'vorner' Vaner committed
983 984
                 src/lib/python/isc/util/cio/Makefile
                 src/lib/python/isc/util/cio/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
985
                 src/lib/python/isc/datasrc/Makefile
986
                 src/lib/python/isc/datasrc/tests/Makefile
987
                 src/lib/python/isc/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
988
                 src/lib/python/isc/cc/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
989
                 src/lib/python/isc/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
990
                 src/lib/python/isc/config/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
991
                 src/lib/python/isc/config/tests/Makefile
992 993
                 src/lib/python/isc/log/Makefile
                 src/lib/python/isc/log/tests/Makefile
994 995
                 src/lib/python/isc/log_messages/Makefile
                 src/lib/python/isc/log_messages/work/Makefile
996
                 src/lib/python/isc/net/Makefile
Michal Vaner's avatar
Michal Vaner committed
997
                 src/lib/python/isc/net/tests/Makefile
998 999
                 src/lib/python/isc/notify/Makefile
                 src/lib/python/isc/notify/tests/Makefile
1000
                 src/lib/python/isc/testutils/Makefile
1001 1002
                 src/lib/python/isc/bind10/Makefile
                 src/lib/python/isc/bind10/tests/Makefile
1003 1004
                 src/lib/python/isc/xfrin/Makefile
                 src/lib/python/isc/xfrin/tests/Makefile
1005
                 src/lib/config/Makefile
1006
                 src/lib/config/tests/Makefile
1007
                 src/lib/config/tests/testdata/Makefile
1008 1009
                 src/lib/cryptolink/Makefile
                 src/lib/cryptolink/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
1010
                 src/lib/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1011
                 src/lib/dns/tests/Makefile
1012
                 src/lib/dns/tests/testdata/Makefile
1013
                 src/lib/dns/python/Makefile
1014
                 src/lib/dns/python/tests/Makefile
1015
                 src/lib/dns/benchmarks/Makefile
1016 1017
                 src/lib/dhcp/Makefile
                 src/lib/dhcp/tests/Makefile
1018
                 src/lib/exceptions/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
1019
                 src/lib/exceptions/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
1020 1021
                 src/lib/datasrc/Makefile
                 src/lib/datasrc/tests/Makefile
1022
                 src/lib/datasrc/tests/testdata/Makefile
1023
                 src/lib/xfr/Makefile
1024
                 src/lib/xfr/tests/Makefile
1025
                 src/lib/log/Makefile
1026
                 src/lib/log/compiler/Makefile
1027
                 src/lib/log/tests/Makefile
1028 1029
                 src/lib/resolve/Makefile
                 src/lib/resolve/tests/Makefile
1030
                 src/lib/testutils/Makefile
Michal Vaner's avatar
Michal Vaner committed
1031
                 src/lib/testutils/testdata/Makefile
1032 1033
                 src/lib/nsas/Makefile
                 src/lib/nsas/tests/Makefile
1034 1035
                 src/lib/cache/Makefile
                 src/lib/cache/tests/Makefile
1036 1037
                 src/lib/server_common/Makefile
                 src/lib/server_common/tests/Makefile