configure.ac 37.4 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, 20110809, 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 99
*-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__"
	;;
100
*-apple-darwin*)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
101
	# libtool doesn't work perfectly with Darwin: libtool embeds the
102 103 104 105 106 107 108 109
	# 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
	;;
110
esac
111 112 113
AM_CONDITIONAL(SET_ENV_LIBRARY_PATH, test $SET_ENV_LIBRARY_PATH = yes)
AC_SUBST(SET_ENV_LIBRARY_PATH)
AC_SUBST(ENV_LIBRARY_PATH)
114

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

148 149 150 151 152 153 154 155 156 157
# 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)

158 159 160
# Check for python development environments
if test -x ${PYTHON}-config; then
	PYTHON_INCLUDES=`${PYTHON}-config --includes`
161

162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
	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.])
179 180
	fi
fi
181

182 183 184 185
# 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
186
# it's stored in a common "hint" file) for simplicity.
187 188 189
if test $rpath_available = yes; then
	python_rpath=
	for flag in ${PYTHON_LDFLAGS}; do
190
		python_rpath="${python_rpath} `echo $flag | sed -ne 's/^\(\-L\)/-R/p'`"
191 192 193 194
	done
	PYTHON_LDFLAGS="${PYTHON_LDFLAGS} ${python_rpath}"
fi

195 196 197
AC_SUBST(PYTHON_INCLUDES)
AC_SUBST(PYTHON_LDFLAGS)

198 199 200 201 202
CPPFLAGS_SAVED="$CPPFLAGS"
CPPFLAGS="$CPPFLAGS ${PYTHON_INCLUDES}"
AC_CHECK_HEADERS([Python.h],, AC_MSG_ERROR([Missing Python.h]))
CPPFLAGS="$CPPFLAGS_SAVED"

203
# Check for python library.  Needed for Python-wrapper libraries.
204 205 206 207 208 209 210 211
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)
212
LDFLAGS=$LDFLAGS_SAVED
213

Michal Vaner's avatar
Michal Vaner committed
214 215 216 217 218 219 220
# 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)
221 222 223
        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
224 225 226
    fi
fi

227 228
# TODO: check for _sqlite3.py module

229 230
# 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
231
# used as the default value for each specific AM_CXXFLAGS:
232 233 234 235 236 237 238 239
# 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.

240
# This may be used to try linker flags.
241 242 243 244 245 246
AC_DEFUN([BIND10_CXX_TRY_FLAG], [
  AC_MSG_CHECKING([whether $CXX supports $1])

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

247 248
  AC_LINK_IFELSE([int main(void){ return 0;} ],
                 [bind10_cxx_flag=yes], [bind10_cxx_flag=no])
249 250
  CXXFLAGS="$bind10_save_CXXFLAGS"

251 252 253 254 255 256
  if test "x$bind10_cxx_flag" = "xyes"; then
    ifelse([$2], , :, [$2])
  else
    ifelse([$3], , :, [$3])
  fi

257 258 259
  AC_MSG_RESULT([$bind10_cxx_flag])
])

260
werror_ok=0
261 262 263 264 265

# 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"
266
MULTITHREADING_FLAG="-mt"
267 268
fi

269 270 271 272
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)

273
# gcc specific settings:
274
if test "X$GXX" = "Xyes"; then
275
B10_CXXFLAGS="-Wall -Wextra -Wwrite-strings -Woverloaded-virtual -Wno-sign-compare"
276 277 278
case "$host" in
*-solaris*)
	MULTITHREADING_FLAG=-pthreads
279 280
	# In Solaris, IN6ADDR_ANY_INIT and IN6ADDR_LOOPBACK_INIT need -Wno-missing-braces
	B10_CXXFLAGS="$B10_CXXFLAGS -Wno-missing-braces"
281 282 283 284 285
	;;
*)
	MULTITHREADING_FLAG=-pthread
	;;
esac
286 287 288 289 290

# 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"
291
CXXFLAGS="$CXXFLAGS $B10_CXXFLAGS -Werror"
292 293 294 295
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)
296 297
	 werror_ok=1
	 B10_CXXFLAGS="$B10_CXXFLAGS -Werror"],
