diff options
author | JINMEI Tatuya <jinmei@isc.org> | 2012-12-28 02:54:42 +0100 |
---|---|---|
committer | JINMEI Tatuya <jinmei@isc.org> | 2012-12-28 02:54:42 +0100 |
commit | 96e4248d61ccbcd23c7563f0a36d5443b607ea02 (patch) | |
tree | 632704bf68d2b2d7ee3a04c00d7602aebbc9c759 /m4macros | |
parent | [master] fix spelling typo (diff) | |
download | kea-96e4248d61ccbcd23c7563f0a36d5443b607ea02.tar.xz kea-96e4248d61ccbcd23c7563f0a36d5443b607ea02.zip |
[1991] moved boost-related config to a separate m4
in order to keep the main configure.ac more concise, and so that we can
eventually introduce more fine-grained configuration (e.g., skipping some
checks for DNS/DHCP-only build)
At the moment, this is just a cleanup, and doesn't change the behavior itself.
Diffstat (limited to 'm4macros')
-rw-r--r-- | m4macros/ax_boost_for_bind10.m4 | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/m4macros/ax_boost_for_bind10.m4 b/m4macros/ax_boost_for_bind10.m4 new file mode 100644 index 0000000000..9b48a4821b --- /dev/null +++ b/m4macros/ax_boost_for_bind10.m4 @@ -0,0 +1,88 @@ +dnl @synopsis AX_BOOST_FOR_BIND10 +dnl +dnl Test for the Boost C++ header files intended to be used within BIND 10 +dnl +dnl If no path to the installed boost header files is given via the +dnl --with-boost-include option, the macro searchs under +dnl /usr/local /usr/pkg /opt /opt/local directories. +dnl If it cannot detect any workable path for Boost, this macro treats it +dnl as a fatal error (so it cannot be called if the availability of Boost +dnl is optional). +dnl +dnl This macro also tries to identify some known portability issues, and +dnl sets corresponding variables so the caller can react to (or ignore, +dnl depending on other configuration) specific issues appropriately. +dnl +dnl This macro calls: +dnl +dnl AC_SUBST(BOOST_INCLUDES) +dnl +dnl And possibly sets: +dnl CPPFLAGS_BOOST_THREADCONF should be added to CPPFLAGS by caller +dnl BOOST_OFFSET_PTR_WOULDFAIL set to yes if offset_ptr would cause build +dnl error; otherwise set to no +dnl + +AC_DEFUN([AX_BOOST_FOR_BIND10], [ +AC_LANG_SAVE +AC_LANG([C++]) + +# +# Configure Boost header path +# +# If explicitly specified, use it. +AC_ARG_WITH([boost-include], + AC_HELP_STRING([--with-boost-include=PATH], + [specify exact directory for Boost headers]), + [boost_include_path="$withval"]) +# 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 + +# Check the path with some specific headers. +CPPFLAGS_SAVED="$CPPFLAGS" +if test "${boost_include_path}" ; then + BOOST_INCLUDES="-I${boost_include_path}" + CPPFLAGS="$CPPFLAGS $BOOST_INCLUDES" +fi +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],, + AC_MSG_ERROR([Missing required header files.])) + +# Detect whether Boost tries to use threads by default, and, if not, +# make it sure explicitly. In some systems the automatic detection +# may depend on preceding header files, and if inconsistency happens +# it could lead to a critical disruption. +AC_MSG_CHECKING([whether Boost tries to use threads]) +AC_TRY_COMPILE([ +#include <boost/config.hpp> +#ifdef BOOST_HAS_THREADS +#error "boost will use threads" +#endif],, +[AC_MSG_RESULT(no) + CPPFLAGS_BOOST_THREADCONF="-DBOOST_DISABLE_THREADS=1"], +[AC_MSG_RESULT(yes)]) + +# Boost offset_ptr is known to not compile on some platforms, depending on +# boost version, its local configuration, and compiler. Detect it. +AC_MSG_CHECKING([Boost offset_ptr compiles]) +AC_TRY_COMPILE([ +#include <boost/interprocess/offset_ptr.hpp> +],, +[AC_MSG_RESULT(yes) + BOOST_OFFSET_PTR_WOULDFAIL=no], +[AC_MSG_RESULT(no) + BOOST_OFFSET_PTR_WOULDFAIL=yes]) + +AC_SUBST(BOOST_INCLUDES) + +CPPFLAGS="$CPPFLAGS_SAVED" +AC_LANG_RESTORE +])dnl AX_BOOST_FOR_BIND10 |