X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=folly%2Fconfigure.ac;h=fad024dabb39d350bc9bc64a120b95fb7e029e52;hb=2d6a824fc67a236d41c7a6cdf5734654d42fe710;hp=cbdb5f2e4ef80d4cb564f6c7c7fe18ef6a903167;hpb=f7e3adf5719c326b6e197878f8e8f3fc9a17375e;p=folly.git diff --git a/folly/configure.ac b/folly/configure.ac index cbdb5f2e..fad024da 100644 --- a/folly/configure.ac +++ b/folly/configure.ac @@ -52,11 +52,53 @@ fi CXXFLAGS="$STD $CXXFLAGS" -# Checks for libraries. -AC_CHECK_LIB([glog],[openlog],[],[AC_MSG_ERROR( - [Please install google-glog library])]) -AC_CHECK_LIB([gflags],[getenv],[],[AC_MSG_ERROR( - [Please install google-gflags library])]) +# Checks for glog and gflags +# There are no symbols with C linkage, so we do a try-run +AC_HAVE_LIBRARY([glog],[],[AC_MSG_ERROR( + [Please install google-glog library])]) +AC_CACHE_CHECK( + [for glog viability], + [folly_cv_prog_cc_glog], + [AC_RUN_IFELSE( + [AC_LANG_SOURCE[ + #include + int main(int argc, char** argv) { + google::InitGoogleLogging(argv[0]); + google::ShutdownGoogleLogging(); + return 0; + } + ]], + [folly_cv_prog_cc_glog=yes], + [folly_cv_prog_cc_glog=no] + )] +) + +if test "$folly_cv_prog_cc_glog" != "yes"; then + AC_MSG_ERROR(["libglog invalid, see config.log for details"]) +fi + +AC_HAVE_LIBRARY([gflags],[],[AC_MSG_ERROR( + [Please install google-gflags library])]) +AC_CACHE_CHECK( + [for gflags viability], + [folly_cv_prog_cc_gflags], + [AC_RUN_IFELSE( + [AC_LANG_SOURCE[ + #include + DEFINE_bool(folly_truthy, true, "Sample truthy flag"); + DEFINE_bool(folly_falsey, false, "Sample falsey flag"); + int main(int argc, char** argv) { + return (FLAGS_folly_truthy && !FLAGS_folly_falsey) ? 0 : 1; + } + ]], + [folly_cv_prog_cc_gflags=yes], + [folly_cv_prog_cc_gflags=no] + )] +) + +if test "$folly_cv_prog_cc_gflags" != "yes"; then + AC_MSG_ERROR(["libgflags invalid, see config.log for details"]) +fi AC_CHECK_LIB(ssl, SSL_ctrl, @@ -64,20 +106,25 @@ AC_CHECK_LIB(ssl, [AC_MSG_ERROR(["Error: libssl required"])]) # check for boost libs -AX_BOOST_BASE([1.20.0], [], [AC_MSG_ERROR( - [Please install boost >= 1.20.0 (thread, regex, and system)])]) +AX_BOOST_BASE([1.51.0], [], [AC_MSG_ERROR( + [Please install boost >= 1.51.0 (context, thread, program_options, regex, and system)])]) +AX_BOOST_CONTEXT +AX_BOOST_PROGRAM_OPTIONS AX_BOOST_THREAD AX_BOOST_REGEX AX_BOOST_SYSTEM AX_BOOST_FILESYSTEM +# Check for python interpreter +AM_PATH_PYTHON + # Checks for header files. AC_HEADER_STDC AC_CHECK_HEADERS([fcntl.h features.h inttypes.h limits.h stdint.h stdlib.h string.h sys/time.h unistd.h mutex.h malloc.h emmintrin.h byteswap.h bits/functexcept.h bits/c++config.h]) AC_CHECK_HEADER(double-conversion/double-conversion.h, [], [AC_MSG_ERROR( [Couldn't find double-conversion.h, please download from \ - http://code.google.com/p/double-conversion/])], []) + https://github.com/google/double-conversion/])], []) AC_CHECK_LIB([double-conversion],[ceil],[],[AC_MSG_ERROR( [Please install double-conversion library])]) @@ -92,10 +139,8 @@ AC_C_INLINE AC_TYPE_SIZE_T AC_HEADER_TIME AC_C_VOLATILE -AC_CHECK_TYPE([__int128], - [AC_DEFINE([HAVE_INT128_T], [1], [Define if __int128 exists])], - [AC_DEFINE([HAVE_INT128_T], [0], [Define if __int128 does not exist])]) -AC_CHECK_TYPES([ptrdiff_t]) +AC_CHECK_TYPE([__int128], AC_DEFINE([HAVE_INT128_T], [1], [Define if we have __int128])) +AC_CHECK_TYPES([ptrdiff_t, pthread_spinlock_t]) AC_CACHE_CHECK( [for ifunc support], @@ -251,6 +296,25 @@ if test "$folly_cv_prog_cc_weak_symbols" = yes; then [Define to 1 if the linker supports weak symbols.]) fi +AC_CACHE_CHECK( + [for vsnprintf reporting bad format strings], + [folly_cv_prog_vsnprintf_bad_format], + [AC_RUN_IFELSE( + [AC_LANG_SOURCE[ + #include + + int main(int argc, char** argv) { + char buf[256]; + return vsnprintf(buf, sizeof(buf), "%", 1) < 0 ? 0 : 1; + }]], + [folly_cv_prog_vsnprintf_bad_format="yes"], + [folly_cv_prog_vsnprintf_bad_format="no"])]) + +if test "$folly_cv_prog_vsnprintf_bad_format" = yes; then + AC_DEFINE([HAVE_VSNPRINTF_ERRORS], [1], + [Define to 1 if the vsnprintf supports returning errors on bad format strings.]) +fi + AC_SEARCH_LIBS([cplus_demangle_v3_callback], [iberty_pic iberty]) if test "$ac_cv_search_cplus_demangle_v3_callback" != "no" ; then AC_DEFINE([HAVE_CPLUS_DEMANGLE_V3_CALLBACK], [1], @@ -266,6 +330,45 @@ AC_SEARCH_LIBS([clock_gettime], [rt], [Define to 1 if we support clock_gettime(2).]), []) +# Check for pthread_atfork(3). This is not in an AC_CHECK_FUNCS() because we +# want to include pthread.h if necessary. +AC_CACHE_CHECK( + [for pthread_atfork support], + [folly_cv_prog_cc_pthread_atfork], + [AC_COMPILE_IFELSE( + [AC_LANG_SOURCE[ + #include + void func() {pthread_atfork(NULL, NULL, NULL);}] + ], + [folly_cv_prog_cc_pthread_atfork=yes], + [folly_cv_prog_cc_pthread_atfork=no])]) + +if test "$folly_cv_prog_cc_pthread_atfork" = "yes"; then + AC_DEFINE([HAVE_PTHREAD_ATFORK], [1], [Define to 1 if the compiler supports pthread_atfork]) +fi + +# Check for XSI-compatible strerror_r as default implementation +AC_CACHE_CHECK( + [for XSI style strerror_r support], + [folly_cv_prog_cc_xsi_strerror_r], + [AC_RUN_IFELSE( + [AC_LANG_SOURCE[ + #include + #include + int main(int argc, char** argv) { + char buf[1024]; + buf[0] = 0; + int ret = strerror_r(ENOMEM, buf, sizeof(buf)); + return ret; + } + ]], + [folly_cv_prog_cc_xsi_strerror_r=yes], + [folly_cv_prog_cc_xsi_strerror_r=no])]) + +if test "$folly_cv_prog_cc_xsi_strerror_r" = "yes"; then + AC_DEFINE([HAVE_XSI_STRERROR_R], [1], [Define to 1 if the runtime supports XSI-style strerror_r]) +fi + # Checks for library functions. AC_CHECK_FUNCS([getdelim \ gettimeofday \ @@ -292,6 +395,7 @@ AC_CHECK_HEADER([lzma.h], AC_CHECK_LIB([lzma], [main])) # Include directory that contains "folly" so #include works AM_CPPFLAGS='-I$(top_srcdir)/..' AM_CPPFLAGS="$AM_CPPFLAGS $BOOST_CPPFLAGS" +AM_LDFLAGS="$AM_LDFLAGS $BOOST_CONTEXT_LIB $BOOST_PROGRAM_OPTIONS_LIB" AM_LDFLAGS="$AM_LDFLAGS $BOOST_THREAD_LIB $BOOST_FILESYSTEM_LIB" AM_LDFLAGS="$AM_LDFLAGS $BOOST_SYSTEM_LIB $BOOST_REGEX_LIB -lpthread" @@ -303,7 +407,7 @@ AM_CONDITIONAL([HAVE_X86_64], [test "$build_cpu" = "x86_64"]) AM_CONDITIONAL([HAVE_LINUX], [test "$build_os" == "linux-gnu"]) AM_CONDITIONAL([HAVE_WEAK_SYMBOLS], [test "$folly_cv_prog_cc_weak_symbols" = "yes"]) -AM_CONDITIONAL([HAVE_BITS_FUNCTEXCEPT], [test "$ac_cv_header_bits_functexcept" = "yes"]) +AM_CONDITIONAL([HAVE_BITS_FUNCTEXCEPT], [test "$ac_cv_header_bits_functexcept_h" = "yes"]) # Output AC_CONFIG_FILES([Makefile