298 299
	[AC_MSG_RESULT(yes)])
CXXFLAGS="$CXXFLAGS_SAVED"
300

301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329
# 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

330
fi				dnl GXX = yes
331

332
AM_CONDITIONAL(GCC_WERROR_OK, test $werror_ok = 1)
333 334

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

339 340
AC_SUBST(B10_CXXFLAGS)

341 342
# Checks for libraries.

343 344
AC_SEARCH_LIBS(inet_pton, [nsl])
AC_SEARCH_LIBS(recvfrom, [socket])
345
AC_SEARCH_LIBS(nanosleep, [rt])
346

347 348 349 350 351 352
# Checks for header files.

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

353 354


355 356 357 358 359 360
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)
361
        AC_DEFINE(HAVE_SA_LEN, 1, [Define to 1 if sockaddr has a sa_len member, and corresponding sin_len and sun_len])],
362 363
        AC_MSG_RESULT(no))

364 365
AC_ARG_WITH(pycoverage,
[  --with-pycoverage[=PROGRAM]         enable python code coverage using the specified coverage], pycoverage="$withval", pycoverage="no")
366 367 368 369 370 371 372 373
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"
374
else
375 376 377
	PYCOVERAGE="$pycoverage"
	PYCOVERAGE_RUN="${PYCOVERAGE} run --branch --append"
	USE_PYCOVERAGE="yes"
378
fi
379
AM_CONDITIONAL(ENABLE_PYTHON_COVERAGE, test x$USE_PYCOVERAGE != xno)
380
AC_SUBST(PYCOVERAGE)
Jeremy C. Reed's avatar
Jeremy C. Reed committed
381
AC_SUBST(PYCOVERAGE_RUN)
382
AC_SUBST(USE_PYCOVERAGE)
383

384
AC_ARG_WITH(lcov,
385
[  --with-lcov[=PROGRAM]         enable gtest and coverage target using the specified lcov], lcov="$withval", lcov="no")
386

387
AC_ARG_WITH(gtest,
388
[  --with-gtest=PATH       specify a path to gtest header files (PATH/include) and library (PATH/lib)],
389
    gtest_path="$withval", gtest_path="no")
390 391 392 393 394

USE_LCOV="no"
if test "$lcov" != "no"; then
	# force gtest if not set
	if test "$gtest_path" = "no"; then
395 396
#		AC_MSG_ERROR("lcov needs gtest for test coverage report")
		AC_MSG_NOTICE([gtest support is now enabled, because used by coverage tests])
397 398 399
		gtest_path="yes"
	fi
	if test "$lcov" != "yes"; then
400
		LCOV=$lcov
401
	else
402
		AC_PATH_PROG([LCOV], [lcov])
403
	fi
404 405 406 407
	if test -x "${LCOV}"; then
		USE_LCOV="yes"
	else
		AC_MSG_ERROR([Cannot find lcov.])
408 409 410 411 412 413
	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
414
	# GCC specific?
415
	CXXFLAGS="$CXXFLAGS -fprofile-arcs -ftest-coverage"
416
	LIBS=" $LIBS -lgcov"
417 418 419 420 421 422 423
	AC_SUBST(CPPFLAGS)
	AC_SUBST(LIBS)
	AC_SUBST(LCOV)
	AC_SUBST(GENHTML)
fi
AC_SUBST(USE_LCOV)

Jelte Jansen's avatar
Jelte Jansen committed
424
# Check for Botan
Jelte Jansen's avatar
Jelte Jansen committed
425
botan_path="yes"
Jelte Jansen's avatar
Jelte Jansen committed
426 427 428 429
AC_ARG_WITH([botan],
  AC_HELP_STRING([--with-botan=PATH],
    [specify exact directory of Botan library]),
    [botan_path="$withval"])
Jelte Jansen's avatar
Jelte Jansen committed
430 431
if test "${botan_path}" == "no" ; then
    AC_MSG_ERROR([Need botan for libcryptolink])
