From 72d7fa413a2305be8626fcb3f6041bea959fc262 Mon Sep 17 00:00:00 2001 From: Adam Dickmeiss Date: Mon, 26 May 2003 20:09:01 +0000 Subject: [PATCH] Special socklen_t check for AIX --- CHANGELOG | 3 ++- configure.in | 60 ++++++++++++++++++++++++++++++++++++++-------------------- 2 files changed, 42 insertions(+), 21 deletions(-) diff --git a/CHANGELOG b/CHANGELOG index 7454050..e9c26d6 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -11,7 +11,8 @@ Bug fix: some MARC8 sequences were not converted. New ZOOM option "step" which specifies number of records to be retrieved in one chunk. Used in conjunction with "start" and "count". -SRW support for yaz-client. +SRW support for yaz-client. Use scheme http: to use it, e.g. + http://host:port/db yaz-client no longer does (un)intelligent character set conversions by default. Can be enabled with charset and marc_charset commands. diff --git a/configure.in b/configure.in index db7da1a..2a82368 100644 --- a/configure.in +++ b/configure.in @@ -1,6 +1,6 @@ dnl YAZ Toolkit, Index Data 1994-2003 dnl See the file LICENSE for details. -dnl $Id: configure.in,v 1.112 2003-04-28 21:02:15 adam Exp $ +dnl $Id: configure.in,v 1.113 2003-05-26 20:09:01 adam Exp $ AC_INIT(include/yaz/yaz-version.h) AM_INIT_AUTOMAKE(yaz, 2.0.2) AM_MAINTAINER_MODE @@ -98,7 +98,7 @@ if test "$checkBoth" = "1"; then fi AC_CHECK_FUNC(gethostbyname, , AC_CHECK_LIB(nsl, main, [LIBS="$LIBS -lnsl"])) dnl -dnl ------ Open SSL +dnl ------ OpenSSL openssl=no AC_ARG_WITH(openssl, [ --with-openssl[=PREFIX] OpenSSL library in PREFIX], [openssl=$withval]) AC_SUBST(SSL_CFLAGS) @@ -202,29 +202,49 @@ if test "$ac_cv_func_poll" = "yes"; then AC_CHECK_HEADERS(sys/poll.h) fi dnl ------ socklen_t +dnl We check for socklen_t by making prototypes with the +dnl various types. First socklen_t, then size_t, finally int. +dnl If the prototype succeeds, we're probably safe. +dnl That works if accept is not preprocessor defined (such sa AIX) AC_MSG_CHECKING([for socklen_t]) AC_CACHE_VAL(ac_cv_check_socklen_t,[ac_cv_check_socklen_t='' AC_TRY_COMPILE([ - #include - #include - #ifdef __cplusplus - extern "C" { - #endif - extern int accept(int, struct sockaddr *, socklen_t *); - #ifdef __cplusplus - } - #endif +#include +#include +#ifdef __cplusplus +extern "C" { +#endif +#define try 1 +#ifdef AIX +#if AIX >= 51 +#define try 0 +#endif +#endif +#if try +extern int accept(int, struct sockaddr *, socklen_t *); +#endif +#ifdef __cplusplus +} +#endif ],,[ac_cv_check_socklen_t=socklen_t],[ AC_TRY_COMPILE([ - #include - #include - #ifdef __cplusplus - extern "C" { - #endif - extern int accept(int, struct sockaddr *, size_t t *); - #ifdef __cplusplus - } - #endif +#include +#include +#ifdef __cplusplus +extern "C" { +#endif +#define try 1 +#ifdef AIX +#if AIX >= 42 +#define try 0 +#endif +#endif +#if try +extern int accept(int, struct sockaddr *, size_t t *); +#endif +#ifdef __cplusplus +} +#endif ],,[ac_cv_check_socklen_t=size_t],[ac_cv_check_socklen_t=int]) ]) ]) -- 1.7.10.4