configure.ac 44.7 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
werror_ok=0
292
293
294
295
296

# 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"
297
MULTITHREADING_FLAG="-mt"
298
299
fi

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

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

# 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"
322
CXXFLAGS="$CXXFLAGS $B10_CXXFLAGS -Werror"
323
324
325
326
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)
327
328
	 werror_ok=1
	 B10_CXXFLAGS="$B10_CXXFLAGS -Werror"],
329
330
	[AC_MSG_RESULT(yes)])
CXXFLAGS="$CXXFLAGS_SAVED"
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
356
357
358
359
360
# 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

361
fi				dnl GXX = yes
362

363
AM_CONDITIONAL(GCC_WERROR_OK, test $werror_ok = 1)
364
365

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

370
371
AC_SUBST(B10_CXXFLAGS)

372
373
# Checks for libraries.

374
375
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
376
AC_SEARCH_LIBS(nanosleep, [rt])
377

378
379
380
381
382
383
# Checks for header files.

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

384

385
386
387
388
389
390
# 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)
391
      OS_TYPE="Linux"
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
      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)
408
409
410

AM_CONDITIONAL(OS_LINUX, test $OS_TYPE = Linux)
AM_COND_IF([OS_LINUX], [AC_DEFINE([OS_LINUX], [1], [Running on Linux?])])
411
AM_CONDITIONAL(OS_BSD, test $OS_TYPE = BSD)
412
AM_COND_IF([OS_BSD], [AC_DEFINE([OS_BSD], [1], [Running on BSD?])])
413
AM_CONDITIONAL(OS_SOLARIS, test $OS_TYPE = Solaris)
414
AM_COND_IF([OS_SOLARIS], [AC_DEFINE([OS_SOLARIS], [1], [Running on Solaris?])])
415

416
417
418
419
420
421
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)
422
        AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
423
424
        AC_MSG_RESULT(no))

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