Jelte Jansen's avatar
Jelte Jansen committed
432
fi
Jelte Jansen's avatar
Jelte Jansen committed
433 434 435 436 437 438 439 440 441 442 443 444
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
        AC_PATH_PROG([BOTAN_CONFIG], [botan-config])
fi

if test -x "${BOTAN_CONFIG}" ; then
    BOTAN_LDFLAGS=`${BOTAN_CONFIG} --libs`
445 446 447 448 449 450
    # 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.
    echo ${BOTAN_LDFLAGS} | grep -- -L > /dev/null || \
	    BOTAN_LDFLAGS="-L`${BOTAN_CONFIG} --prefix`/lib ${BOTAN_LDFLAGS}"
Jelte Jansen's avatar
Jelte Jansen committed
451
    BOTAN_INCLUDES=`${BOTAN_CONFIG} --cflags`
452 453
    echo ${BOTAN_INCLUDES} | grep -- -I > /dev/null || \
	    BOTAN_INCLUDES="-I`${BOTAN_CONFIG} --prefix`/include ${BOTAN_INCLUDES}"
Jelte Jansen's avatar
Jelte Jansen committed
454 455 456 457 458 459
    # 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
460
	AC_SUBST(BOTAN_RPATH)
461 462 463 464 465 466 467 468

	# 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.
469
        LDFLAGS="$BOTAN_RPATH $LDFLAGS"
Jelte Jansen's avatar
Jelte Jansen committed
470 471
    fi

472 473
    AC_SUBST(BOTAN_LDFLAGS)
    AC_SUBST(BOTAN_INCLUDES)
Jelte Jansen's avatar
Jelte Jansen committed
474
fi
475 476 477

CPPFLAGS_SAVED=$CPPFLAGS
CPPFLAGS="$BOTAN_INCLUDES $CPPFLAGS"
478
LDFLAGS_SAVED="$LDFLAGS"
479 480
LDFLAGS="$BOTAN_LDFLAGS $LDFLAGS"

Jelte Jansen's avatar
Jelte Jansen committed
481 482
AC_CHECK_HEADERS([botan/botan.h],,AC_MSG_ERROR([Missing required header files.]))
AC_LINK_IFELSE(
483 484 485
        [AC_LANG_PROGRAM([#include <botan/botan.h>
                          #include <botan/hash.h>
                         ],
Jelte Jansen's avatar
Jelte Jansen committed
486 487
                         [using namespace Botan;
                          LibraryInitializer::initialize();
488
                          HashFunction *h = get_hash("MD5");
Jelte Jansen's avatar
Jelte Jansen committed
489 490 491
                         ])],
        [AC_MSG_RESULT([checking for Botan library... yes])],
        [AC_MSG_RESULT([checking for Botan library... no])
492
         AC_MSG_ERROR([Needs Botan library 1.8 or higher])]
Jelte Jansen's avatar
Jelte Jansen committed
493
)
494 495
CPPFLAGS=$CPPFLAGS_SAVED
LDFLAGS=$LDFLAGS_SAVED
Jelte Jansen's avatar
Jelte Jansen committed
496

497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545
# 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"])
if test "${log4cplus_path}" == "no" ; then
    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"
LDFLAGS_SAVED="$LDFLAGS"
LDFLAGS="$LOG4CPLUS_LDFLAGS $LDFLAGS"

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
LDFLAGS=$LDFLAGS_SAVED

546 547 548 549
#
# Configure Boost header path
#
# If explicitly specified, use it.
550 551 552 553
AC_ARG_WITH([boost-include],
  AC_HELP_STRING([--with-boost-include=PATH],
    [specify exact directory for Boost headers]),
    [boost_include_path="$withval"])
554 555 556 557 558 559 560 561 562 563 564
# 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
565
CPPFLAGS_SAVES="$CPPFLAGS"
566
if test "${boost_include_path}" ; then
567 568
	BOOST_INCLUDES="-I${boost_include_path}"
	CPPFLAGS="$CPPFLAGS $BOOST_INCLUDES"
569
fi
570
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],,
571
  AC_MSG_ERROR([Missing required header files.]))
