diff options
-rw-r--r-- | configure.ac | 318 |
1 files changed, 173 insertions, 145 deletions
diff --git a/configure.ac b/configure.ac index 57c8c03..df5e89f 100644 --- a/configure.ac +++ b/configure.ac @@ -1,22 +1,20 @@ # -*- Autoconf -*- # Process this file with autoconf to produce a configure script. -AC_PREREQ(2.61) +AC_PREREQ([2.64]) # # The Crossroads version number is extracted from include/xs.h using # the version.sh script. Hence, it should be updated there. # The version in git should reflect the *next* version planned. # -AC_INIT([libxs],[m4_esyscmd([./version.sh])],[crossroads-dev@groups.crossroads.io]) +AC_INIT([libxs], [m4_esyscmd([./version.sh])], + [crossroads-dev@groups.crossroads.io], [libxs], [http://www.crossroads.io/]) -AC_CONFIG_AUX_DIR(config) -AC_CONFIG_MACRO_DIR(config) -AM_CONFIG_HEADER(src/platform.hpp) -AM_INIT_AUTOMAKE(tar-ustar dist-zip foreign) +AC_CONFIG_AUX_DIR([config]) +AC_CONFIG_MACRO_DIR([config]) +AM_CONFIG_HEADER([src/platform.hpp]) +AM_INIT_AUTOMAKE([tar-ustar dist-zip foreign]) m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])]) -# This lets us use PACKAGE_VERSION in Makefiles -AC_SUBST(PACKAGE_VERSION) - # ABI version for libxs (Libtool -version-info) # # Don't change this unless you know exactly what you're doing and have read and @@ -34,7 +32,7 @@ AC_SUBST(LIBXS_ABI_VERSION) # # libzmq -version-info current:revision:age LIBZMQ_ABI_VERSION="1:0:0" -AC_SUBST(LIBZMQ_ABI_VERSION) +AC_SUBST([LIBZMQ_ABI_VERSION]) # Take a copy of original flags XS_ORIG_CFLAGS="${CFLAGS:-none}" @@ -87,26 +85,26 @@ CPPFLAGS="-D_REENTRANT -D_THREAD_SAFE $CPPFLAGS" AC_CANONICAL_HOST # OS-specific tests -case "${host_os}" in - *linux*) +AS_CASE(["${host_os}"], + [*linux*], [ # Define on Linux to enable all library features. Define if using a gnu compiler - if test "x$GXX" = "xyes"; then + AS_IF([test "x$GXX" = "xyes"], [ CPPFLAGS="-D_GNU_SOURCE $CPPFLAGS" - fi - AC_DEFINE(XS_HAVE_LINUX, 1, [Have Linux OS]) - - case "${host_os}" in - *android*) - AC_DEFINE(XS_HAVE_ANDROID, 1, [Have Android OS]) - ;; - esac - ;; - *solaris*) + ]) + AC_DEFINE([XS_HAVE_LINUX], [1], [Have Linux OS]) + + AS_CASE(["${host_os}"], + [*android*], [ + AC_DEFINE([XS_HAVE_ANDROID], [1], [Have Android OS]) + ] + ) + ], + [*solaris*], [ # Define on Solaris to enable all library features CPPFLAGS="-D_PTHREADS $CPPFLAGS" - AC_DEFINE(XS_HAVE_SOLARIS, 1, [Have Solaris OS]) - AC_CHECK_LIB(socket, socket) - AC_CHECK_LIB(nsl, gethostbyname) + AC_DEFINE([XS_HAVE_SOLARIS], [1], [Have Solaris OS]) + AC_CHECK_LIB([socket], [socket]) + AC_CHECK_LIB([nsl], [gethostbyname]) AC_MSG_CHECKING([whether atomic operations can be used]) AC_COMPILE_IFELSE([AC_LANG_PROGRAM( [[#include <atomic.h>]], @@ -117,29 +115,29 @@ case "${host_os}" in [solaris_has_atomic=no]) AC_MSG_RESULT([$solaris_has_atomic]) # Solaris 8 does not have atomic operations exported to user space. - if test "x$solaris_has_atomic" = "xno"; then - AC_DEFINE(XS_FORCE_MUTEXES, 1, [Force to use mutexes]) - fi - ;; - *freebsd*) + AS_IF([test "x$solaris_has_atomic" = "xno"], [ + AC_DEFINE([XS_FORCE_MUTEXES], [1], [Force to use mutexes]) + ]) + ], + [*freebsd*], [ # Define on FreeBSD to enable all library features CPPFLAGS="-D__BSD_VISIBLE $CPPFLAGS" - AC_DEFINE(XS_HAVE_FREEBSD, 1, [Have FreeBSD OS]) - ;; - *darwin*) + AC_DEFINE([XS_HAVE_FREEBSD], [1], [Have FreeBSD OS]) + ], + [*darwin*], [ # Define on Darwin to enable all library features CPPFLAGS="-D_DARWIN_C_SOURCE $CPPFLAGS" libxs_pedantic="no" libxs_werror="no" - AC_DEFINE(XS_HAVE_OSX, 1, [Have DarwinOSX OS]) + AC_DEFINE([XS_HAVE_OSX], [1], [Have DarwinOSX OS]) AC_LANG_PUSH([C++]) LIBXS_CHECK_LANG_FLAG_PREPEND([-Wno-uninitialized]) AC_LANG_POP([C++]) - ;; - *netbsd*) + ], + [*netbsd*], [ # Define on NetBSD to enable all library features CPPFLAGS="-D_NETBSD_SOURCE $CPPFLAGS" - AC_DEFINE(XS_HAVE_NETBSD, 1, [Have NetBSD OS]) + AC_DEFINE([XS_HAVE_NETBSD], [1], [Have NetBSD OS]) # NetBSD 5.0 and newer provides atomic operations but we can # only use these on systems where PR #42842 has been fixed so # we must try and link a test program using C++. @@ -155,39 +153,39 @@ case "${host_os}" in [libxs_netbsd_has_atomic=no]) AC_LANG_POP([C++]) AC_MSG_RESULT([$libxs_netbsd_has_atomic]) - if test "x$libxs_netbsd_has_atomic" = "xno"; then - AC_DEFINE(XS_FORCE_MUTEXES, 1, [Force to use mutexes]) - fi - ;; - *openbsd*) + AS_IF([test "x$libxs_netbsd_has_atomic" = "xno"], [ + AC_DEFINE([XS_FORCE_MUTEXES], [1], [Force to use mutexes]) + ]) + ], + [openbsd*], [ # Define on OpenBSD to enable all library features CPPFLAGS="-D_BSD_SOURCE $CPPFLAGS" - AC_DEFINE(XS_HAVE_OPENBSD, 1, [Have OpenBSD OS]) - ;; - *nto-qnx*) + AC_DEFINE([XS_HAVE_OPENBSD], [1], [Have OpenBSD OS]) + ], + [*nto-qnx*], [ libxs_pedantic="no" - AC_DEFINE(XS_HAVE_QNXNTO, 1, [Have QNX Neutrino OS]) - AC_CHECK_LIB(socket, socket) - ;; - *aix*) - AC_DEFINE(XS_HAVE_AIX, 1, [Have AIX OS]) - ;; - *hpux*) + AC_DEFINE([XS_HAVE_QNXNTO], [1], [Have QNX Neutrino OS]) + AC_CHECK_LIB([socket], [socket]) + ], + [*aix*], [ + AC_DEFINE([XS_HAVE_AIX], [1], [Have AIX OS]) + ], + [*hpux*], [ # Define on HP-UX to enable all library features CPPFLAGS="-D_POSIX_C_SOURCE=200112L $CPPFLAGS" - AC_DEFINE(XS_HAVE_HPUX, 1, [Have HPUX OS]) + AC_DEFINE([XS_HAVE_HPUX], [1], [Have HPUX OS]) LIBXS_CHECK_LANG_FLAG_PREPEND([-Ae]) - AC_CHECK_FUNCS(gethrtime) - ;; - *mingw32*) - AC_DEFINE(XS_HAVE_WINDOWS, 1, [Have Windows OS]) - AC_DEFINE(XS_HAVE_MINGW32, 1, [Have MinGW32]) - AC_CHECK_HEADERS(windows.h) - AC_CHECK_LIB(ws2_32, main, , + AC_CHECK_FUNCS([gethrtime]) + ], + [*mingw32*], [ + AC_DEFINE([XS_HAVE_WINDOWS], [1], [Have Windows OS]) + AC_DEFINE([XS_HAVE_MINGW32], [1], [Have MinGW32]) + AC_CHECK_HEADERS([windows.h]) + AC_CHECK_LIB([ws2_32], [main], [], [AC_MSG_ERROR([cannot link with ws2_32.dll.])]) - AC_CHECK_LIB(rpcrt4, main, , + AC_CHECK_LIB([rpcrt4], [main], [], [AC_MSG_ERROR([cannot link with rpcrt4.dll.])]) - AC_CHECK_LIB(iphlpapi, main, , + AC_CHECK_LIB([iphlpapi], [main], [], [AC_MSG_ERROR([cannot link with iphlpapi.dll.])]) # mingw32 defines __int64_t as long long AC_LANG_PUSH([C++]) @@ -196,83 +194,96 @@ case "${host_os}" in libxs_on_mingw32="yes" libxs_dso_visibility="no" - if test "x$enable_static" = "xyes"; then + AS_IF([test "x$enable_static" = "xyes"], [ AC_MSG_ERROR([Building static libraries is not supported under MinGW32]) - fi - ;; - *cygwin*) + ]) + ], + [*cygwin*], [ # Define on Cygwin to enable all library features CPPFLAGS="-D_GNU_SOURCE $CPPFLAGS" - AC_DEFINE(XS_HAVE_CYGWIN, 1, [Have Cygwin]) - if test "x$enable_static" = "xyes"; then + AC_DEFINE([XS_HAVE_CYGWIN], [1], [Have Cygwin]) + AS_IF([test "x$enable_static" = "xyes"], [ AC_MSG_ERROR([Building static libraries is not supported under Cygwin]) - fi - ;; - *) - AC_MSG_ERROR([unsupported system: ${host_os}.]) - ;; -esac + ]) + ], + [AC_MSG_ERROR([unsupported system: ${host_os}.])] +) # # Check if the compiler supports -fvisibility=hidden flag. MinGW32 uses __declspec # -if test "x$libxs_dso_visibility" = "xyes"; then +AS_IF([test "x$libxs_dso_visibility" = "xyes"], [ AC_LANG_PUSH([C++]) LIBXS_CHECK_LANG_VISIBILITY([LIBXS_EXTRA_CXXFLAGS="$libxs_cv_[]_AC_LANG_ABBREV[]_visibility_flag ${LIBXS_EXTRA_CXXFLAGS}"]) AC_LANG_POP([C++]) -fi +]) # CPU-specific optimizations -case "${host_cpu}" in - *sparc*) +AS_CASE(["${host_cpu}"], + [*sparc*], [ AC_LANG_PUSH([C++]) LIBXS_CHECK_LANG_FLAG_PREPEND([-mcpu=v9]) AC_LANG_POP([C++]) - ;; - *) - ;; -esac + ] +) # Check whether to build docs / install man pages LIBXS_CHECK_DOC_BUILD # Check polling system LIBXS_CHECK_POLLER([CPPFLAGS="${CPPFLAGS} -D${libxs_cv_poller_flag}"], - [AC_MSG_ERROR([Unable to continue without polling system])]) + [AC_MSG_ERROR([Unable to continue without polling system])]) # Checks for header files. AC_HEADER_STDC -AC_CHECK_HEADERS(errno.h arpa/inet.h netinet/tcp.h netinet/in.h stddef.h \ -stdlib.h string.h sys/socket.h sys/time.h time.h unistd.h limits.h) +AC_CHECK_HEADERS([ \ + errno.h \ + arpa/inet.h \ + netinet/tcp.h \ + netinet/in.h \ + stddef.h \ + stdlib.h \ + string.h \ + sys/socket.h \ + sys/time.h \ + time.h \ + unistd.h \ + limits.h +]) # Check if we have ifaddrs.h header file. -AC_CHECK_HEADERS(ifaddrs.h, [AC_DEFINE(XS_HAVE_IFADDRS, 1, [Have ifaddrs.h header.])]) +AC_CHECK_HEADERS([ifaddrs.h], + [AC_DEFINE([XS_HAVE_IFADDRS], [1], [Have ifaddrs.h header.])]) # Force not to use eventfd -AC_ARG_ENABLE([eventfd], [AS_HELP_STRING([--disable-eventfd], [disable eventfd [default=no]])], +AC_ARG_ENABLE([eventfd], + [AS_HELP_STRING([--disable-eventfd], [disable eventfd [default=no]])], [xs_disable_eventfd=yes], [xs_disable_eventfd=no]) -if test "x$xs_disable_eventfd" != "xyes"; then +AS_IF([test "x$xs_disable_eventfd" != "xyes"], [ # Check if we have eventfd.h header file. - AC_CHECK_HEADERS(sys/eventfd.h, [AC_DEFINE(XS_HAVE_EVENTFD, 1, [Have eventfd extension.])]) -fi + AC_CHECK_HEADERS([sys/eventfd.h], + [AC_DEFINE([XS_HAVE_EVENTFD], [1], [Have eventfd extension.])]) +]) # Use c++ in subsequent tests -AC_LANG_PUSH(C++) +AC_LANG_PUSH([C++]) AC_HEADER_STDBOOL AC_C_CONST AC_C_INLINE + # Checks for typedefs, structures, and compiler characteristics. -if test "x$libxs_cv_[]_AC_LANG_ABBREV[]_intel_compiler" = "xyes"; then +AS_IF([test "x$libxs_cv_[]_AC_LANG_ABBREV[]_intel_compiler" = "xyes"], [ dnl 279: controlling expression is constant dnl Fixes build with ICC 12.x LIBXS_CHECK_WITH_FLAG([-wd279], [AC_TYPE_SIZE_T]) LIBXS_CHECK_WITH_FLAG([-wd279], [AC_TYPE_SSIZE_T]) -else +], [ AC_TYPE_SIZE_T AC_TYPE_SSIZE_T -fi +]) + AC_HEADER_TIME AC_TYPE_UINT32_T AC_C_VOLATILE @@ -283,18 +294,18 @@ AC_ARG_ENABLE([libzmq], [AS_HELP_STRING([--enable-libzmq], [install libzmq compatibility library and headers [default=no]])], [enable_libzmq=$enableval], [enable_libzmq=no]) -if test "x$enable_libzmq" != "xno"; then +AS_IF([test "x$enable_libzmq" != "xno"], [ AC_MSG_NOTICE([enabling libzmq compatibility library and headers]) libxs_libzmq="yes" -fi +]) # PGM extension libxs_pgm_ext="no" pgm_basename="libpgm-5.1.118~dfsg" -AC_ARG_WITH([pgm], [AS_HELP_STRING([--with-pgm], - [build libxs with PGM extension [default=no]])], +AC_ARG_WITH([pgm], [AS_HELP_STRING([--with-pgm], + [build libxs with PGM extension [default=no]])], [with_pgm_ext=$withval], [with_pgm_ext=no]) # build using system pgm @@ -302,39 +313,40 @@ AC_ARG_WITH([system-pgm], [AS_HELP_STRING([--with-system-pgm], [build libxs with PGM extension. Requires pkg-config [default=no]])], [with_system_pgm_ext=yes], [with_system_pgm_ext=no]) -if test "x$with_pgm_ext" != "xno" -a "x$with_system_pgm_ext" != "xno"; then +AS_IF([test "x$with_pgm_ext" != "xno" \ + && test "x$with_system_pgm_ext" != "xno"], +[ AC_MSG_ERROR([--with-pgm and --with-system-pgm cannot be specified together]) -fi - -if test "x$with_pgm_ext" != "xno"; then +]) +AS_IF([test "x$with_pgm_ext" != "xno"], [ # This allows placing the tar.gz to foreign/openpgm # and using ./configure --with-pgm=libpgm-x.y.z - if test "x$with_pgm_ext" != "xyes"; then + AS_IF([test "x$with_pgm_ext" != "xyes"], [ pgm_basename="$with_pgm_ext" - fi + ]) # Unpack libpgm AC_MSG_NOTICE([Unpacking ${pgm_basename}.tar.gz]) libxs_pwd=`pwd` cd foreign/openpgm - if ! (gzip -dc "${pgm_basename}.tar.gz" || echo "failed") | ${am__untar}; then + AS_IF([! (gzip -dc "${pgm_basename}.tar.gz" || echo "failed") | ${am__untar}], [ AC_MSG_ERROR([cannot unpack the foreign/openpgm/${pgm_basename}.tar.gz file]) - fi + ]) cd "${libxs_pwd}" - if test -d foreign/openpgm/build-staging; then + AS_IF([test -d foreign/openpgm/build-staging], [ rm -rf foreign/openpgm/build-staging - fi + ]) mv foreign/openpgm/${pgm_basename} foreign/openpgm/build-staging pgm_srcdir=foreign/openpgm/build-staging/openpgm/pgm - if ! test -d foreign/openpgm/build-staging/openpgm/pgm/config; then + AS_IF([! test -d foreign/openpgm/build-staging/openpgm/pgm/config], [ mkdir foreign/openpgm/build-staging/openpgm/pgm/config - fi + ]) # DSO symbol visibility for openpgm AC_LANG_PUSH([C]) @@ -342,28 +354,28 @@ if test "x$with_pgm_ext" != "xno"; then AC_LANG_POP([C]) pgm_subdir=build-staging/openpgm/pgm - AC_SUBST(pgm_subdir) + AC_SUBST([pgm_subdir]) - AC_SUBST(pgm_srcdir) + AC_SUBST([pgm_srcdir]) AC_CONFIG_SUBDIRS([foreign/openpgm/build-staging/openpgm/pgm/]) # Success! - AC_DEFINE(XS_HAVE_OPENPGM, 1, [Have OpenPGM extension]) + AC_DEFINE([XS_HAVE_OPENPGM], [1], [Have OpenPGM extension]) libxs_pgm_ext="yes" -fi +]) # Build with system openpgm -if test "x$with_system_pgm_ext" != "xno"; then +AS_IF([test "x$with_system_pgm_ext" != "xno"], [ m4_ifdef([PKG_CHECK_MODULES], [ PKG_CHECK_MODULES([OpenPGM], [openpgm-5.1 >= 5.1]) - AC_DEFINE(XS_HAVE_OPENPGM, 1, [Have OpenPGM extension]) + AC_DEFINE([XS_HAVE_OPENPGM], [1], [Have OpenPGM extension]) LIBXS_EXTRA_CXXFLAGS="$OpenPGM_CFLAGS $LIBXS_EXTRA_CXXFLAGS" LIBS="$OpenPGM_LIBS $LIBS" ], [AC_MSG_ERROR([--with-system-pgm requires a working pkg-config installation])]) -fi +]) -AC_SUBST(pgm_basename) +AC_SUBST([pgm_basename]) # Set -Wall, -Werror and -pedantic AC_LANG_PUSH([C++]) @@ -371,41 +383,58 @@ AC_LANG_PUSH([C++]) # Check how to enable -Wall LIBXS_LANG_WALL([CPPFLAGS="$libxs_cv_[]_AC_LANG_ABBREV[]_wall_flag $CPPFLAGS"]) -if test "x$libxs_werror" = "xyes" -a "x$libxs_cv_[]_AC_LANG_ABBREV[]_sun_studio_compiler" != "xyes"; then +AS_IF([test "x$libxs_werror" = "xyes" \ + && test "x$libxs_cv_[]_AC_LANG_ABBREV[]_sun_studio_compiler" != "xyes"], +[ LIBXS_LANG_WERROR([CPPFLAGS="$libxs_cv_[]_AC_LANG_ABBREV[]_werror_flag $CPPFLAGS"]) -fi +]) -if test "x$libxs_pedantic" = "xyes"; then +AS_IF([test "x$libxs_pedantic" = "xyes"], [ LIBXS_LANG_STRICT([CPPFLAGS="$libxs_cv_[]_AC_LANG_ABBREV[]_strict_flag $CPPFLAGS"]) -fi +]) AC_LANG_POP([C++]) -AM_CONDITIONAL(BUILD_LIBZMQ, test "x$libxs_libzmq" = "xyes") -AM_CONDITIONAL(BUILD_PGM, test "x$libxs_pgm_ext" = "xyes") -AM_CONDITIONAL(ON_MINGW, test "x$libxs_on_mingw32" = "xyes") +AM_CONDITIONAL([BUILD_LIBZMQ], [test "x$libxs_libzmq" = "xyes"]) +AM_CONDITIONAL([BUILD_PGM], [test "x$libxs_pgm_ext" = "xyes"]) +AM_CONDITIONAL([ON_MINGW], [test "x$libxs_on_mingw32" = "xyes"]) # Checks for library functions. AC_TYPE_SIGNAL -AC_CHECK_FUNCS(perror gettimeofday clock_gettime memset socket getifaddrs freeifaddrs) +AC_CHECK_FUNCS([ \ + perror \ + gettimeofday \ + clock_gettime \ + memset \ + socket \ + getifaddrs \ + freeifaddrs +]) AC_CHECK_HEADERS([alloca.h]) -LIBXS_CHECK_SOCK_CLOEXEC([AC_DEFINE( - [XS_HAVE_SOCK_CLOEXEC], - [1], - [Whether SOCK_CLOEXEC is defined and functioning.]) - ]) +LIBXS_CHECK_SOCK_CLOEXEC([ + AC_DEFINE([XS_HAVE_SOCK_CLOEXEC], [1], + [Whether SOCK_CLOEXEC is defined and functioning.]) +]) # Subst LIBXS_EXTRA_CFLAGS & CXXFLAGS & LDFLAGS -AC_SUBST(LIBXS_EXTRA_CFLAGS) -AC_SUBST(LIBXS_EXTRA_CXXFLAGS) -AC_SUBST(LIBXS_EXTRA_LDFLAGS) - -AC_CONFIG_FILES([Makefile src/Makefile doc/Makefile - perf/Makefile src/libxs.pc \ - builds/msvc/Makefile tests/Makefile \ - foreign/openpgm/Makefile]) -if test "x$libxs_libzmq" == "xyes"; then +AC_SUBST([LIBXS_EXTRA_CFLAGS]) +AC_SUBST([LIBXS_EXTRA_CXXFLAGS]) +AC_SUBST([LIBXS_EXTRA_LDFLAGS]) + +AC_CONFIG_FILES([ + Makefile + src/Makefile + doc/Makefile + perf/Makefile + src/libxs.pc + builds/msvc/Makefile + tests/Makefile + foreign/openpgm/Makefile +]) + +AS_IF([test "x$libxs_libzmq" == "xyes"], [ AC_CONFIG_FILES([src/libzmq.pc]) -fi +]) + AC_OUTPUT # Print configuration @@ -438,9 +467,8 @@ Installation: EOF -if test "x$libxs_libzmq" == "xyes"; then +AS_IF([test "x$libxs_libzmq" == "xyes"], [ AC_MSG_WARN([The --enable-libzmq option was specified:]) AC_MSG_WARN([libzmq compatibility library and headers are enabled.]) AC_MSG_WARN([This will overwrite any existing installation of libzmq.]) -fi - +]) |