From 5afba764bb01b806cf4f0399627280247d43cc97 Mon Sep 17 00:00:00 2001 From: Robert James Kaes Date: Sat, 2 Jun 2001 17:23:16 +0000 Subject: Fixed the tests for libsocket, libnsl, and libresolv. Improved the tests for the yacc program since bison 1.25 was originally used to write the scanner. Updated the list of headers to look for when configuring. Bumped up the prerelease number. --- ChangeLog | 7 ++++ configure.in | 118 +++++++++++++++++++++++++++++++++++++++++++++++++---------- 2 files changed, 106 insertions(+), 19 deletions(-) diff --git a/ChangeLog b/ChangeLog index 0d03934..0b81b1f 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2001-06-02 Robert James Kaes + + * configure.in: Fixed up the tests for libsocket, libnsl, and + libresolv. Also improved the test for the yacc program since I + used bison 1.25 to originally write it. Updated the list of + headers to look for when configuring. Bumped up the version. + 2001-06-01 Robert James Kaes * configure.in: Fixed a problem when using the --with-port= config diff --git a/configure.in b/configure.in index 63b9a88..66070b6 100644 --- a/configure.in +++ b/configure.in @@ -1,23 +1,79 @@ -dnl $Id: configure.in,v 1.9 2001-06-02 03:33:17 rjkaes Exp $ +dnl $Id: configure.in,v 1.10 2001-06-02 17:23:16 rjkaes Exp $ AC_INIT() -AM_INIT_AUTOMAKE(tinyproxy,1.4.0pre4) +AM_INIT_AUTOMAKE(tinyproxy,1.4.0pre5) AM_CONFIG_HEADER(config.h) AC_CANONICAL_HOST AC_CANONICAL_TARGET dnl Checks for programs. +AC_PROG_AWK AC_PROG_MAKE_SET AC_PROG_CC AC_PROG_INSTALL -AM_PROG_LEX +AC_PROG_LN_S AC_PROG_YACC +if test "$YACC" != "bison -y"; then + AC_MSG_WARN(You will need bison if you want to regenerate the parser.) +else + AC_MSG_CHECKING(bison version) + oldIFS=$IFS; IFS=. + set `bison -V | sed -e 's/^GNU Bison version //'` + IFS=$oldIFS + if test "$1" = "1" -a "$2" -lt "25"; then + AC_MSG_WARN(Bison 1.25 or newer needed to regenerate parsers (found $1.$2).) + fi + AC_MSG_RESULT($1.$2 (ok)) +fi + +AM_PROG_LEX AM_C_PROTOTYPES dnl Checks for header files. AC_HEADER_STDC -AC_CHECK_HEADERS(sys/types.h sys/socket.h sys/time.h time.h netinet/in.h arpa/inet.h error.h fcntl.h netdb.h signal.h stdio.h stdint.h stdlib.h string.h sys/stat.h sys/uio.h unistd.h sys/wait.h sys/un.h sys/select.h strings.h sys/ioctl.h pthread.h sys/sysctl.h syslog.h stdint.h sys/resource.h) +AC_CHECK_HEADERS(\ +sys/types.h \ +sys/ioctl.h \ +sys/resource.h \ +sys/select.h \ +sys/socket.h \ +sys/stat.h \ +sys/sysctl.h \ +sys/time.h \ +sys/uio.h \ +sys/un.h \ +sys/wait.h \ +arpa/inet.h \ +netinet/in.h \ +alloca.h \ +assert.h \ +ctype.h \ +errno.h \ +fcntl.h \ +grp.h \ +io.h \ +libintl.h \ +malloc.h \ +netdb.h \ +pthread.h \ +pwd.h \ +regex.h \ +signal.h \ +stdarg.h \ +stddef.h \ +stdint.h \ +stdio.h \ +stdlib.h \ +string.h \ +strings.h \ +sysexists.h \ +syslog.h \ +time.h \ +unistd.h \ +wchar.h \ +wctype.h \ +) dnl Checks for typedefs, structures, and compiler characteristics. AC_C_CONST @@ -35,26 +91,50 @@ AC_UNP_CHECK_TYPE(in_addr_t, uint32_t) dnl Checks for libraries AC_CHECK_LIB(pthread, pthread_create) -if test $ac_cv_lib_pthread_pthread_create = yes ; then +if test "$ac_cv_lib_pthread_pthread_create" = "yes"; then CFLAGS="$CFLAGS -D_REENTRANT" else AC_CHECK_LIB(pthreads, pthread_create) - if test $ac_cv_lib_pthreads_pthread_create = yes ; then + if test "$ac_cv_lib_pthreads_pthread_create" = "yes"; then CFLAGS="$CFLAGS -D_REENTRANT" else AC_MSG_ERROR(You must have a POSIX compliant threading library installed) fi fi -AC_CHECK_LIB(nsl, t_open) -AC_CHECK_LIB(socket, socket) -AC_CHECK_LIB(resolv, gethostbyname) +AC_CHECK_LIB(socket, socket, [ ], [ AC_CHECK_LIB(socket, htonl) ]) + +dnl Some systems (OpenServer 5) dislike -lsocket -lnsl, so we try to +dnl avoid -lnsl checks, if we already have the functions which are +dnl usually in libnsl + +unset ac_cv_func_yp_get_default_domain +AC_CHECK_FUNC(yp_get_default_domain, [ tinyproxy_no_nsl_checks=yes ], [ ]) +unset ac_cv_func_yp_get_default_domain + +if test "$tinyproxy_no_nsl_checks" != "yes"; then + AC_CHECK_LIB(nsl, gethostname, [ ], [ AC_CHECK_LIB(nsl, gethostbyaddr) ]) +fi + +AC_CHECK_LIB(resolv, inet_aton) dnl Checks for library functions. +AC_FUNC_ALLOCA +dnl AC_FUNC_MEMCMP AC_TYPE_SIGNAL AC_FUNC_STRFTIME AC_FUNC_VPRINTF -AC_CHECK_FUNCS(ftruncate select setrlimit socket strdup strerror vsnprintf vsyslog) +AC_CHECK_FUNCS(\ +ftruncate \ +select \ +setrlimit \ +socket \ +strdup \ +strerror \ +strtol \ +vsnprintf \ +vsyslog \ +) AC_CHECK_FUNCS(strlcpy strlcat) dnl chris - allow user to choose log file location, port and username @@ -75,7 +155,7 @@ AC_ARG_WITH(regex, [ --with-regex Use the GNU regex libary], tinyproxy_cv_regex=yes, AC_CHECK_FUNCS(regcomp, tinyproxy_cv_regex=no, tinyproxy_cv_regex=yes)) -if test $tinyproxy_cv_regex = no ; then +if test "$tinyproxy_cv_regex" != "yes" ; then AC_MSG_CHECKING(whether your system's regexp library is completely broken) AC_CACHE_VAL(tinyproxy_cv_regex_broken, AC_TRY_RUN([ @@ -92,13 +172,13 @@ int main(void) tinyproxy_cv_regex_broken=yes)) AC_MSG_RESULT($tinyproxy_cv_regex_broken) - if test $tinyproxy_cv_regex_broken = yes ; then + if test "$tinyproxy_cv_regex_broken" = "yes" ; then echo "Using the included GNU regex instead." >&AC_FD_MSG tinyproxy_cv_regex=yes fi fi -if test $tinyproxy_cv_regex = yes ; then +if test "$tinyproxy_cv_regex" = "yes" ; then AC_DEFINE(USE_GNU_REGEX) LIBOBJS="$LIBOBJS gnuregex.o" fi @@ -109,7 +189,7 @@ AC_ARG_ENABLE(debug, debug_enabled=yes) CFLAGS="$CFLAGS -Wall" -if test x$enable_debug = xyes ; then +if test "$enable_debug" = "yes" ; then dnl Add the warnings if we have the GCC compiler if test x$ac_cv_prog_gcc = xyes ; then CFLAGS="$CFLAGS -Wshadow" @@ -134,10 +214,10 @@ AC_ARG_ENABLE(socks, [ --enable-socks Enable SOCKS support [default=no]], socks_enabled=yes) -if test x$socks_enabled = xyes; then +if test "$socks_enabled" = "yes"; then AC_CHECK_HEADER(socks.h, socks_header=yes, socks_header=no) AC_CHECK_LIB(socks, main, socks_library=yes, socks_library=no) - if test "$socks_header" = yes && test "$socks_library" = yes; then + if test "$socks_header" = "yes" -a "$socks_library" = "yes"; then CFLAGS="$CFLAGS -I/usr/include/sock.h -DSOCKS" LIBS="$LIBS -lsocks" else @@ -150,7 +230,7 @@ AC_ARG_ENABLE(xtinyproxy, [ --enable-xtinyproxy Include X-Tinyproxy header [default=yes]], xtinyproxy_enabled=yes) -if test x$xtinyproxy_enabled != xno ; then +if test "$xtinyproxy_enabled" = "yes" ; then AC_DEFINE(XTINYPROXY_ENABLE) fi @@ -159,7 +239,7 @@ AC_ARG_ENABLE(filter, [ --enable-filter Enable filtering of domains/URLs [default=yes]], filter_enabled=yes) -if test x$filter_enabled != xno ; then +if test "$filter_enabled" = "yes" ; then LIBOBJS="$LIBOBJS filter.o" AC_DEFINE(FILTER_ENABLE) fi @@ -169,7 +249,7 @@ AC_ARG_ENABLE(tunnel, [ --enable-tunnel Enable support for TCP tunneling [default=yes]], tunnel_enabled=yes) -if test x$tunnel_enabled != xno ; then +if test "$tunnel_enabled" = "yes" ; then AC_DEFINE(TUNNEL_SUPPORT) fi -- cgit v1.2.3