572
CPPFLAGS="$CPPFLAGS_SAVES"
573
AC_SUBST(BOOST_INCLUDES)
574

575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634

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")
635
fi
636

637

638
#
639
# Check availability of gtest, which will be used for unit tests.
640
#
641
if test "$gtest_path" != "no"
642
then
643 644
	if test "$gtest_path" != "yes"; then
		GTEST_PATHS=$gtest_path
645 646 647
		if test -x "${gtest_path}/bin/gtest-config" ; then
			GTEST_CONFIG="${gtest_path}/bin/gtest-config"
		fi
648
	else
649
		AC_PATH_PROG([GTEST_CONFIG], [gtest-config])
650
	fi
651 652 653 654 655 656 657 658 659 660
	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"
661
		fi
662 663 664 665 666 667 668 669 670 671 672 673 674 675 676
		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
677 678
		AC_MSG_ERROR([Cannot find gtest in: $GTEST_PATHS])
	fi
679
else
680 681 682
	GTEST_INCLUDES=
	GTEST_LDFLAGS=
	GTEST_LDADD=
683
fi
684 685 686 687
AM_CONDITIONAL(HAVE_GTEST, test $gtest_path != "no")
AC_SUBST(GTEST_INCLUDES)
AC_SUBST(GTEST_LDFLAGS)
AC_SUBST(GTEST_LDADD)
688

689 690 691 692 693
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
694
PKG_CHECK_MODULES(SQLITE, sqlite3 >= 3.3.9, enable_features="$enable_features SQLite3")
695

Jelte Jansen's avatar
 
Jelte Jansen committed
696 697 698 699 700 701 702
# 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)

703 704
AC_SUBST(MULTITHREADING_FLAG)

705 706 707
#
# ASIO: we extensively use it as the C++ event management module.
#
708
# Use local ASIO headers from ext
709
#
710
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/asio"
711
#
712 713 714
# Use our 'coroutine' header from ext
CPPFLAGS="$CPPFLAGS -I\$(top_srcdir)/ext/coroutine"
#
715 716 717
# Disable threads: Currently we don't use them.
CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_THREADS=1"
#
718 719 720 721 722 723 724 725
# 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)
726
if test "X$ac_cv_have_kqueue" = "Xyes"; then
727 728 729 730 731 732 733 734 735 736 737
	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"
	])
738
fi
739 740 741 742 743

# /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
744
# gcc don't provide an option to selectively suppress this warning.
745 746 747
# 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
748
# run time performance.  Hopefully we can find a better solution or the ASIO
749 750
# 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)
751
if test "X$ac_cv_have_devpoll" = "Xyes" -a "X$GXX" = "Xyes"; then
752 753
	CPPFLAGS="$CPPFLAGS -DASIO_DISABLE_DEV_POLL=1"
fi
754

755 756 757 758 759 760
#
# Perl is optional; it is used only by some of the system test scripts.
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)

761
AC_ARG_ENABLE(man, [AC_HELP_STRING([--enable-man],
762
  [regenerate man pages [default=no]])], enable_man=yes, enable_man=no)
763 764

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

766 767 768
AC_ARG_ENABLE(install-configurations,
  [AC_HELP_STRING([--disable-install-configurations],
  [do not install configuration])], install_configurations=$enableval, install_configurations=yes)
769

770
AM_CONDITIONAL(INSTALL_CONFIGURATIONS, test x$install_configurations = xyes || test x$install_configurations = xtrue)
771