445
AC_ARG_WITH(lcov,
446
[  --with-lcov[=PROGRAM]         enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
447

448
AC_ARG_WITH(gtest,
449
[  --with-gtest=PATH       specify a path to gtest header files (PATH/include) and library (PATH/lib)],
450
    gtest_path="$withval", gtest_path="no")
451
452
453
454
455

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

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

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

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

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

616
LOG4CPLUS_LIBS="$LOG4CPLUS_LIBS -llog4cplus $MULTITHREADING_FLAG"
617

618
AC_SUBST(LOG4CPLUS_LIBS)
619
620
621
622
AC_SUBST(LOG4CPLUS_INCLUDES)

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$LOG4CPLUS_INCLUDES $CPPFLAGS"
623
LIBS_SAVED="$LIBS"
624
LIBS="$LOG4CPLUS_LIBS $LIBS"
625
626
627
628
629
630
631
632
633
634
635
636
637
638

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
639
LIBS=$LIBS_SAVED
640

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

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")
730
fi
731

732
733
734
735
736
737
738
# 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)
739

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

836
837
838
839
840
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
841
PKG_CHECK_MODULES(SQLITE, sqlite3 >= 3.3.9, enable_features="$enable_features SQLite3")
842

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

878
879
# perfdhcp: If the clock_gettime() function does not exist on the system,
# use an alternative supplied in the code based on gettimeofday().
880
881
882
883
CLOCK_GETTIME_LDFLAGS=
AC_CHECK_LIB([rt], [clock_gettime], [CLOCK_GETTIME_LDFLAGS=-lrt], [])
AC_SUBST([CLOCK_GETTIME_LDFLAGS])

884
885
886
887
888
889
890
891
# 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])])

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

907
908
909
910
911
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)
912
913
AC_PATH_PROGS(AWK, gawk awk)
AC_SUBST(AWK)
914

915
AC_ARG_ENABLE(man, [AC_HELP_STRING([--enable-man],
916
  [regenerate man pages [default=no]])], enable_man=$enableval, enable_man=no)
917
918

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

920
921
922
AC_ARG_ENABLE(install-configurations,
  [AC_HELP_STRING([--disable-install-configurations],
  [do not install configuration])], install_configurations=$enableval, install_configurations=yes)
923

924
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
925

926
AC_CONFIG_FILES([Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
927
                 doc/Makefile
928
                 doc/guide/Makefile
929
                 compatcheck/Makefile
930
                 src/Makefile
931
                 src/bin/Makefile
932
                 src/bin/bind10/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
933
                 src/bin/bind10/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
934
                 src/bin/cmdctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
935
                 src/bin/cmdctl/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
936
                 src/bin/bindctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
937
                 src/bin/bindctl/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
938
                 src/bin/cfgmgr/Makefile
939
                 src/bin/cfgmgr/plugins/Makefile
940
                 src/bin/cfgmgr/plugins/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
941
                 src/bin/cfgmgr/tests/Makefile
942
                 src/bin/host/Makefile
Evan Hunt's avatar
Evan Hunt committed
943
                 src/bin/loadzone/Makefile
944
945
                 src/bin/loadzone/tests/correct/Makefile
                 src/bin/loadzone/tests/error/Makefile
946
                 src/bin/msgq/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
947
                 src/bin/msgq/tests/Makefile
948
                 src/bin/auth/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
949
                 src/bin/auth/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
950
                 src/bin/auth/benchmarks/Makefile
951
952
                 src/bin/ddns/Makefile
                 src/bin/ddns/tests/Makefile
953
                 src/bin/dhcp6/Makefile
954
                 src/bin/dhcp6/tests/Makefile
955
956
		 src/bin/dhcp4/Makefile
		 src/bin/dhcp4/tests/Makefile
957
958
                 src/bin/resolver/Makefile
                 src/bin/resolver/tests/Makefile
959
960
                 src/bin/sockcreator/Makefile
                 src/bin/sockcreator/tests/Makefile
Likun Zhang's avatar
Likun Zhang committed
961
                 src/bin/xfrin/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
962
                 src/bin/xfrin/tests/Makefile
963
                 src/bin/xfrin/tests/testdata/Makefile
964
                 src/bin/xfrout/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
965
                 src/bin/xfrout/tests/Makefile
966
967
                 src/bin/zonemgr/Makefile
                 src/bin/zonemgr/tests/Makefile
968
969
                 src/bin/stats/Makefile
                 src/bin/stats/tests/Makefile
970
                 src/bin/usermgr/Makefile
Michal Vaner's avatar
Michal Vaner committed
971
                 src/bin/tests/Makefile
972
                 src/lib/Makefile
973
974
                 src/lib/asiolink/Makefile
                 src/lib/asiolink/tests/Makefile
Ocean Wang's avatar
Ocean Wang committed
975
                 src/lib/asiodns/Makefile
976
                 src/lib/asiodns/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
977
978
979
                 src/lib/bench/Makefile
                 src/lib/bench/example/Makefile
                 src/lib/bench/tests/Makefile
980
                 src/lib/cc/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
981
                 src/lib/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
982
983
                 src/lib/python/Makefile
                 src/lib/python/isc/Makefile
984
985
                 src/lib/python/isc/acl/Makefile
                 src/lib/python/isc/acl/tests/Makefile
986
987
                 src/lib/python/isc/util/Makefile
                 src/lib/python/isc/util/tests/Makefile
Michal 'vorner' Vaner's avatar
Michal 'vorner' Vaner committed
988
989
                 src/lib/python/isc/util/cio/Makefile
                 src/lib/python/isc/util/cio/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
990
                 src/lib/python/isc/datasrc/Makefile
991
                 src/lib/python/isc/datasrc/tests/Makefile
992
                 src/lib/python/isc/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
993
                 src/lib/python/isc/cc/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
994
                 src/lib/python/isc/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
995
                 src/lib/python/isc/config/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
996
                 src/lib/python/isc/config/tests/Makefile
997
998
                 src/lib/python/isc/log/Makefile
                 src/lib/python/isc/log/tests/Makefile
999
1000
                 src/lib/python/isc/log_messages/Makefile
                 src/lib/python/isc/log_messages/work/Makefile