X-Git-Url: http://www.project-moonshot.org/gitweb/?p=freeradius.git;a=blobdiff_plain;f=acinclude.m4;h=1dd8ad14c8ec7c775aaf6bbf6fbfdb70be49a1cf;hp=82539764cc550352f2bb80fe124e5911536592d8;hb=HEAD;hpb=fd9beb53d8c269eb21a8fad31a2f7b375198b6b1 diff --git a/acinclude.m4 b/acinclude.m4 index 8253976..1dd8ad1 100644 --- a/acinclude.m4 +++ b/acinclude.m4 @@ -111,233 +111,6 @@ AC_DEFUN([FR_CHECK_TYPE_INCLUDE], fi ]) -dnl ####################################################################### -dnl # -dnl # Look for SNMP in a variety of places. -dnl # -AC_DEFUN([SNMP_CHECKS], [ - AC_SUBST(SNMP_LIBS) - AC_SUBST(SNMP_INCLUDE) - -AC_MSG_CHECKING([for asn1.h,snmp.h,snmp_impl.h]) - -dnl # -dnl # First, see if we can build it WITHOUT using any special includes and in ucd-snmp -dnl # -AC_TRY_COMPILE([ -#ifdef HAVE_SYS_TYPES_H -#include -#endif -#ifdef HAVE_STDINT_H -#include -#endif -#ifdef HAVE_STDIO_H -#include -#endif -#ifdef HAVE_NETDB_H -#include -#endif -#ifdef HAVE_UNISTD_H -#include -#endif -#include -#include -#include -#include ], - [ int a = 1;], - SNMP_INCLUDE="";ucdsnmp=yes, - ucdsnmp=) - -dnl # -dnl # If not, look for it in a number of directories and in ucd-snmp. -dnl # -if test "x$ucdsnmp" = "x"; then - old_CFLAGS="$CFLAGS" - for try in /usr/include /usr/local/include $snmp_include_dir; do - CFLAGS="$old_CFLAGS -I$try" - AC_TRY_COMPILE([ -#ifdef HAVE_SYS_TYPES_H -#include -#endif -#ifdef HAVE_STDINT_H -#include -#endif -#ifdef HAVE_STDIO_H -#include -#endif -#ifdef HAVE_NETDB_H -#include -#endif -#ifdef HAVE_UNISTD_H -#include -#endif -#include -#include -#include -#include ], - [ int a = 1;], - SNMP_INCLUDE="-I$try";ucdsnmp=yes, - ucdsnmp=) - if test "x$ucdsnmp" != "x"; then - break; - fi - done - CFLAGS="$old_CFLAGS" -fi - -if test "x$ucdsnmp" = "x"; then - old_CFLAGS="$CFLAGS" - for try in /usr/include/ucd-snmp /usr/local/include/ucd-snmp $snmp_include_dir; do - CFLAGS="$old_CFLAGS -I$try" -dnl # -dnl # First, see if we can build it WITHOUT using any special includes and without ucd-snmp -dnl # -AC_TRY_COMPILE([ -#ifdef HAVE_SYS_TYPES_H -#include -#endif -#ifdef HAVE_STDINT_H -#include -#endif -#ifdef HAVE_STDIO_H -#include -#endif -#ifdef HAVE_NETDB_H -#include -#endif -#ifdef HAVE_UNISTD_H -#include -#endif -#include -#include -#include ], - [ int a = 1;], - SNMP_INCLUDE="";ucdsnmp=no, - ucdsnmp=) - if test "x$ucdsnmp" != "x"; then - break; - fi - done - CFLAGS="$old_CFLAGS" -fi - -dnl # -dnl # If not, look for it in a number of directories and without ucd-snmp -dnl # -if test "x$ucdsnmp" = "x"; then - old_CFLAGS="$CFLAGS" - for try in /usr/include/ucd-snmp /usr/local/include/ucd-snmp $snmp_include_dir; do - CFLAGS="$old_CFLAGS -I$try" - AC_TRY_COMPILE([ -#ifdef HAVE_SYS_TYPES_H -#include -#endif -#ifdef HAVE_STDINT_H -#include -#endif -#ifdef HAVE_STDIO_H -#include -#endif -#ifdef HAVE_NETDB_H -#include -#endif -#ifdef HAVE_UNISTD_H -#include -#endif -#include -#include -#include ], - [ int a = 1;], - SNMP_INCLUDE="-I$try";ucdsnmp=no, - ucdsnmp=) - if test "x$ucdsnmp" != "x"; then - break; - fi - done - CFLAGS="$old_CFLAGS" -fi - -if test "x$ucdsnmp" = "x"; then - AC_MSG_RESULT(no) -else - if test "x$ucdsnmp" = "xyes"; then - AC_MSG_RESULT((ucd-snmp)yes) - AC_DEFINE(HAVE_UCD_SNMP_ASN1_SNMP_SNMPIMPL_H, [], [Define if you have the , and header file.]) - else - AC_MSG_RESULT(yes) - AC_DEFINE(HAVE_ASN1_SNMP_SNMPIMPL_H, [], [Define if you have the , and header file.]) - fi -dnl # -dnl # Now do the same thing, looking for the SNMP library directory -dnl # - AC_MSG_CHECKING([for snmp_build_var_op in -lsnmp]) - -dnl # -dnl # First, see if we can build it WITHOUT using any special includes -dnl # - old_LIBS="$LIBS" - LIBS="$old_LIBS -lsnmp" - AC_TRY_LINK([extern char snmp_build_var_op();], - [ snmp_build_var_op()], - SNMP_LIBS="-lsnmp", - SNMP_LIBS=) - - if test "x$SNMP_LIBS" = "x"; then - for try in /usr/lib /usr/local/lib /usr/local/snmp/lib $with_snmp_lib_dir; do - LIBS="$old_LIBS -L$try -lsnmp" - AC_TRY_LINK([extern char snmp_build_var_op();], - [ snmp_build_var_op()], - SNMP_LIBS="-L$try -lsnmp", - SNMP_LIBS=) - if test "x$SNMP_LIBS" != "x"; then - break; - fi -dnl # -dnl # That didn't work. Try adding the '-lcrypto' line. -dnl # Some SNMP libraries are linked against SSL... -dnl # - LIBS="$old_LIBS -L$try -lsnmp -lcrypto" - AC_TRY_LINK([extern char snmp_build_var_op();], - [ snmp_build_var_op()], - SNMP_LIBS="-L$try -lsnmp -lcrypto", - SNMP_LIBS=) - if test "x$SNMP_LIBS" != "x"; then - break; - fi -dnl # -dnl # That didn't work. Try adding the '-lkstat' line. -dnl # Some SNMP libraries are linked against Kernel Statistics, -dnl # in particular, Solaris 9... -dnl # - LIBS="$old_LIBS -L$try -lsnmp -lcrypto -lkstat" - AC_TRY_LINK([extern char snmp_build_var_op();], - [ snmp_build_var_op()], - SNMP_LIBS="-L$try -lsnmp -lcrypto -lkstat", - SNMP_LIBS=) - if test "x$SNMP_LIBS" != "x"; then - break; - fi - done - fi - LIBS="$old_LIBS" - - dnl # - dnl # If one or the other isn't found, disable them both.. - dnl # If both are found, enable them both. - dnl # - CFLAGS="$old_CFLAGS" - if test "x$SNMP_LIBS" = "x"; then - AC_MSG_RESULT(no) - SNMP_INCLUDE= - else - AC_MSG_RESULT(yes) - AC_DEFINE(WITH_SNMP, [], [Include SNMP subagent]) - AC_DEFINE(HAVE_LIBSNMP, [], [Define if you have the snmp library (-lsnmp).]) - fi -fi -]) - - dnl # dnl # Locate the directory in which a particular file is found. dnl # @@ -594,4 +367,74 @@ $1 fi ]) +dnl Autoconf 2.61 breaks the support for chained configure scripts +dnl in combination with config.cache +m4_pushdef([AC_OUTPUT], +[ + unset ac_cv_env_LIBS_set + unset ac_cv_env_LIBS_value + m4_popdef([AC_OUTPUT]) + AC_OUTPUT([$1],[$2],[$3]) +]) + + +# See if the compilation works with __thread, for thread-local storage +# +AC_DEFUN([FR_TLS], +[ + AC_MSG_CHECKING(for TLS) + AC_RUN_IFELSE([AC_LANG_SOURCE([[ static __thread int val; int main(int argc, char *argv[]) { return val = argc; } ]])],[have_tls=yes],[have_tls=no],[have_tls=no ]) + AC_MSG_RESULT($have_tls) + if test "$have_tls" = "yes"; then + AC_DEFINE([HAVE_THREAD_TLS],[1],[Define if the compiler supports __thread]) + fi +]) + + +AC_DEFUN([AC_LIB_READLINE], [ + AC_CACHE_CHECK([for a readline compatible library], + ac_cv_lib_readline, [ + ORIG_LIBS=$LIBS + for readline_lib in readline edit editline; do + for termcap_lib in "" termcap curses ncurses; do + if test -z "$termcap_lib"; then + TRY_LIB="-l$readline_lib" + else + TRY_LIB="-l$readline_lib -l$termcap_lib" + fi + LIBS="$ORIG_LIBS $TRY_LIB" + AC_TRY_LINK_FUNC(readline, ac_cv_lib_readline="$TRY_LIB") + if test -n "$ac_cv_lib_readline"; then + LIBREADLINE="$TRY_LIB" + AC_SUBST(LIBREADLINE) + break + fi + done + if test -n "$ac_cv_lib_readline"; then + break + fi + done + if test -z "$ac_cv_lib_readline"; then + ac_cv_lib_readline="no" + fi + LIBS=$ORIG_LIBS + ]) + + if test "$ac_cv_lib_readline" != "no"; then + AC_DEFINE(HAVE_LIBREADLINE, 1, + [Define if you have a readline compatible library]) + AC_CHECK_HEADERS(readline.h readline/readline.h) + AC_CACHE_CHECK([whether readline supports history], + ac_cv_lib_readline_history, [ + ac_cv_lib_readline_history="no" + AC_TRY_LINK_FUNC(add_history, ac_cv_lib_readline_history="yes") + ]) + if test "$ac_cv_lib_readline_history" = "yes"; then + AC_DEFINE(HAVE_READLINE_HISTORY, 1, + [Define if your readline library has \`add_history']) + AC_CHECK_HEADERS(history.h readline/history.h) + fi + fi +]) + AC_INCLUDE(aclocal.m4)