772
AC_CONFIG_FILES([Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
773
                 doc/Makefile
774
                 doc/guide/Makefile
775
                 src/Makefile
776
                 src/bin/Makefile
777
                 src/bin/bind10/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
778
                 src/bin/bind10/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
779
                 src/bin/cmdctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
780
                 src/bin/cmdctl/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
781
                 src/bin/bindctl/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
782
                 src/bin/bindctl/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
783
                 src/bin/cfgmgr/Makefile
784
                 src/bin/cfgmgr/plugins/Makefile
785
                 src/bin/cfgmgr/plugins/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
786
                 src/bin/cfgmgr/tests/Makefile
787
                 src/bin/host/Makefile
Evan Hunt's avatar
Evan Hunt committed
788
                 src/bin/loadzone/Makefile
789 790
                 src/bin/loadzone/tests/correct/Makefile
                 src/bin/loadzone/tests/error/Makefile
791
                 src/bin/msgq/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
792
                 src/bin/msgq/tests/Makefile
793
                 src/bin/auth/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
794
                 src/bin/auth/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
795
                 src/bin/auth/benchmarks/Makefile
796
                 src/bin/dhcp6/Makefile
797
                 src/bin/dhcp6/tests/Makefile
798 799
                 src/bin/resolver/Makefile
                 src/bin/resolver/tests/Makefile
800 801
                 src/bin/sockcreator/Makefile
                 src/bin/sockcreator/tests/Makefile
Likun Zhang's avatar
Likun Zhang committed
802
                 src/bin/xfrin/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
803
                 src/bin/xfrin/tests/Makefile
804
                 src/bin/xfrout/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
805
                 src/bin/xfrout/tests/Makefile
806 807
                 src/bin/zonemgr/Makefile
                 src/bin/zonemgr/tests/Makefile
808 809
                 src/bin/stats/Makefile
                 src/bin/stats/tests/Makefile
810 811 812
                 src/bin/stats/tests/isc/Makefile
                 src/bin/stats/tests/isc/cc/Makefile
                 src/bin/stats/tests/isc/config/Makefile
Likun Zhang's avatar
Likun Zhang committed
813
                 src/bin/stats/tests/isc/util/Makefile
814
                 src/bin/stats/tests/isc/log/Makefile
815
                 src/bin/stats/tests/testdata/Makefile
Naoki Kambe's avatar
Naoki Kambe committed
816
                 src/bin/stats/tests/http/Makefile
817
                 src/bin/usermgr/Makefile
Michal Vaner's avatar
Michal Vaner committed
818
                 src/bin/tests/Makefile
819
                 src/lib/Makefile
820 821
                 src/lib/asiolink/Makefile
                 src/lib/asiolink/tests/Makefile
Ocean Wang's avatar
Ocean Wang committed
822
                 src/lib/asiodns/Makefile
823
                 src/lib/asiodns/tests/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
824 825 826
                 src/lib/bench/Makefile
                 src/lib/bench/example/Makefile
                 src/lib/bench/tests/Makefile
827
                 src/lib/cc/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
828
                 src/lib/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
829 830
                 src/lib/python/Makefile
                 src/lib/python/isc/Makefile
831 832
                 src/lib/python/isc/acl/Makefile
                 src/lib/python/isc/acl/tests/Makefile
833 834
                 src/lib/python/isc/util/Makefile
                 src/lib/python/isc/util/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
835
                 src/lib/python/isc/datasrc/Makefile
836
                 src/lib/python/isc/datasrc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
837
                 src/lib/python/isc/cc/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
838
                 src/lib/python/isc/cc/tests/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
839
                 src/lib/python/isc/config/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
840
                 src/lib/python/isc/config/tests/Makefile
841 842
                 src/lib/python/isc/log/Makefile
                 src/lib/python/isc/log/tests/Makefile
843
                 src/lib/python/isc/net/Makefile
Michal Vaner's avatar
Michal Vaner committed
844
                 src/lib/python/isc/net/tests/Makefile
845 846
                 src/lib/python/isc/notify/Makefile
                 src/lib/python/isc/notify/tests/Makefile
847
                 src/lib/python/isc/testutils/Makefile
848 849
                 src/lib/python/isc/bind10/Makefile
                 src/lib/python/isc/bind10/tests/Makefile
850
                 src/lib/config/Makefile
851
                 src/lib/config/tests/Makefile
852
                 src/lib/config/tests/testdata/Makefile
853 854
                 src/lib/cryptolink/Makefile
                 src/lib/cryptolink/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
855
                 src/lib/dns/Makefile
Jeremy C. Reed's avatar
Jeremy C. Reed committed
856
                 src/lib/dns/tests/Makefile
857
                 src/lib/dns/tests/testdata/Makefile
858
                 src/lib/dns/python/Makefile
859
                 src/lib/dns/python/tests/Makefile
860
                 src/lib/dns/benchmarks/Makefile
861
                 src/lib/exceptions/Makefile
JINMEI Tatuya's avatar
JINMEI Tatuya committed
862
                 src/lib/exceptions/tests/Makefile
Evan Hunt's avatar
Evan Hunt committed
863 864
                 src/lib/datasrc/Makefile
                 src/lib/datasrc/tests/Makefile
865
                 src/lib/datasrc/tests/testdata/Makefile
866
                 src/lib/xfr/Makefile
867
                 src/lib/log/Makefile
868
                 src/lib/log/compiler/Makefile
869
                 src/lib/log/tests/Makefile
870 871
                 src/lib/resolve/Makefile
                 src/lib/resolve/tests/Makefile
872
                 src/lib/testutils/Makefile
Michal Vaner's avatar
Michal Vaner committed
873
                 src/lib/testutils/testdata/Makefile
874 875
                 src/lib/nsas/Makefile
                 src/lib/nsas/tests/Makefile
876 877
                 src/lib/cache/Makefile
                 src/lib/cache/tests/Makefile
878 879
                 src/lib/server_common/Makefile
                 src/lib/server_common/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
880 881 882
                 src/lib/util/Makefile
                 src/lib/util/io/Makefile
                 src/lib/util/unittests/Makefile
883
                 src/lib/util/python/Makefile
884
                 src/lib/util/pyunittests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
885
                 src/lib/util/tests/Makefile
886 887
                 src/lib/acl/Makefile
                 src/lib/acl/tests/Makefile
888 889
                 tests/Makefile
                 tests/system/Makefile
Stephen Morris's avatar
Stephen Morris committed
890 891 892
                 tests/tools/Makefile
                 tests/tools/badpacket/Makefile
                 tests/tools/badpacket/tests/Makefile
Jelte Jansen's avatar
Jelte Jansen committed
893
               ])
