X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=configure.in;h=69e75c6144aea3d3b34063bdfaa78cdbc4f6367e;hb=e1a4408c83869c52247fd6a9d2acba37bfa86a6d;hp=3fe7fa03a4c098dcf33bf19e9ba324edb7fe8014;hpb=635e698a1fe3921355e1472f53ccd5d717037fad;p=srvx.git diff --git a/configure.in b/configure.in index 3fe7fa0..69e75c6 100644 --- a/configure.in +++ b/configure.in @@ -2,8 +2,8 @@ dnl Process this file with autoconf to create a configure script. dnl General initialization. AC_REVISION([$Id: configure.in,v 1.77 2004/01/02 01:49:15 entrope Exp $]) -AC_PREREQ(2.57) -AC_INIT(srvx, 1.3, srvx-bugs@lists.sourceforge.net) +AC_PREREQ(2.59) +AC_INIT([srvx],[1.3],[srvx-bugs@lists.sourceforge.net]) CODENAME=surge AC_CONFIG_HEADERS(src/config.h) AC_CONFIG_SRCDIR(src/opserv.c) @@ -96,6 +96,32 @@ if test $ac_cv_sin_len = yes ; then AC_DEFINE(HAVE_SIN_LEN, 1, [Define if struct sockaddr_in contains a sin_len field]) fi +dnl Check for socklen_t. In traditional BSD this is an int, but some +dnl OSes use a different type. Test until we find something that will +dnl work properly. Test borrowed from a patch submitted for Python. +AC_CHECK_TYPE([socklen_t], ,[ + AC_MSG_CHECKING([for socklen_t equivalent]) + AC_CACHE_VAL([curl_cv_socklen_t_equiv], + [ +dnl Systems have either "struct sockaddr*" or "void*" as second +dnl arg to getpeername. + curl_cv_socklen_t_equiv= + for arg2 in "struct sockaddr" void ; do + for t in int size_t unsigned long "unsigned long" ; do + AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include +#include +int getpeername (int $arg2 *, $t *);]], [[$t len; + getpeername(0, 0, &len);]])],[curl_cv_socklen_t_equiv="$t" + break],[]) + done + done + ]) + AC_MSG_RESULT($curl_cv_socklen_t_equiv) + AC_DEFINE_UNQUOTED(socklen_t, $curl_cv_socklen_t_equiv, + [type to use in place of socklen_t if not defined])], + [#include +#include]) + dnl Can only check with -Werror, but the rest of configure doesn't like -Werror OLD_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -W -Wall -Werror"