894 895
AC_OUTPUT([doc/version.ent
           src/bin/cfgmgr/b10-cfgmgr.py
Jelte Jansen's avatar
Jelte Jansen committed
896
           src/bin/cfgmgr/tests/b10-cfgmgr_test.py
897
           src/bin/cmdctl/cmdctl.py
898
           src/bin/cmdctl/run_b10-cmdctl.sh
899
           src/bin/cmdctl/tests/cmdctl_test
Likun Zhang's avatar
 
Likun Zhang committed
900
           src/bin/cmdctl/cmdctl.spec.pre
901
           src/bin/xfrin/tests/xfrin_test
Likun Zhang's avatar
Likun Zhang committed
902 903
           src/bin/xfrin/xfrin.py
           src/bin/xfrin/run_b10-xfrin.sh
904
           src/bin/xfrout/xfrout.py
905
           src/bin/xfrout/xfrout.spec.pre
Likun Zhang's avatar
Likun Zhang committed
906
           src/bin/xfrout/tests/xfrout_test
907
           src/bin/xfrout/tests/xfrout_test.py
908
           src/bin/xfrout/run_b10-xfrout.sh
909 910
           src/bin/resolver/resolver.spec.pre
           src/bin/resolver/spec_config.h.pre
911 912 913 914
           src/bin/zonemgr/zonemgr.py
           src/bin/zonemgr/zonemgr.spec.pre
           src/bin/zonemgr/tests/zonemgr_test
           src/bin/zonemgr/run_b10-zonemgr.sh
915
           src/bin/stats/stats.py
Naoki Kambe's avatar
Naoki Kambe committed
916
           src/bin/stats/stats_httpd.py
917
           src/bin/bind10/bind10_src.py
918
           src/bin/bind10/run_bind10.sh
919
           src/bin/bind10/tests/bind10_test.py
920
           src/bin/bindctl/run_bindctl.sh
921
           src/bin/bindctl/bindctl_main.py
922
           src/bin/bindctl/tests/bindctl_test
923
           src/bin/loadzone/run_loadzone.sh
924 925
           src/bin/loadzone/tests/correct/correct_test.sh
           src/bin/loadzone/tests/error/error_test.sh
Evan Hunt's avatar
Evan Hunt committed
926
           src/bin/loadzone/b10-loadzone.py
927 928
           src/bin/usermgr/run_b10-cmdctl-usermgr.sh
           src/bin/usermgr/b10-cmdctl-usermgr.py
929
           src/bin/msgq/msgq.py
Jeremy C. Reed's avatar
Jeremy C. Reed committed
930
           src/bin/msgq/tests/msgq_test
931
           src/bin/msgq/run_msgq.sh
932
           src/bin/auth/auth.spec.pre
933
           src/bin/auth/spec_config.h.pre
934
           src/bin/dhcp6/spec_config.h.pre
Michal Vaner's avatar
Michal Vaner committed
935
           src/bin/tests/process_rename_test.py
936 937
           src/lib/config/tests/data_def_unittests_config.h
           src/lib/python/isc/config/tests/config_test
938
           src/lib/python/isc/cc/tests/cc_test
939
           src/lib/python/isc/notify/tests/notify_out_test
940
           src/lib/python/isc/log/tests/log_console.py
Jeremy C. Reed's avatar
Jeremy C. Reed committed
941
           src/lib/dns/gen-rdatacode.py
942
           src/lib/python/bind10_config.py
943
           src/lib/cc/session_config.h.pre
Jelte Jansen's avatar
Jelte Jansen committed
944
           src/lib/cc/tests/session_unittests_config.h
945
           src/lib/log/tests/console_test.sh
946
           src/lib/log/tests/destination_test.sh
947
           src/lib/log/tests/init_logger_test.sh
948 949
           src/lib/log/tests/local_file_test.sh
           src/lib/log/tests/severity_test.sh
950
           src/lib/log/tests/tempdir.h
951
           src/lib/util/python/mkpywrapper.py
952
           src/lib/util/python/gen_wiredata.py
953
           src/lib/server_common/tests/data_path.h
954
           tests/system/conf.sh
955 956
           tests/system/glue/setup.sh
           tests/system/glue/nsx1/b10-config.db
957
           tests/system/bindctl/nsx1/b10-config.db.template
958
          ], [
959
           chmod +x src/bin/cmdctl/run_b10-cmdctl.sh
Likun Zhang's avatar
Likun Zhang committed
960
           chmod +x src/bin/xfrin/run_b10-xfrin.sh
961
           chmod +x src/bin/xfrout/run_b10-xfrout.sh
962
           chmod +x src/bin/zonemgr/run_b10-zonemgr.sh
963
           chmod +x src/bin/bind10/run_bind10.sh
964 965
           chmod +x src/bin/cmdctl/tests/cmdctl_test
           chmod +x src/bin/xfrin/tests/xfrin_test
Likun Zhang's avatar
Likun Zhang committed
966
           chmod +x src/bin/xfrout/tests/xfrout_test
967
           chmod +x src/bin/zonemgr/tests/zonemgr_test
968
           chmod +x src/bin/bindctl/tests/bindctl_test
969 970
           chmod +x src/bin/bindctl/run_bindctl.sh
           chmod +x src/bin/loadzone/run_loadzone.sh
971 972
           chmod +x src/bin/loadzone/tests/correct/correct_test.sh
           chmod +x src/bin/loadzone/tests/error/error_test.sh
973
           chmod +x src/bin/usermgr/run_b10-cmdctl-usermgr.sh
974
           chmod +x src/bin/msgq/run_msgq.sh
Jeremy C. Reed's avatar
Jeremy C. Reed committed
975
           chmod +x src/bin/msgq/tests/msgq_test
Jeremy C. Reed's avatar
Jeremy C. Reed committed
976
           chmod +x src/lib/dns/gen-rdatacode.py
977
           chmod +x src/lib/log/tests/console_test.sh
978
           chmod +x src/lib/log/tests/destination_test.sh
</