mirror of
https://github.com/curl/curl.git
synced 2025-01-06 13:44:52 +08:00
c8925f3ec3
Closes #13605
5013 lines
132 KiB
Plaintext
5013 lines
132 KiB
Plaintext
#***************************************************************************
|
|
# _ _ ____ _
|
|
# Project ___| | | | _ \| |
|
|
# / __| | | | |_) | |
|
|
# | (__| |_| | _ <| |___
|
|
# \___|\___/|_| \_\_____|
|
|
#
|
|
# Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
#
|
|
# This software is licensed as described in the file COPYING, which
|
|
# you should have received as part of this distribution. The terms
|
|
# are also available at https://curl.se/docs/copyright.html.
|
|
#
|
|
# You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
# copies of the Software, and permit persons to whom the Software is
|
|
# furnished to do so, under the terms of the COPYING file.
|
|
#
|
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
# KIND, either express or implied.
|
|
#
|
|
# SPDX-License-Identifier: curl
|
|
#
|
|
#***************************************************************************
|
|
|
|
# File version for 'aclocal' use. Keep it a single number.
|
|
# serial 73
|
|
|
|
|
|
dnl CURL_INCLUDES_ARPA_INET
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when arpa/inet.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_ARPA_INET], [
|
|
curl_includes_arpa_inet="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
# include <sys/socket.h>
|
|
#endif
|
|
#ifdef HAVE_NETINET_IN_H
|
|
# include <netinet/in.h>
|
|
#endif
|
|
#ifdef HAVE_ARPA_INET_H
|
|
# include <arpa/inet.h>
|
|
#endif
|
|
#ifdef _WIN32
|
|
#include <winsock2.h>
|
|
#include <ws2tcpip.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h sys/socket.h netinet/in.h arpa/inet.h,
|
|
[], [], [$curl_includes_arpa_inet])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_FCNTL
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when fcntl.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_FCNTL], [
|
|
curl_includes_fcntl="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_UNISTD_H
|
|
# include <unistd.h>
|
|
#endif
|
|
#ifdef HAVE_FCNTL_H
|
|
# include <fcntl.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h unistd.h fcntl.h,
|
|
[], [], [$curl_includes_fcntl])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_IFADDRS
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when ifaddrs.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_IFADDRS], [
|
|
curl_includes_ifaddrs="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
# include <sys/socket.h>
|
|
#endif
|
|
#ifdef HAVE_NETINET_IN_H
|
|
# include <netinet/in.h>
|
|
#endif
|
|
#ifdef HAVE_IFADDRS_H
|
|
# include <ifaddrs.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h sys/socket.h netinet/in.h ifaddrs.h,
|
|
[], [], [$curl_includes_ifaddrs])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_LIBGEN
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when libgen.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_LIBGEN], [
|
|
curl_includes_libgen="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_LIBGEN_H
|
|
# include <libgen.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h libgen.h,
|
|
[], [], [$curl_includes_libgen])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_NETDB
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when netdb.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_NETDB], [
|
|
curl_includes_netdb="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_NETDB_H
|
|
# include <netdb.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h netdb.h,
|
|
[], [], [$curl_includes_netdb])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_POLL
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when poll.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_POLL], [
|
|
curl_includes_poll="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_POLL_H
|
|
# include <poll.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_POLL_H
|
|
# include <sys/poll.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h poll.h sys/poll.h,
|
|
[], [], [$curl_includes_poll])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_SETJMP
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when setjmp.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_SETJMP], [
|
|
curl_includes_setjmp="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#include <setjmp.h>
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h,
|
|
[], [], [$curl_includes_setjmp])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_SIGNAL
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when signal.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_SIGNAL], [
|
|
curl_includes_signal="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#include <signal.h>
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h,
|
|
[], [], [$curl_includes_signal])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_SOCKET
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when socket.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_SOCKET], [
|
|
curl_includes_socket="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SOCKET_H
|
|
# include <socket.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h socket.h,
|
|
[], [], [$curl_includes_socket])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_STDLIB
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when stdlib.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_STDLIB], [
|
|
curl_includes_stdlib="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#include <stdlib.h>
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h,
|
|
[], [], [$curl_includes_stdlib])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_STRING
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when string(s).h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_STRING], [
|
|
curl_includes_string="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#include <string.h>
|
|
#ifdef HAVE_STRINGS_H
|
|
# include <strings.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h strings.h,
|
|
[], [], [$curl_includes_string])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_STROPTS
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when stropts.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_STROPTS], [
|
|
curl_includes_stropts="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_UNISTD_H
|
|
# include <unistd.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
# include <sys/socket.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_IOCTL_H
|
|
# include <sys/ioctl.h>
|
|
#endif
|
|
#ifdef HAVE_STROPTS_H
|
|
# include <stropts.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h unistd.h sys/socket.h sys/ioctl.h stropts.h,
|
|
[], [], [$curl_includes_stropts])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_SYS_SOCKET
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when sys/socket.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_SYS_SOCKET], [
|
|
curl_includes_sys_socket="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
# include <sys/socket.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h sys/socket.h,
|
|
[], [], [$curl_includes_sys_socket])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_SYS_TYPES
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when sys/types.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_SYS_TYPES], [
|
|
curl_includes_sys_types="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h,
|
|
[], [], [$curl_includes_sys_types])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_SYS_XATTR
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when sys/xattr.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_SYS_XATTR], [
|
|
curl_includes_sys_xattr="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_XATTR_H
|
|
# include <sys/xattr.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h sys/xattr.h,
|
|
[], [], [$curl_includes_sys_xattr])
|
|
])
|
|
|
|
dnl CURL_INCLUDES_TIME
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when time.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_TIME], [
|
|
curl_includes_time="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_TIME_H
|
|
# include <sys/time.h>
|
|
#endif
|
|
#include <time.h>
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h sys/time.h,
|
|
[], [], [$curl_includes_time])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_UNISTD
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when unistd.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_UNISTD], [
|
|
curl_includes_unistd="\
|
|
/* includes start */
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
# include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_UNISTD_H
|
|
# include <unistd.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h unistd.h,
|
|
[], [], [$curl_includes_unistd])
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_WINSOCK2
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when winsock2.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_WINSOCK2], [
|
|
curl_includes_winsock2="\
|
|
/* includes start */
|
|
#ifdef _WIN32
|
|
# ifndef WIN32_LEAN_AND_MEAN
|
|
# define WIN32_LEAN_AND_MEAN
|
|
# endif
|
|
# include <winsock2.h>
|
|
#endif
|
|
/* includes end */"
|
|
CURL_CHECK_NATIVE_WINDOWS
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_WS2TCPIP
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when ws2tcpip.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_WS2TCPIP], [
|
|
curl_includes_ws2tcpip="\
|
|
/* includes start */
|
|
#ifdef _WIN32
|
|
# ifndef WIN32_LEAN_AND_MEAN
|
|
# define WIN32_LEAN_AND_MEAN
|
|
# endif
|
|
# include <winsock2.h>
|
|
# include <ws2tcpip.h>
|
|
#endif
|
|
/* includes end */"
|
|
CURL_CHECK_NATIVE_WINDOWS
|
|
])
|
|
|
|
|
|
dnl CURL_INCLUDES_BSDSOCKET
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when bsdsocket.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_BSDSOCKET], [
|
|
curl_includes_bsdsocket="\
|
|
/* includes start */
|
|
#if defined(HAVE_PROTO_BSDSOCKET_H)
|
|
# define __NO_NET_API
|
|
# define __USE_INLINE__
|
|
# include <proto/bsdsocket.h>
|
|
# ifdef HAVE_SYS_IOCTL_H
|
|
# include <sys/ioctl.h>
|
|
# endif
|
|
# ifdef __amigaos4__
|
|
struct SocketIFace *ISocket = NULL;
|
|
# else
|
|
struct Library *SocketBase = NULL;
|
|
# endif
|
|
# define select(a,b,c,d,e) WaitSelect(a,b,c,d,e,0)
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
proto/bsdsocket.h,
|
|
[], [], [$curl_includes_bsdsocket])
|
|
])
|
|
|
|
dnl CURL_INCLUDES_NETIF
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with list of headers that must be
|
|
dnl included when net/if.h is to be included.
|
|
|
|
AC_DEFUN([CURL_INCLUDES_NETIF], [
|
|
curl_includes_netif="\
|
|
/* includes start */
|
|
#ifdef HAVE_NET_IF_H
|
|
# include <net/if.h>
|
|
#endif
|
|
/* includes end */"
|
|
AC_CHECK_HEADERS(
|
|
net/if.h,
|
|
[], [], [$curl_includes_netif])
|
|
])
|
|
|
|
|
|
dnl CURL_PREPROCESS_CALLCONV
|
|
dnl -------------------------------------------------
|
|
dnl Set up variable with a preprocessor block which
|
|
dnl defines function calling convention.
|
|
|
|
AC_DEFUN([CURL_PREPROCESS_CALLCONV], [
|
|
curl_preprocess_callconv="\
|
|
/* preprocess start */
|
|
#ifdef _WIN32
|
|
# define FUNCALLCONV __stdcall
|
|
#else
|
|
# define FUNCALLCONV
|
|
#endif
|
|
/* preprocess end */"
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_ALARM
|
|
dnl -------------------------------------------------
|
|
dnl Verify if alarm is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_alarm, then
|
|
dnl HAVE_ALARM will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_ALARM], [
|
|
AC_REQUIRE([CURL_INCLUDES_UNISTD])dnl
|
|
#
|
|
tst_links_alarm="unknown"
|
|
tst_proto_alarm="unknown"
|
|
tst_compi_alarm="unknown"
|
|
tst_allow_alarm="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if alarm can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([alarm])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_alarm="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_alarm="no"
|
|
])
|
|
#
|
|
if test "$tst_links_alarm" = "yes"; then
|
|
AC_MSG_CHECKING([if alarm is prototyped])
|
|
AC_EGREP_CPP([alarm],[
|
|
$curl_includes_unistd
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_alarm="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_alarm="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_alarm" = "yes"; then
|
|
AC_MSG_CHECKING([if alarm is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_unistd
|
|
]],[[
|
|
if(0 != alarm(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_alarm="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_alarm="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_alarm" = "yes"; then
|
|
AC_MSG_CHECKING([if alarm usage allowed])
|
|
if test "x$curl_disallow_alarm" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_alarm="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_alarm="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if alarm might be used])
|
|
if test "$tst_links_alarm" = "yes" &&
|
|
test "$tst_proto_alarm" = "yes" &&
|
|
test "$tst_compi_alarm" = "yes" &&
|
|
test "$tst_allow_alarm" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_ALARM, 1,
|
|
[Define to 1 if you have the alarm function.])
|
|
curl_cv_func_alarm="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_alarm="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_BASENAME
|
|
dnl -------------------------------------------------
|
|
dnl Verify if basename is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_basename, then
|
|
dnl HAVE_BASENAME will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_BASENAME], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_LIBGEN])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_UNISTD])dnl
|
|
#
|
|
tst_links_basename="unknown"
|
|
tst_proto_basename="unknown"
|
|
tst_compi_basename="unknown"
|
|
tst_allow_basename="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if basename can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([basename])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_basename="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_basename="no"
|
|
])
|
|
#
|
|
if test "$tst_links_basename" = "yes"; then
|
|
AC_MSG_CHECKING([if basename is prototyped])
|
|
AC_EGREP_CPP([basename],[
|
|
$curl_includes_string
|
|
$curl_includes_libgen
|
|
$curl_includes_unistd
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_basename="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_basename="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_basename" = "yes"; then
|
|
AC_MSG_CHECKING([if basename is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
$curl_includes_libgen
|
|
$curl_includes_unistd
|
|
]],[[
|
|
if(0 != basename(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_basename="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_basename="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_basename" = "yes"; then
|
|
AC_MSG_CHECKING([if basename usage allowed])
|
|
if test "x$curl_disallow_basename" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_basename="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_basename="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if basename might be used])
|
|
if test "$tst_links_basename" = "yes" &&
|
|
test "$tst_proto_basename" = "yes" &&
|
|
test "$tst_compi_basename" = "yes" &&
|
|
test "$tst_allow_basename" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_BASENAME, 1,
|
|
[Define to 1 if you have the basename function.])
|
|
curl_cv_func_basename="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_basename="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_CLOSESOCKET
|
|
dnl -------------------------------------------------
|
|
dnl Verify if closesocket is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_closesocket, then
|
|
dnl HAVE_CLOSESOCKET will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_CLOSESOCKET], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_SOCKET])dnl
|
|
#
|
|
tst_links_closesocket="unknown"
|
|
tst_proto_closesocket="unknown"
|
|
tst_compi_closesocket="unknown"
|
|
tst_allow_closesocket="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if closesocket can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_socket
|
|
]],[[
|
|
if(0 != closesocket(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_closesocket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_closesocket="no"
|
|
])
|
|
#
|
|
if test "$tst_links_closesocket" = "yes"; then
|
|
AC_MSG_CHECKING([if closesocket is prototyped])
|
|
AC_EGREP_CPP([closesocket],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_socket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_closesocket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_closesocket="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_closesocket" = "yes"; then
|
|
AC_MSG_CHECKING([if closesocket is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_socket
|
|
]],[[
|
|
if(0 != closesocket(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_closesocket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_closesocket="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_closesocket" = "yes"; then
|
|
AC_MSG_CHECKING([if closesocket usage allowed])
|
|
if test "x$curl_disallow_closesocket" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_closesocket="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_closesocket="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if closesocket might be used])
|
|
if test "$tst_links_closesocket" = "yes" &&
|
|
test "$tst_proto_closesocket" = "yes" &&
|
|
test "$tst_compi_closesocket" = "yes" &&
|
|
test "$tst_allow_closesocket" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_CLOSESOCKET, 1,
|
|
[Define to 1 if you have the closesocket function.])
|
|
curl_cv_func_closesocket="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_closesocket="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_CLOSESOCKET_CAMEL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if CloseSocket is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_closesocket_camel,
|
|
dnl then HAVE_CLOSESOCKET_CAMEL will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_CLOSESOCKET_CAMEL], [
|
|
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_BSDSOCKET])dnl
|
|
#
|
|
tst_links_closesocket_camel="unknown"
|
|
tst_proto_closesocket_camel="unknown"
|
|
tst_compi_closesocket_camel="unknown"
|
|
tst_allow_closesocket_camel="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if CloseSocket can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
]],[[
|
|
if(0 != CloseSocket(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_closesocket_camel="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_closesocket_camel="no"
|
|
])
|
|
#
|
|
if test "$tst_links_closesocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if CloseSocket is prototyped])
|
|
AC_EGREP_CPP([CloseSocket],[
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_closesocket_camel="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_closesocket_camel="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_closesocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if CloseSocket is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
]],[[
|
|
if(0 != CloseSocket(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_closesocket_camel="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_closesocket_camel="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_closesocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if CloseSocket usage allowed])
|
|
if test "x$curl_disallow_closesocket_camel" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_closesocket_camel="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_closesocket_camel="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if CloseSocket might be used])
|
|
if test "$tst_links_closesocket_camel" = "yes" &&
|
|
test "$tst_proto_closesocket_camel" = "yes" &&
|
|
test "$tst_compi_closesocket_camel" = "yes" &&
|
|
test "$tst_allow_closesocket_camel" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_CLOSESOCKET_CAMEL, 1,
|
|
[Define to 1 if you have the CloseSocket camel case function.])
|
|
curl_cv_func_closesocket_camel="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_closesocket_camel="no"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_CHECK_FUNC_FCNTL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if fcntl is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_fcntl, then
|
|
dnl HAVE_FCNTL will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_FCNTL], [
|
|
AC_REQUIRE([CURL_INCLUDES_FCNTL])dnl
|
|
#
|
|
tst_links_fcntl="unknown"
|
|
tst_proto_fcntl="unknown"
|
|
tst_compi_fcntl="unknown"
|
|
tst_allow_fcntl="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if fcntl can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([fcntl])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_fcntl="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_fcntl="no"
|
|
])
|
|
#
|
|
if test "$tst_links_fcntl" = "yes"; then
|
|
AC_MSG_CHECKING([if fcntl is prototyped])
|
|
AC_EGREP_CPP([fcntl],[
|
|
$curl_includes_fcntl
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_fcntl="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_fcntl="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_fcntl" = "yes"; then
|
|
AC_MSG_CHECKING([if fcntl is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_fcntl
|
|
]],[[
|
|
if(0 != fcntl(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_fcntl="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_fcntl="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_fcntl" = "yes"; then
|
|
AC_MSG_CHECKING([if fcntl usage allowed])
|
|
if test "x$curl_disallow_fcntl" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_fcntl="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_fcntl="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if fcntl might be used])
|
|
if test "$tst_links_fcntl" = "yes" &&
|
|
test "$tst_proto_fcntl" = "yes" &&
|
|
test "$tst_compi_fcntl" = "yes" &&
|
|
test "$tst_allow_fcntl" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_FCNTL, 1,
|
|
[Define to 1 if you have the fcntl function.])
|
|
curl_cv_func_fcntl="yes"
|
|
CURL_CHECK_FUNC_FCNTL_O_NONBLOCK
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_fcntl="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_FCNTL_O_NONBLOCK
|
|
dnl -------------------------------------------------
|
|
dnl Verify if fcntl with status flag O_NONBLOCK is
|
|
dnl available, can be compiled, and seems to work. If
|
|
dnl all of these are true, then HAVE_FCNTL_O_NONBLOCK
|
|
dnl will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_FCNTL_O_NONBLOCK], [
|
|
#
|
|
tst_compi_fcntl_o_nonblock="unknown"
|
|
tst_allow_fcntl_o_nonblock="unknown"
|
|
#
|
|
case $host_os in
|
|
sunos4* | aix3*)
|
|
dnl O_NONBLOCK does not work on these platforms
|
|
curl_disallow_fcntl_o_nonblock="yes"
|
|
;;
|
|
esac
|
|
#
|
|
if test "$curl_cv_func_fcntl" = "yes"; then
|
|
AC_MSG_CHECKING([if fcntl O_NONBLOCK is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_fcntl
|
|
]],[[
|
|
int flags = 0;
|
|
if(0 != fcntl(0, F_SETFL, flags | O_NONBLOCK))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_fcntl_o_nonblock="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_fcntl_o_nonblock="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_fcntl_o_nonblock" = "yes"; then
|
|
AC_MSG_CHECKING([if fcntl O_NONBLOCK usage allowed])
|
|
if test "x$curl_disallow_fcntl_o_nonblock" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_fcntl_o_nonblock="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_fcntl_o_nonblock="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if fcntl O_NONBLOCK might be used])
|
|
if test "$tst_compi_fcntl_o_nonblock" = "yes" &&
|
|
test "$tst_allow_fcntl_o_nonblock" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_FCNTL_O_NONBLOCK, 1,
|
|
[Define to 1 if you have a working fcntl O_NONBLOCK function.])
|
|
curl_cv_func_fcntl_o_nonblock="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_fcntl_o_nonblock="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_FREEADDRINFO
|
|
dnl -------------------------------------------------
|
|
dnl Verify if freeaddrinfo is available, prototyped,
|
|
dnl and can be compiled. If all of these are true,
|
|
dnl and usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_freeaddrinfo, then
|
|
dnl HAVE_FREEADDRINFO will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_FREEADDRINFO], [
|
|
AC_REQUIRE([CURL_INCLUDES_WS2TCPIP])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_NETDB])dnl
|
|
#
|
|
tst_links_freeaddrinfo="unknown"
|
|
tst_proto_freeaddrinfo="unknown"
|
|
tst_compi_freeaddrinfo="unknown"
|
|
tst_allow_freeaddrinfo="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if freeaddrinfo can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
freeaddrinfo(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_freeaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_freeaddrinfo="no"
|
|
])
|
|
#
|
|
if test "$tst_links_freeaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if freeaddrinfo is prototyped])
|
|
AC_EGREP_CPP([freeaddrinfo],[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_freeaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_freeaddrinfo="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_freeaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if freeaddrinfo is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
freeaddrinfo(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_freeaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_freeaddrinfo="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_freeaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if freeaddrinfo usage allowed])
|
|
if test "x$curl_disallow_freeaddrinfo" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_freeaddrinfo="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_freeaddrinfo="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if freeaddrinfo might be used])
|
|
if test "$tst_links_freeaddrinfo" = "yes" &&
|
|
test "$tst_proto_freeaddrinfo" = "yes" &&
|
|
test "$tst_compi_freeaddrinfo" = "yes" &&
|
|
test "$tst_allow_freeaddrinfo" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_FREEADDRINFO, 1,
|
|
[Define to 1 if you have the freeaddrinfo function.])
|
|
curl_cv_func_freeaddrinfo="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_freeaddrinfo="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_FSETXATTR
|
|
dnl -------------------------------------------------
|
|
dnl Verify if fsetxattr is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_fsetxattr, then
|
|
dnl HAVE_FSETXATTR will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_FSETXATTR], [
|
|
AC_REQUIRE([CURL_INCLUDES_SYS_XATTR])dnl
|
|
#
|
|
tst_links_fsetxattr="unknown"
|
|
tst_proto_fsetxattr="unknown"
|
|
tst_compi_fsetxattr="unknown"
|
|
tst_allow_fsetxattr="unknown"
|
|
tst_nargs_fsetxattr="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if fsetxattr can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([fsetxattr])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_fsetxattr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_fsetxattr="no"
|
|
])
|
|
#
|
|
if test "$tst_links_fsetxattr" = "yes"; then
|
|
AC_MSG_CHECKING([if fsetxattr is prototyped])
|
|
AC_EGREP_CPP([fsetxattr],[
|
|
$curl_includes_sys_xattr
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_fsetxattr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_fsetxattr="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_fsetxattr" = "yes"; then
|
|
if test "$tst_nargs_fsetxattr" = "unknown"; then
|
|
AC_MSG_CHECKING([if fsetxattr takes 5 args.])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_sys_xattr
|
|
]],[[
|
|
if(0 != fsetxattr(0, 0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_fsetxattr="yes"
|
|
tst_nargs_fsetxattr="5"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_fsetxattr="no"
|
|
])
|
|
fi
|
|
if test "$tst_nargs_fsetxattr" = "unknown"; then
|
|
AC_MSG_CHECKING([if fsetxattr takes 6 args.])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_sys_xattr
|
|
]],[[
|
|
if(0 != fsetxattr(0, 0, 0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_fsetxattr="yes"
|
|
tst_nargs_fsetxattr="6"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_fsetxattr="no"
|
|
])
|
|
fi
|
|
AC_MSG_CHECKING([if fsetxattr is compilable])
|
|
if test "$tst_compi_fsetxattr" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
fi
|
|
fi
|
|
#
|
|
if test "$tst_compi_fsetxattr" = "yes"; then
|
|
AC_MSG_CHECKING([if fsetxattr usage allowed])
|
|
if test "x$curl_disallow_fsetxattr" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_fsetxattr="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_fsetxattr="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if fsetxattr might be used])
|
|
if test "$tst_links_fsetxattr" = "yes" &&
|
|
test "$tst_proto_fsetxattr" = "yes" &&
|
|
test "$tst_compi_fsetxattr" = "yes" &&
|
|
test "$tst_allow_fsetxattr" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_FSETXATTR, 1,
|
|
[Define to 1 if you have the fsetxattr function.])
|
|
dnl AC_DEFINE_UNQUOTED(FSETXATTR_ARGS, $tst_nargs_fsetxattr,
|
|
dnl [Specifies the number of arguments to fsetxattr])
|
|
#
|
|
if test "$tst_nargs_fsetxattr" -eq "5"; then
|
|
AC_DEFINE(HAVE_FSETXATTR_5, 1, [fsetxattr() takes 5 args])
|
|
elif test "$tst_nargs_fsetxattr" -eq "6"; then
|
|
AC_DEFINE(HAVE_FSETXATTR_6, 1, [fsetxattr() takes 6 args])
|
|
fi
|
|
#
|
|
curl_cv_func_fsetxattr="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_fsetxattr="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_FTRUNCATE
|
|
dnl -------------------------------------------------
|
|
dnl Verify if ftruncate is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_ftruncate, then
|
|
dnl HAVE_FTRUNCATE will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_FTRUNCATE], [
|
|
AC_REQUIRE([CURL_INCLUDES_UNISTD])dnl
|
|
#
|
|
tst_links_ftruncate="unknown"
|
|
tst_proto_ftruncate="unknown"
|
|
tst_compi_ftruncate="unknown"
|
|
tst_allow_ftruncate="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if ftruncate can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([ftruncate])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_ftruncate="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_ftruncate="no"
|
|
])
|
|
#
|
|
if test "$tst_links_ftruncate" = "yes"; then
|
|
AC_MSG_CHECKING([if ftruncate is prototyped])
|
|
AC_EGREP_CPP([ftruncate],[
|
|
$curl_includes_unistd
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_ftruncate="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_ftruncate="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_ftruncate" = "yes"; then
|
|
AC_MSG_CHECKING([if ftruncate is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_unistd
|
|
]],[[
|
|
if(0 != ftruncate(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ftruncate="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ftruncate="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ftruncate" = "yes"; then
|
|
AC_MSG_CHECKING([if ftruncate usage allowed])
|
|
if test "x$curl_disallow_ftruncate" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ftruncate="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ftruncate="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if ftruncate might be used])
|
|
if test "$tst_links_ftruncate" = "yes" &&
|
|
test "$tst_proto_ftruncate" = "yes" &&
|
|
test "$tst_compi_ftruncate" = "yes" &&
|
|
test "$tst_allow_ftruncate" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_FTRUNCATE, 1,
|
|
[Define to 1 if you have the ftruncate function.])
|
|
curl_cv_func_ftruncate="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ftruncate="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_GETADDRINFO
|
|
dnl -------------------------------------------------
|
|
dnl Verify if getaddrinfo is available, prototyped, can
|
|
dnl be compiled and seems to work. If all of these are
|
|
dnl true, and usage has not been previously disallowed
|
|
dnl with shell variable curl_disallow_getaddrinfo, then
|
|
dnl HAVE_GETADDRINFO will be defined. Additionally when
|
|
dnl HAVE_GETADDRINFO gets defined this will also attempt
|
|
dnl to find out if getaddrinfo happens to be threadsafe,
|
|
dnl defining HAVE_GETADDRINFO_THREADSAFE when true.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETADDRINFO], [
|
|
AC_REQUIRE([CURL_INCLUDES_WS2TCPIP])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_NETDB])dnl
|
|
AC_REQUIRE([CURL_CHECK_NATIVE_WINDOWS])dnl
|
|
#
|
|
tst_links_getaddrinfo="unknown"
|
|
tst_proto_getaddrinfo="unknown"
|
|
tst_compi_getaddrinfo="unknown"
|
|
tst_works_getaddrinfo="unknown"
|
|
tst_allow_getaddrinfo="unknown"
|
|
tst_tsafe_getaddrinfo="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if getaddrinfo can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
if(0 != getaddrinfo(0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_getaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_getaddrinfo="no"
|
|
])
|
|
#
|
|
if test "$tst_links_getaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if getaddrinfo is prototyped])
|
|
AC_EGREP_CPP([getaddrinfo],[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_getaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_getaddrinfo="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_getaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if getaddrinfo is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
if(0 != getaddrinfo(0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_getaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_getaddrinfo="no"
|
|
])
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_compi_getaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if getaddrinfo seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_ws2tcpip
|
|
$curl_includes_stdlib
|
|
$curl_includes_string
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
struct addrinfo hints;
|
|
struct addrinfo *ai = 0;
|
|
int error;
|
|
|
|
#ifdef _WIN32
|
|
WSADATA wsa;
|
|
if(WSAStartup(MAKEWORD(2, 2), &wsa))
|
|
exit(2);
|
|
#endif
|
|
|
|
memset(&hints, 0, sizeof(hints));
|
|
hints.ai_flags = AI_NUMERICHOST;
|
|
hints.ai_family = AF_UNSPEC;
|
|
hints.ai_socktype = SOCK_STREAM;
|
|
error = getaddrinfo("127.0.0.1", 0, &hints, &ai);
|
|
if(error || !ai)
|
|
exit(1); /* fail */
|
|
else
|
|
exit(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_getaddrinfo="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_getaddrinfo="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_getaddrinfo" = "yes" &&
|
|
test "$tst_works_getaddrinfo" != "no"; then
|
|
AC_MSG_CHECKING([if getaddrinfo usage allowed])
|
|
if test "x$curl_disallow_getaddrinfo" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_getaddrinfo="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_getaddrinfo="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if getaddrinfo might be used])
|
|
if test "$tst_links_getaddrinfo" = "yes" &&
|
|
test "$tst_proto_getaddrinfo" = "yes" &&
|
|
test "$tst_compi_getaddrinfo" = "yes" &&
|
|
test "$tst_allow_getaddrinfo" = "yes" &&
|
|
test "$tst_works_getaddrinfo" != "no"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETADDRINFO, 1,
|
|
[Define to 1 if you have a working getaddrinfo function.])
|
|
curl_cv_func_getaddrinfo="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_getaddrinfo="no"
|
|
curl_cv_func_getaddrinfo_threadsafe="no"
|
|
fi
|
|
#
|
|
if test "$curl_cv_func_getaddrinfo" = "yes"; then
|
|
AC_MSG_CHECKING([if getaddrinfo is threadsafe])
|
|
case $host_os in
|
|
aix[[1234]].* | aix5.[[01]].*)
|
|
dnl aix 5.1 and older
|
|
tst_tsafe_getaddrinfo="no"
|
|
;;
|
|
aix*)
|
|
dnl aix 5.2 and newer
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
darwin[[12345]].*)
|
|
dnl darwin 5.0 and mac os x 10.1.X and older
|
|
tst_tsafe_getaddrinfo="no"
|
|
;;
|
|
darwin*)
|
|
dnl darwin 6.0 and mac os x 10.2.X and newer
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
freebsd[[1234]].* | freebsd5.[[1234]]*)
|
|
dnl freebsd 5.4 and older
|
|
tst_tsafe_getaddrinfo="no"
|
|
;;
|
|
freebsd*)
|
|
dnl freebsd 5.5 and newer
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
hpux[[123456789]].* | hpux10.* | hpux11.0* | hpux11.10*)
|
|
dnl hpux 11.10 and older
|
|
tst_tsafe_getaddrinfo="no"
|
|
;;
|
|
hpux*)
|
|
dnl hpux 11.11 and newer
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
midnightbsd*)
|
|
dnl all MidnightBSD versions
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
netbsd[[123]].*)
|
|
dnl netbsd 3.X and older
|
|
tst_tsafe_getaddrinfo="no"
|
|
;;
|
|
netbsd*)
|
|
dnl netbsd 4.X and newer
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
*bsd*)
|
|
dnl All other bsd's
|
|
tst_tsafe_getaddrinfo="no"
|
|
;;
|
|
solaris2*)
|
|
dnl solaris which have it
|
|
tst_tsafe_getaddrinfo="yes"
|
|
;;
|
|
esac
|
|
if test "$tst_tsafe_getaddrinfo" = "unknown" &&
|
|
test "$curl_cv_native_windows" = "yes"; then
|
|
tst_tsafe_getaddrinfo="yes"
|
|
fi
|
|
if test "$tst_tsafe_getaddrinfo" = "unknown"; then
|
|
CURL_CHECK_DEF_CC([h_errno], [
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
], [silent])
|
|
if test "$curl_cv_have_def_h_errno" = "yes"; then
|
|
tst_h_errno_macro="yes"
|
|
else
|
|
tst_h_errno_macro="no"
|
|
fi
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_sys_socket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
h_errno = 2;
|
|
if(0 != h_errno)
|
|
return 1;
|
|
]])
|
|
],[
|
|
tst_h_errno_modifiable_lvalue="yes"
|
|
],[
|
|
tst_h_errno_modifiable_lvalue="no"
|
|
])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
]],[[
|
|
#if defined(_POSIX_C_SOURCE) && (_POSIX_C_SOURCE >= 200809L)
|
|
return 0;
|
|
#elif defined(_XOPEN_SOURCE) && (_XOPEN_SOURCE >= 700)
|
|
return 0;
|
|
#else
|
|
force compilation error
|
|
#endif
|
|
]])
|
|
],[
|
|
tst_h_errno_sbs_issue_7="yes"
|
|
],[
|
|
tst_h_errno_sbs_issue_7="no"
|
|
])
|
|
if test "$tst_h_errno_macro" = "no" &&
|
|
test "$tst_h_errno_modifiable_lvalue" = "no" &&
|
|
test "$tst_h_errno_sbs_issue_7" = "no"; then
|
|
tst_tsafe_getaddrinfo="no"
|
|
else
|
|
tst_tsafe_getaddrinfo="yes"
|
|
fi
|
|
fi
|
|
AC_MSG_RESULT([$tst_tsafe_getaddrinfo])
|
|
if test "$tst_tsafe_getaddrinfo" = "yes"; then
|
|
AC_DEFINE_UNQUOTED(HAVE_GETADDRINFO_THREADSAFE, 1,
|
|
[Define to 1 if the getaddrinfo function is threadsafe.])
|
|
curl_cv_func_getaddrinfo_threadsafe="yes"
|
|
else
|
|
curl_cv_func_getaddrinfo_threadsafe="no"
|
|
fi
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_GETHOSTBYNAME
|
|
dnl -------------------------------------------------
|
|
dnl Verify if gethostbyname is available, prototyped,
|
|
dnl and can be compiled. If all of these are true,
|
|
dnl and usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_gethostbyname, then
|
|
dnl HAVE_GETHOSTBYNAME will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETHOSTBYNAME], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_NETDB])dnl
|
|
#
|
|
tst_links_gethostbyname="unknown"
|
|
tst_proto_gethostbyname="unknown"
|
|
tst_compi_gethostbyname="unknown"
|
|
tst_allow_gethostbyname="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if gethostbyname can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
if(0 != gethostbyname(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_gethostbyname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_gethostbyname="no"
|
|
])
|
|
#
|
|
if test "$tst_links_gethostbyname" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostbyname is prototyped])
|
|
AC_EGREP_CPP([gethostbyname],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_netdb
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_gethostbyname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_gethostbyname="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_gethostbyname" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostbyname is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_netdb
|
|
]],[[
|
|
if(0 != gethostbyname(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_gethostbyname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_gethostbyname="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_gethostbyname" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostbyname usage allowed])
|
|
if test "x$curl_disallow_gethostbyname" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_gethostbyname="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_gethostbyname="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if gethostbyname might be used])
|
|
if test "$tst_links_gethostbyname" = "yes" &&
|
|
test "$tst_proto_gethostbyname" = "yes" &&
|
|
test "$tst_compi_gethostbyname" = "yes" &&
|
|
test "$tst_allow_gethostbyname" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETHOSTBYNAME, 1,
|
|
[Define to 1 if you have the gethostbyname function.])
|
|
curl_cv_func_gethostbyname="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_gethostbyname="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_GETHOSTBYNAME_R
|
|
dnl -------------------------------------------------
|
|
dnl Verify if gethostbyname_r is available, prototyped,
|
|
dnl and can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_gethostbyname_r, then
|
|
dnl HAVE_GETHOSTBYNAME_R will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETHOSTBYNAME_R], [
|
|
AC_REQUIRE([CURL_INCLUDES_NETDB])dnl
|
|
#
|
|
tst_links_gethostbyname_r="unknown"
|
|
tst_proto_gethostbyname_r="unknown"
|
|
tst_compi_gethostbyname_r="unknown"
|
|
tst_allow_gethostbyname_r="unknown"
|
|
tst_nargs_gethostbyname_r="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if gethostbyname_r can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([gethostbyname_r])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_gethostbyname_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_gethostbyname_r="no"
|
|
])
|
|
#
|
|
if test "$tst_links_gethostbyname_r" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostbyname_r is prototyped])
|
|
AC_EGREP_CPP([gethostbyname_r],[
|
|
$curl_includes_netdb
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_gethostbyname_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_gethostbyname_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_gethostbyname_r" = "yes"; then
|
|
if test "$tst_nargs_gethostbyname_r" = "unknown"; then
|
|
AC_MSG_CHECKING([if gethostbyname_r takes 3 args.])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_netdb
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
if(0 != gethostbyname_r(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_gethostbyname_r="yes"
|
|
tst_nargs_gethostbyname_r="3"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_gethostbyname_r="no"
|
|
])
|
|
fi
|
|
if test "$tst_nargs_gethostbyname_r" = "unknown"; then
|
|
AC_MSG_CHECKING([if gethostbyname_r takes 5 args.])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_netdb
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
if(0 != gethostbyname_r(0, 0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_gethostbyname_r="yes"
|
|
tst_nargs_gethostbyname_r="5"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_gethostbyname_r="no"
|
|
])
|
|
fi
|
|
if test "$tst_nargs_gethostbyname_r" = "unknown"; then
|
|
AC_MSG_CHECKING([if gethostbyname_r takes 6 args.])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_netdb
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
if(0 != gethostbyname_r(0, 0, 0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_gethostbyname_r="yes"
|
|
tst_nargs_gethostbyname_r="6"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_gethostbyname_r="no"
|
|
])
|
|
fi
|
|
AC_MSG_CHECKING([if gethostbyname_r is compilable])
|
|
if test "$tst_compi_gethostbyname_r" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
fi
|
|
fi
|
|
#
|
|
if test "$tst_compi_gethostbyname_r" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostbyname_r usage allowed])
|
|
if test "x$curl_disallow_gethostbyname_r" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_gethostbyname_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_gethostbyname_r="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if gethostbyname_r might be used])
|
|
if test "$tst_links_gethostbyname_r" = "yes" &&
|
|
test "$tst_proto_gethostbyname_r" = "yes" &&
|
|
test "$tst_compi_gethostbyname_r" = "yes" &&
|
|
test "$tst_allow_gethostbyname_r" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETHOSTBYNAME_R, 1,
|
|
[Define to 1 if you have the gethostbyname_r function.])
|
|
dnl AC_DEFINE_UNQUOTED(GETHOSTBYNAME_R_ARGS, $tst_nargs_gethostbyname_r,
|
|
dnl [Specifies the number of arguments to gethostbyname_r])
|
|
#
|
|
if test "$tst_nargs_gethostbyname_r" -eq "3"; then
|
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3, 1, [gethostbyname_r() takes 3 args])
|
|
elif test "$tst_nargs_gethostbyname_r" -eq "5"; then
|
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_5, 1, [gethostbyname_r() takes 5 args])
|
|
elif test "$tst_nargs_gethostbyname_r" -eq "6"; then
|
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_6, 1, [gethostbyname_r() takes 6 args])
|
|
fi
|
|
#
|
|
curl_cv_func_gethostbyname_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_gethostbyname_r="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_GETHOSTNAME
|
|
dnl -------------------------------------------------
|
|
dnl Verify if gethostname is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_gethostname, then
|
|
dnl HAVE_GETHOSTNAME will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETHOSTNAME], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_BSDSOCKET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_UNISTD])dnl
|
|
AC_REQUIRE([CURL_PREPROCESS_CALLCONV])dnl
|
|
#
|
|
tst_links_gethostname="unknown"
|
|
tst_proto_gethostname="unknown"
|
|
tst_compi_gethostname="unknown"
|
|
tst_allow_gethostname="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if gethostname can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_unistd
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
if(0 != gethostname(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_gethostname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_gethostname="no"
|
|
])
|
|
#
|
|
if test "$tst_links_gethostname" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostname is prototyped])
|
|
AC_EGREP_CPP([gethostname],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_unistd
|
|
$curl_includes_bsdsocket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_gethostname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_gethostname="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_gethostname" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostname is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_unistd
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
if(0 != gethostname(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_gethostname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_gethostname="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_gethostname" = "yes"; then
|
|
AC_MSG_CHECKING([for gethostname arg 2 data type])
|
|
tst_gethostname_type_arg2="unknown"
|
|
for tst_arg1 in 'char *' 'unsigned char *' 'void *'; do
|
|
for tst_arg2 in 'int' 'unsigned int' 'size_t'; do
|
|
if test "$tst_gethostname_type_arg2" = "unknown"; then
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_unistd
|
|
$curl_includes_bsdsocket
|
|
$curl_preprocess_callconv
|
|
extern int FUNCALLCONV gethostname($tst_arg1, $tst_arg2);
|
|
]],[[
|
|
if(0 != gethostname(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
tst_gethostname_type_arg2="$tst_arg2"
|
|
])
|
|
fi
|
|
done
|
|
done
|
|
AC_MSG_RESULT([$tst_gethostname_type_arg2])
|
|
if test "$tst_gethostname_type_arg2" != "unknown"; then
|
|
AC_DEFINE_UNQUOTED(GETHOSTNAME_TYPE_ARG2, $tst_gethostname_type_arg2,
|
|
[Define to the type of arg 2 for gethostname.])
|
|
fi
|
|
fi
|
|
#
|
|
if test "$tst_compi_gethostname" = "yes"; then
|
|
AC_MSG_CHECKING([if gethostname usage allowed])
|
|
if test "x$curl_disallow_gethostname" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_gethostname="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_gethostname="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if gethostname might be used])
|
|
if test "$tst_links_gethostname" = "yes" &&
|
|
test "$tst_proto_gethostname" = "yes" &&
|
|
test "$tst_compi_gethostname" = "yes" &&
|
|
test "$tst_allow_gethostname" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETHOSTNAME, 1,
|
|
[Define to 1 if you have the gethostname function.])
|
|
curl_cv_func_gethostname="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_gethostname="no"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_CHECK_FUNC_GETPEERNAME
|
|
dnl -------------------------------------------------
|
|
dnl Verify if getpeername is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_getpeername, then
|
|
dnl HAVE_GETPEERNAME will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETPEERNAME], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_UNISTD])dnl
|
|
AC_REQUIRE([CURL_PREPROCESS_CALLCONV])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_BSDSOCKET])dnl
|
|
#
|
|
tst_links_getpeername="unknown"
|
|
tst_proto_getpeername="unknown"
|
|
tst_compi_getpeername="unknown"
|
|
tst_allow_getpeername="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if getpeername can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
]],[[
|
|
if(0 != getpeername(0, (void *)0, (void *)0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_getpeername="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_getpeername="no"
|
|
])
|
|
#
|
|
if test "$tst_links_getpeername" = "yes"; then
|
|
AC_MSG_CHECKING([if getpeername is prototyped])
|
|
AC_EGREP_CPP([getpeername],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_getpeername="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_getpeername="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_getpeername" = "yes"; then
|
|
AC_MSG_CHECKING([if getpeername is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
]],[[
|
|
if(0 != getpeername(0, (void *)0, (void *)0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_getpeername="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_getpeername="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_getpeername" = "yes"; then
|
|
AC_MSG_CHECKING([if getpeername usage allowed])
|
|
if test "x$curl_disallow_getpeername" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_getpeername="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_getpeername="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if getpeername might be used])
|
|
if test "$tst_links_getpeername" = "yes" &&
|
|
test "$tst_proto_getpeername" = "yes" &&
|
|
test "$tst_compi_getpeername" = "yes" &&
|
|
test "$tst_allow_getpeername" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETPEERNAME, 1,
|
|
[Define to 1 if you have the getpeername function.])
|
|
curl_cv_func_getpeername="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_getpeername="no"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_CHECK_FUNC_GETSOCKNAME
|
|
dnl -------------------------------------------------
|
|
dnl Verify if getsockname is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_getsockname, then
|
|
dnl HAVE_GETSOCKNAME will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETSOCKNAME], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_UNISTD])dnl
|
|
AC_REQUIRE([CURL_PREPROCESS_CALLCONV])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_BSDSOCKET])dnl
|
|
#
|
|
tst_links_getsockname="unknown"
|
|
tst_proto_getsockname="unknown"
|
|
tst_compi_getsockname="unknown"
|
|
tst_allow_getsockname="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if getsockname can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
]],[[
|
|
if(0 != getsockname(0, (void *)0, (void *)0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_getsockname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_getsockname="no"
|
|
])
|
|
#
|
|
if test "$tst_links_getsockname" = "yes"; then
|
|
AC_MSG_CHECKING([if getsockname is prototyped])
|
|
AC_EGREP_CPP([getsockname],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_getsockname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_getsockname="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_getsockname" = "yes"; then
|
|
AC_MSG_CHECKING([if getsockname is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
]],[[
|
|
if(0 != getsockname(0, (void *)0, (void *)0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_getsockname="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_getsockname="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_getsockname" = "yes"; then
|
|
AC_MSG_CHECKING([if getsockname usage allowed])
|
|
if test "x$curl_disallow_getsockname" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_getsockname="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_getsockname="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if getsockname might be used])
|
|
if test "$tst_links_getsockname" = "yes" &&
|
|
test "$tst_proto_getsockname" = "yes" &&
|
|
test "$tst_compi_getsockname" = "yes" &&
|
|
test "$tst_allow_getsockname" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETSOCKNAME, 1,
|
|
[Define to 1 if you have the getsockname function.])
|
|
curl_cv_func_getsockname="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_getsockname="no"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_CHECK_FUNC_IF_NAMETOINDEX
|
|
dnl -------------------------------------------------
|
|
dnl Verify if if_nametoindex is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_if_nametoindex, then
|
|
dnl HAVE_IF_NAMETOINDEX will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IF_NAMETOINDEX], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_NETIF])dnl
|
|
AC_REQUIRE([CURL_PREPROCESS_CALLCONV])dnl
|
|
#
|
|
tst_links_if_nametoindex="unknown"
|
|
tst_proto_if_nametoindex="unknown"
|
|
tst_compi_if_nametoindex="unknown"
|
|
tst_allow_if_nametoindex="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if if_nametoindex can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
#include <net/if.h>
|
|
]],[[
|
|
if(0 != if_nametoindex(""))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_if_nametoindex="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_if_nametoindex="no"
|
|
])
|
|
#
|
|
if test "$tst_links_if_nametoindex" = "yes"; then
|
|
AC_MSG_CHECKING([if if_nametoindex is prototyped])
|
|
AC_EGREP_CPP([if_nametoindex],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_netif
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_if_nametoindex="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_if_nametoindex="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_if_nametoindex" = "yes"; then
|
|
AC_MSG_CHECKING([if if_nametoindex is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_netif
|
|
]],[[
|
|
if(0 != if_nametoindex(""))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_if_nametoindex="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_if_nametoindex="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_if_nametoindex" = "yes"; then
|
|
AC_MSG_CHECKING([if if_nametoindex usage allowed])
|
|
if test "x$curl_disallow_if_nametoindex" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_if_nametoindex="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_if_nametoindex="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if if_nametoindex might be used])
|
|
if test "$tst_links_if_nametoindex" = "yes" &&
|
|
test "$tst_proto_if_nametoindex" = "yes" &&
|
|
test "$tst_compi_if_nametoindex" = "yes" &&
|
|
test "$tst_allow_if_nametoindex" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IF_NAMETOINDEX, 1,
|
|
[Define to 1 if you have the if_nametoindex function.])
|
|
curl_cv_func_if_nametoindex="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_if_nametoindex="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_GETIFADDRS
|
|
dnl -------------------------------------------------
|
|
dnl Verify if getifaddrs is available, prototyped, can
|
|
dnl be compiled and seems to work. If all of these are
|
|
dnl true, and usage has not been previously disallowed
|
|
dnl with shell variable curl_disallow_getifaddrs, then
|
|
dnl HAVE_GETIFADDRS will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GETIFADDRS], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_IFADDRS])dnl
|
|
#
|
|
tst_links_getifaddrs="unknown"
|
|
tst_proto_getifaddrs="unknown"
|
|
tst_compi_getifaddrs="unknown"
|
|
tst_works_getifaddrs="unknown"
|
|
tst_allow_getifaddrs="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if getifaddrs can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([getifaddrs])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_getifaddrs="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_getifaddrs="no"
|
|
])
|
|
#
|
|
if test "$tst_links_getifaddrs" = "yes"; then
|
|
AC_MSG_CHECKING([if getifaddrs is prototyped])
|
|
AC_EGREP_CPP([getifaddrs],[
|
|
$curl_includes_ifaddrs
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_getifaddrs="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_getifaddrs="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_getifaddrs" = "yes"; then
|
|
AC_MSG_CHECKING([if getifaddrs is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_ifaddrs
|
|
]],[[
|
|
if(0 != getifaddrs(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_getifaddrs="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_getifaddrs="no"
|
|
])
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_compi_getifaddrs" = "yes"; then
|
|
AC_MSG_CHECKING([if getifaddrs seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_ifaddrs
|
|
]],[[
|
|
struct ifaddrs *ifa = 0;
|
|
int error;
|
|
|
|
error = getifaddrs(&ifa);
|
|
if(error || !ifa)
|
|
exit(1); /* fail */
|
|
else
|
|
exit(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_getifaddrs="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_getifaddrs="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_getifaddrs" = "yes" &&
|
|
test "$tst_works_getifaddrs" != "no"; then
|
|
AC_MSG_CHECKING([if getifaddrs usage allowed])
|
|
if test "x$curl_disallow_getifaddrs" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_getifaddrs="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_getifaddrs="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if getifaddrs might be used])
|
|
if test "$tst_links_getifaddrs" = "yes" &&
|
|
test "$tst_proto_getifaddrs" = "yes" &&
|
|
test "$tst_compi_getifaddrs" = "yes" &&
|
|
test "$tst_allow_getifaddrs" = "yes" &&
|
|
test "$tst_works_getifaddrs" != "no"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GETIFADDRS, 1,
|
|
[Define to 1 if you have a working getifaddrs function.])
|
|
curl_cv_func_getifaddrs="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_getifaddrs="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_GMTIME_R
|
|
dnl -------------------------------------------------
|
|
dnl Verify if gmtime_r is available, prototyped, can
|
|
dnl be compiled and seems to work. If all of these are
|
|
dnl true, and usage has not been previously disallowed
|
|
dnl with shell variable curl_disallow_gmtime_r, then
|
|
dnl HAVE_GMTIME_R will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_GMTIME_R], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_TIME])dnl
|
|
#
|
|
tst_links_gmtime_r="unknown"
|
|
tst_proto_gmtime_r="unknown"
|
|
tst_compi_gmtime_r="unknown"
|
|
tst_works_gmtime_r="unknown"
|
|
tst_allow_gmtime_r="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if gmtime_r can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([gmtime_r])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_gmtime_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_gmtime_r="no"
|
|
])
|
|
#
|
|
if test "$tst_links_gmtime_r" = "yes"; then
|
|
AC_MSG_CHECKING([if gmtime_r is prototyped])
|
|
AC_EGREP_CPP([gmtime_r],[
|
|
$curl_includes_time
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_gmtime_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_gmtime_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_gmtime_r" = "yes"; then
|
|
AC_MSG_CHECKING([if gmtime_r is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_time
|
|
]],[[
|
|
if(0 != gmtime_r(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_gmtime_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_gmtime_r="no"
|
|
])
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_compi_gmtime_r" = "yes"; then
|
|
AC_MSG_CHECKING([if gmtime_r seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_time
|
|
]],[[
|
|
time_t local = 1170352587;
|
|
struct tm *gmt = 0;
|
|
struct tm result;
|
|
gmt = gmtime_r(&local, &result);
|
|
if(gmt)
|
|
exit(0);
|
|
else
|
|
exit(1);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_gmtime_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_gmtime_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_gmtime_r" = "yes" &&
|
|
test "$tst_works_gmtime_r" != "no"; then
|
|
AC_MSG_CHECKING([if gmtime_r usage allowed])
|
|
if test "x$curl_disallow_gmtime_r" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_gmtime_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_gmtime_r="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if gmtime_r might be used])
|
|
if test "$tst_links_gmtime_r" = "yes" &&
|
|
test "$tst_proto_gmtime_r" = "yes" &&
|
|
test "$tst_compi_gmtime_r" = "yes" &&
|
|
test "$tst_allow_gmtime_r" = "yes" &&
|
|
test "$tst_works_gmtime_r" != "no"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_GMTIME_R, 1,
|
|
[Define to 1 if you have a working gmtime_r function.])
|
|
curl_cv_func_gmtime_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_gmtime_r="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_INET_NTOP
|
|
dnl -------------------------------------------------
|
|
dnl Verify if inet_ntop is available, prototyped, can
|
|
dnl be compiled and seems to work. If all of these are
|
|
dnl true, and usage has not been previously disallowed
|
|
dnl with shell variable curl_disallow_inet_ntop, then
|
|
dnl HAVE_INET_NTOP will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_INET_NTOP], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_ARPA_INET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_inet_ntop="unknown"
|
|
tst_proto_inet_ntop="unknown"
|
|
tst_compi_inet_ntop="unknown"
|
|
tst_works_inet_ntop="unknown"
|
|
tst_allow_inet_ntop="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if inet_ntop can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([inet_ntop])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_inet_ntop="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_inet_ntop="no"
|
|
])
|
|
#
|
|
if test "$tst_links_inet_ntop" = "yes"; then
|
|
AC_MSG_CHECKING([if inet_ntop is prototyped])
|
|
AC_EGREP_CPP([inet_ntop],[
|
|
$curl_includes_arpa_inet
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_inet_ntop="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_inet_ntop="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_inet_ntop" = "yes"; then
|
|
AC_MSG_CHECKING([if inet_ntop is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_arpa_inet
|
|
]],[[
|
|
if(0 != inet_ntop(0, 0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_inet_ntop="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_inet_ntop="no"
|
|
])
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_compi_inet_ntop" = "yes"; then
|
|
AC_MSG_CHECKING([if inet_ntop seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_arpa_inet
|
|
$curl_includes_string
|
|
]],[[
|
|
char ipv6res[sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255")];
|
|
char ipv4res[sizeof "255.255.255.255"];
|
|
unsigned char ipv6a[26];
|
|
unsigned char ipv4a[5];
|
|
char *ipv6ptr = 0;
|
|
char *ipv4ptr = 0;
|
|
/* - */
|
|
ipv4res[0] = '\0';
|
|
ipv4a[0] = 0xc0;
|
|
ipv4a[1] = 0xa8;
|
|
ipv4a[2] = 0x64;
|
|
ipv4a[3] = 0x01;
|
|
ipv4a[4] = 0x01;
|
|
/* - */
|
|
ipv4ptr = inet_ntop(AF_INET, ipv4a, ipv4res, sizeof(ipv4res));
|
|
if(!ipv4ptr)
|
|
exit(1); /* fail */
|
|
if(ipv4ptr != ipv4res)
|
|
exit(1); /* fail */
|
|
if(!ipv4ptr[0])
|
|
exit(1); /* fail */
|
|
if(memcmp(ipv4res, "192.168.100.1", 13) != 0)
|
|
exit(1); /* fail */
|
|
/* - */
|
|
ipv6res[0] = '\0';
|
|
memset(ipv6a, 0, sizeof(ipv6a));
|
|
ipv6a[0] = 0xfe;
|
|
ipv6a[1] = 0x80;
|
|
ipv6a[8] = 0x02;
|
|
ipv6a[9] = 0x14;
|
|
ipv6a[10] = 0x4f;
|
|
ipv6a[11] = 0xff;
|
|
ipv6a[12] = 0xfe;
|
|
ipv6a[13] = 0x0b;
|
|
ipv6a[14] = 0x76;
|
|
ipv6a[15] = 0xc8;
|
|
ipv6a[25] = 0x01;
|
|
/* - */
|
|
ipv6ptr = inet_ntop(AF_INET6, ipv6a, ipv6res, sizeof(ipv6res));
|
|
if(!ipv6ptr)
|
|
exit(1); /* fail */
|
|
if(ipv6ptr != ipv6res)
|
|
exit(1); /* fail */
|
|
if(!ipv6ptr[0])
|
|
exit(1); /* fail */
|
|
if(memcmp(ipv6res, "fe80::214:4fff:fe0b:76c8", 24) != 0)
|
|
exit(1); /* fail */
|
|
/* - */
|
|
exit(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_inet_ntop="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_inet_ntop="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_inet_ntop" = "yes" &&
|
|
test "$tst_works_inet_ntop" != "no"; then
|
|
AC_MSG_CHECKING([if inet_ntop usage allowed])
|
|
if test "x$curl_disallow_inet_ntop" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_inet_ntop="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_inet_ntop="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if inet_ntop might be used])
|
|
if test "$tst_links_inet_ntop" = "yes" &&
|
|
test "$tst_proto_inet_ntop" = "yes" &&
|
|
test "$tst_compi_inet_ntop" = "yes" &&
|
|
test "$tst_allow_inet_ntop" = "yes" &&
|
|
test "$tst_works_inet_ntop" != "no"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_INET_NTOP, 1,
|
|
[Define to 1 if you have a IPv6 capable working inet_ntop function.])
|
|
curl_cv_func_inet_ntop="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_inet_ntop="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_INET_PTON
|
|
dnl -------------------------------------------------
|
|
dnl Verify if inet_pton is available, prototyped, can
|
|
dnl be compiled and seems to work. If all of these are
|
|
dnl true, and usage has not been previously disallowed
|
|
dnl with shell variable curl_disallow_inet_pton, then
|
|
dnl HAVE_INET_PTON will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_INET_PTON], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_ARPA_INET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_inet_pton="unknown"
|
|
tst_proto_inet_pton="unknown"
|
|
tst_compi_inet_pton="unknown"
|
|
tst_works_inet_pton="unknown"
|
|
tst_allow_inet_pton="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if inet_pton can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([inet_pton])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_inet_pton="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_inet_pton="no"
|
|
])
|
|
#
|
|
if test "$tst_links_inet_pton" = "yes"; then
|
|
AC_MSG_CHECKING([if inet_pton is prototyped])
|
|
AC_EGREP_CPP([inet_pton],[
|
|
$curl_includes_arpa_inet
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_inet_pton="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_inet_pton="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_inet_pton" = "yes"; then
|
|
AC_MSG_CHECKING([if inet_pton is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_arpa_inet
|
|
]],[[
|
|
if(0 != inet_pton(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_inet_pton="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_inet_pton="no"
|
|
])
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_compi_inet_pton" = "yes"; then
|
|
AC_MSG_CHECKING([if inet_pton seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_arpa_inet
|
|
$curl_includes_string
|
|
]],[[
|
|
unsigned char ipv6a[16+1];
|
|
unsigned char ipv4a[4+1];
|
|
const char *ipv6src = "fe80::214:4fff:fe0b:76c8";
|
|
const char *ipv4src = "192.168.100.1";
|
|
/* - */
|
|
memset(ipv4a, 1, sizeof(ipv4a));
|
|
if(1 != inet_pton(AF_INET, ipv4src, ipv4a))
|
|
exit(1); /* fail */
|
|
/* - */
|
|
if( (ipv4a[0] != 0xc0) ||
|
|
(ipv4a[1] != 0xa8) ||
|
|
(ipv4a[2] != 0x64) ||
|
|
(ipv4a[3] != 0x01) ||
|
|
(ipv4a[4] != 0x01) )
|
|
exit(1); /* fail */
|
|
/* - */
|
|
memset(ipv6a, 1, sizeof(ipv6a));
|
|
if(1 != inet_pton(AF_INET6, ipv6src, ipv6a))
|
|
exit(1); /* fail */
|
|
/* - */
|
|
if( (ipv6a[0] != 0xfe) ||
|
|
(ipv6a[1] != 0x80) ||
|
|
(ipv6a[8] != 0x02) ||
|
|
(ipv6a[9] != 0x14) ||
|
|
(ipv6a[10] != 0x4f) ||
|
|
(ipv6a[11] != 0xff) ||
|
|
(ipv6a[12] != 0xfe) ||
|
|
(ipv6a[13] != 0x0b) ||
|
|
(ipv6a[14] != 0x76) ||
|
|
(ipv6a[15] != 0xc8) ||
|
|
(ipv6a[16] != 0x01) )
|
|
exit(1); /* fail */
|
|
/* - */
|
|
if( (ipv6a[2] != 0x0) ||
|
|
(ipv6a[3] != 0x0) ||
|
|
(ipv6a[4] != 0x0) ||
|
|
(ipv6a[5] != 0x0) ||
|
|
(ipv6a[6] != 0x0) ||
|
|
(ipv6a[7] != 0x0) )
|
|
exit(1); /* fail */
|
|
/* - */
|
|
exit(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_inet_pton="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_inet_pton="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_inet_pton" = "yes" &&
|
|
test "$tst_works_inet_pton" != "no"; then
|
|
AC_MSG_CHECKING([if inet_pton usage allowed])
|
|
if test "x$curl_disallow_inet_pton" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_inet_pton="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_inet_pton="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if inet_pton might be used])
|
|
if test "$tst_links_inet_pton" = "yes" &&
|
|
test "$tst_proto_inet_pton" = "yes" &&
|
|
test "$tst_compi_inet_pton" = "yes" &&
|
|
test "$tst_allow_inet_pton" = "yes" &&
|
|
test "$tst_works_inet_pton" != "no"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_INET_PTON, 1,
|
|
[Define to 1 if you have a IPv6 capable working inet_pton function.])
|
|
curl_cv_func_inet_pton="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_inet_pton="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if ioctl is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_ioctl, then
|
|
dnl HAVE_IOCTL will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTL], [
|
|
AC_REQUIRE([CURL_INCLUDES_STROPTS])dnl
|
|
#
|
|
tst_links_ioctl="unknown"
|
|
tst_proto_ioctl="unknown"
|
|
tst_compi_ioctl="unknown"
|
|
tst_allow_ioctl="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if ioctl can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([ioctl])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_ioctl="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_ioctl="no"
|
|
])
|
|
#
|
|
if test "$tst_links_ioctl" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl is prototyped])
|
|
AC_EGREP_CPP([ioctl],[
|
|
$curl_includes_stropts
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_ioctl="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_ioctl="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_ioctl" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stropts
|
|
]],[[
|
|
if(0 != ioctl(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctl="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctl="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctl" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl usage allowed])
|
|
if test "x$curl_disallow_ioctl" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctl="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctl="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if ioctl might be used])
|
|
if test "$tst_links_ioctl" = "yes" &&
|
|
test "$tst_proto_ioctl" = "yes" &&
|
|
test "$tst_compi_ioctl" = "yes" &&
|
|
test "$tst_allow_ioctl" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTL, 1,
|
|
[Define to 1 if you have the ioctl function.])
|
|
curl_cv_func_ioctl="yes"
|
|
CURL_CHECK_FUNC_IOCTL_FIONBIO
|
|
CURL_CHECK_FUNC_IOCTL_SIOCGIFADDR
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctl="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTL_FIONBIO
|
|
dnl -------------------------------------------------
|
|
dnl Verify if ioctl with the FIONBIO command is
|
|
dnl available, can be compiled, and seems to work. If
|
|
dnl all of these are true, then HAVE_IOCTL_FIONBIO
|
|
dnl will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTL_FIONBIO], [
|
|
#
|
|
tst_compi_ioctl_fionbio="unknown"
|
|
tst_allow_ioctl_fionbio="unknown"
|
|
#
|
|
if test "$curl_cv_func_ioctl" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl FIONBIO is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stropts
|
|
]],[[
|
|
int flags = 0;
|
|
if(0 != ioctl(0, FIONBIO, &flags))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctl_fionbio="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctl_fionbio="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctl_fionbio" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl FIONBIO usage allowed])
|
|
if test "x$curl_disallow_ioctl_fionbio" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctl_fionbio="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctl_fionbio="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if ioctl FIONBIO might be used])
|
|
if test "$tst_compi_ioctl_fionbio" = "yes" &&
|
|
test "$tst_allow_ioctl_fionbio" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTL_FIONBIO, 1,
|
|
[Define to 1 if you have a working ioctl FIONBIO function.])
|
|
curl_cv_func_ioctl_fionbio="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctl_fionbio="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTL_SIOCGIFADDR
|
|
dnl -------------------------------------------------
|
|
dnl Verify if ioctl with the SIOCGIFADDR command is available,
|
|
dnl struct ifreq is defined, they can be compiled, and seem to
|
|
dnl work. If all of these are true, then HAVE_IOCTL_SIOCGIFADDR
|
|
dnl will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTL_SIOCGIFADDR], [
|
|
#
|
|
tst_compi_ioctl_siocgifaddr="unknown"
|
|
tst_allow_ioctl_siocgifaddr="unknown"
|
|
#
|
|
if test "$curl_cv_func_ioctl" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl SIOCGIFADDR is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stropts
|
|
#include <net/if.h>
|
|
]],[[
|
|
struct ifreq ifr;
|
|
if(0 != ioctl(0, SIOCGIFADDR, &ifr))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctl_siocgifaddr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctl_siocgifaddr="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctl_siocgifaddr" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctl SIOCGIFADDR usage allowed])
|
|
if test "x$curl_disallow_ioctl_siocgifaddr" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctl_siocgifaddr="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctl_siocgifaddr="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if ioctl SIOCGIFADDR might be used])
|
|
if test "$tst_compi_ioctl_siocgifaddr" = "yes" &&
|
|
test "$tst_allow_ioctl_siocgifaddr" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTL_SIOCGIFADDR, 1,
|
|
[Define to 1 if you have a working ioctl SIOCGIFADDR function.])
|
|
curl_cv_func_ioctl_siocgifaddr="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctl_siocgifaddr="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTLSOCKET
|
|
dnl -------------------------------------------------
|
|
dnl Verify if ioctlsocket is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_ioctlsocket, then
|
|
dnl HAVE_IOCTLSOCKET will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTLSOCKET], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
#
|
|
tst_links_ioctlsocket="unknown"
|
|
tst_proto_ioctlsocket="unknown"
|
|
tst_compi_ioctlsocket="unknown"
|
|
tst_allow_ioctlsocket="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if ioctlsocket can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
]],[[
|
|
if(0 != ioctlsocket(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_ioctlsocket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_ioctlsocket="no"
|
|
])
|
|
#
|
|
if test "$tst_links_ioctlsocket" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctlsocket is prototyped])
|
|
AC_EGREP_CPP([ioctlsocket],[
|
|
$curl_includes_winsock2
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_ioctlsocket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_ioctlsocket="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_ioctlsocket" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctlsocket is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
]],[[
|
|
if(0 != ioctlsocket(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctlsocket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctlsocket="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctlsocket" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctlsocket usage allowed])
|
|
if test "x$curl_disallow_ioctlsocket" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctlsocket="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctlsocket="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if ioctlsocket might be used])
|
|
if test "$tst_links_ioctlsocket" = "yes" &&
|
|
test "$tst_proto_ioctlsocket" = "yes" &&
|
|
test "$tst_compi_ioctlsocket" = "yes" &&
|
|
test "$tst_allow_ioctlsocket" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTLSOCKET, 1,
|
|
[Define to 1 if you have the ioctlsocket function.])
|
|
curl_cv_func_ioctlsocket="yes"
|
|
CURL_CHECK_FUNC_IOCTLSOCKET_FIONBIO
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctlsocket="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTLSOCKET_FIONBIO
|
|
dnl -------------------------------------------------
|
|
dnl Verify if ioctlsocket with the FIONBIO command is
|
|
dnl available, can be compiled, and seems to work. If
|
|
dnl all of these are true, then HAVE_IOCTLSOCKET_FIONBIO
|
|
dnl will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTLSOCKET_FIONBIO], [
|
|
#
|
|
tst_compi_ioctlsocket_fionbio="unknown"
|
|
tst_allow_ioctlsocket_fionbio="unknown"
|
|
#
|
|
if test "$curl_cv_func_ioctlsocket" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctlsocket FIONBIO is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
]],[[
|
|
unsigned long flags = 0;
|
|
if(0 != ioctlsocket(0, FIONBIO, &flags))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctlsocket_fionbio="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctlsocket_fionbio="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctlsocket_fionbio" = "yes"; then
|
|
AC_MSG_CHECKING([if ioctlsocket FIONBIO usage allowed])
|
|
if test "x$curl_disallow_ioctlsocket_fionbio" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctlsocket_fionbio="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctlsocket_fionbio="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if ioctlsocket FIONBIO might be used])
|
|
if test "$tst_compi_ioctlsocket_fionbio" = "yes" &&
|
|
test "$tst_allow_ioctlsocket_fionbio" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTLSOCKET_FIONBIO, 1,
|
|
[Define to 1 if you have a working ioctlsocket FIONBIO function.])
|
|
curl_cv_func_ioctlsocket_fionbio="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctlsocket_fionbio="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTLSOCKET_CAMEL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if IoctlSocket is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_ioctlsocket_camel,
|
|
dnl then HAVE_IOCTLSOCKET_CAMEL will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTLSOCKET_CAMEL], [
|
|
AC_REQUIRE([CURL_INCLUDES_BSDSOCKET])dnl
|
|
#
|
|
tst_links_ioctlsocket_camel="unknown"
|
|
tst_proto_ioctlsocket_camel="unknown"
|
|
tst_compi_ioctlsocket_camel="unknown"
|
|
tst_allow_ioctlsocket_camel="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if IoctlSocket can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
IoctlSocket(0, 0, 0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_ioctlsocket_camel="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_ioctlsocket_camel="no"
|
|
])
|
|
#
|
|
if test "$tst_links_ioctlsocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if IoctlSocket is prototyped])
|
|
AC_EGREP_CPP([IoctlSocket],[
|
|
$curl_includes_bsdsocket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_ioctlsocket_camel="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_ioctlsocket_camel="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_ioctlsocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if IoctlSocket is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
if(0 != IoctlSocket(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctlsocket_camel="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctlsocket_camel="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctlsocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if IoctlSocket usage allowed])
|
|
if test "x$curl_disallow_ioctlsocket_camel" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctlsocket_camel="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctlsocket_camel="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if IoctlSocket might be used])
|
|
if test "$tst_links_ioctlsocket_camel" = "yes" &&
|
|
test "$tst_proto_ioctlsocket_camel" = "yes" &&
|
|
test "$tst_compi_ioctlsocket_camel" = "yes" &&
|
|
test "$tst_allow_ioctlsocket_camel" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTLSOCKET_CAMEL, 1,
|
|
[Define to 1 if you have the IoctlSocket camel case function.])
|
|
curl_cv_func_ioctlsocket_camel="yes"
|
|
CURL_CHECK_FUNC_IOCTLSOCKET_CAMEL_FIONBIO
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctlsocket_camel="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_IOCTLSOCKET_CAMEL_FIONBIO
|
|
dnl -------------------------------------------------
|
|
dnl Verify if IoctlSocket with FIONBIO command is available,
|
|
dnl can be compiled, and seems to work. If all of these are
|
|
dnl true, then HAVE_IOCTLSOCKET_CAMEL_FIONBIO will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_IOCTLSOCKET_CAMEL_FIONBIO], [
|
|
AC_REQUIRE([CURL_INCLUDES_BSDSOCKET])dnl
|
|
#
|
|
tst_compi_ioctlsocket_camel_fionbio="unknown"
|
|
tst_allow_ioctlsocket_camel_fionbio="unknown"
|
|
#
|
|
if test "$curl_cv_func_ioctlsocket_camel" = "yes"; then
|
|
AC_MSG_CHECKING([if IoctlSocket FIONBIO is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_bsdsocket
|
|
]],[[
|
|
long flags = 0;
|
|
if(0 != IoctlSocket(0, FIONBIO, &flags))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_ioctlsocket_camel_fionbio="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_ioctlsocket_camel_fionbio="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_ioctlsocket_camel_fionbio" = "yes"; then
|
|
AC_MSG_CHECKING([if IoctlSocket FIONBIO usage allowed])
|
|
if test "x$curl_disallow_ioctlsocket_camel_fionbio" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_ioctlsocket_camel_fionbio="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_ioctlsocket_camel_fionbio="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if IoctlSocket FIONBIO might be used])
|
|
if test "$tst_compi_ioctlsocket_camel_fionbio" = "yes" &&
|
|
test "$tst_allow_ioctlsocket_camel_fionbio" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_IOCTLSOCKET_CAMEL_FIONBIO, 1,
|
|
[Define to 1 if you have a working IoctlSocket camel case FIONBIO function.])
|
|
curl_cv_func_ioctlsocket_camel_fionbio="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_ioctlsocket_camel_fionbio="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_MEMRCHR
|
|
dnl -------------------------------------------------
|
|
dnl Verify if memrchr is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_memrchr, then
|
|
dnl HAVE_MEMRCHR will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_MEMRCHR], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_memrchr="unknown"
|
|
tst_macro_memrchr="unknown"
|
|
tst_proto_memrchr="unknown"
|
|
tst_compi_memrchr="unknown"
|
|
tst_allow_memrchr="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if memrchr can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([memrchr])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_memrchr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_memrchr="no"
|
|
])
|
|
#
|
|
if test "$tst_links_memrchr" = "no"; then
|
|
AC_MSG_CHECKING([if memrchr seems a macro])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != memrchr(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_macro_memrchr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_macro_memrchr="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_links_memrchr" = "yes"; then
|
|
AC_MSG_CHECKING([if memrchr is prototyped])
|
|
AC_EGREP_CPP([memrchr],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_memrchr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_memrchr="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_memrchr" = "yes" ||
|
|
test "$tst_macro_memrchr" = "yes"; then
|
|
AC_MSG_CHECKING([if memrchr is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != memrchr(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_memrchr="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_memrchr="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_memrchr" = "yes"; then
|
|
AC_MSG_CHECKING([if memrchr usage allowed])
|
|
if test "x$curl_disallow_memrchr" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_memrchr="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_memrchr="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if memrchr might be used])
|
|
if (test "$tst_proto_memrchr" = "yes" ||
|
|
test "$tst_macro_memrchr" = "yes") &&
|
|
test "$tst_compi_memrchr" = "yes" &&
|
|
test "$tst_allow_memrchr" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_MEMRCHR, 1,
|
|
[Define to 1 if you have the memrchr function or macro.])
|
|
curl_cv_func_memrchr="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_memrchr="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_POLL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if poll is available, prototyped, can
|
|
dnl be compiled and seems to work.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_POLL], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_POLL])dnl
|
|
#
|
|
tst_links_poll="unknown"
|
|
tst_proto_poll="unknown"
|
|
tst_compi_poll="unknown"
|
|
tst_works_poll="unknown"
|
|
tst_allow_poll="unknown"
|
|
#
|
|
case $host_os in
|
|
darwin*|interix*)
|
|
dnl poll() does not work on these platforms
|
|
dnl Interix: "does provide poll(), but the implementing developer must
|
|
dnl have been in a bad mood, because poll() only works on the /proc
|
|
dnl filesystem here"
|
|
dnl macOS: poll() first didn't exist, then was broken until fixed in 10.9
|
|
dnl only to break again in 10.12.
|
|
curl_disallow_poll="yes"
|
|
tst_compi_poll="no"
|
|
;;
|
|
esac
|
|
#
|
|
AC_MSG_CHECKING([if poll can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_poll
|
|
]],[[
|
|
if(0 != poll(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_poll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_poll="no"
|
|
])
|
|
#
|
|
if test "$tst_links_poll" = "yes"; then
|
|
AC_MSG_CHECKING([if poll is prototyped])
|
|
AC_EGREP_CPP([poll],[
|
|
$curl_includes_poll
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_poll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_poll="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_poll" = "yes"; then
|
|
AC_MSG_CHECKING([if poll is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_poll
|
|
]],[[
|
|
if(0 != poll(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_poll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_poll="no"
|
|
])
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_compi_poll" = "yes"; then
|
|
AC_MSG_CHECKING([if poll seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_poll
|
|
$curl_includes_time
|
|
]],[[
|
|
/* detect the original poll() breakage */
|
|
if(0 != poll(0, 0, 10))
|
|
exit(1); /* fail */
|
|
else {
|
|
/* detect the 10.12 poll() breakage */
|
|
struct timeval before, after;
|
|
int rc;
|
|
size_t us;
|
|
|
|
gettimeofday(&before, NULL);
|
|
rc = poll(NULL, 0, 500);
|
|
gettimeofday(&after, NULL);
|
|
|
|
us = (after.tv_sec - before.tv_sec) * 1000000 +
|
|
(after.tv_usec - before.tv_usec);
|
|
|
|
if(us < 400000)
|
|
exit(1);
|
|
}
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_poll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_poll="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_poll" = "yes" &&
|
|
test "$tst_works_poll" != "no"; then
|
|
AC_MSG_CHECKING([if poll usage allowed])
|
|
if test "x$curl_disallow_poll" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_poll="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_poll="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if poll might be used])
|
|
if test "$tst_links_poll" = "yes" &&
|
|
test "$tst_proto_poll" = "yes" &&
|
|
test "$tst_compi_poll" = "yes" &&
|
|
test "$tst_allow_poll" = "yes" &&
|
|
test "$tst_works_poll" != "no"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_POLL_FINE, 1,
|
|
[If you have a fine poll])
|
|
curl_cv_func_poll="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_poll="no"
|
|
fi
|
|
])
|
|
|
|
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_SIGACTION
|
|
dnl -------------------------------------------------
|
|
dnl Verify if sigaction is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_sigaction, then
|
|
dnl HAVE_SIGACTION will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_SIGACTION], [
|
|
AC_REQUIRE([CURL_INCLUDES_SIGNAL])dnl
|
|
#
|
|
tst_links_sigaction="unknown"
|
|
tst_proto_sigaction="unknown"
|
|
tst_compi_sigaction="unknown"
|
|
tst_allow_sigaction="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if sigaction can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([sigaction])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_sigaction="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_sigaction="no"
|
|
])
|
|
#
|
|
if test "$tst_links_sigaction" = "yes"; then
|
|
AC_MSG_CHECKING([if sigaction is prototyped])
|
|
AC_EGREP_CPP([sigaction],[
|
|
$curl_includes_signal
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_sigaction="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_sigaction="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_sigaction" = "yes"; then
|
|
AC_MSG_CHECKING([if sigaction is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_signal
|
|
]],[[
|
|
if(0 != sigaction(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_sigaction="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_sigaction="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_sigaction" = "yes"; then
|
|
AC_MSG_CHECKING([if sigaction usage allowed])
|
|
if test "x$curl_disallow_sigaction" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_sigaction="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_sigaction="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if sigaction might be used])
|
|
if test "$tst_links_sigaction" = "yes" &&
|
|
test "$tst_proto_sigaction" = "yes" &&
|
|
test "$tst_compi_sigaction" = "yes" &&
|
|
test "$tst_allow_sigaction" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_SIGACTION, 1,
|
|
[Define to 1 if you have the sigaction function.])
|
|
curl_cv_func_sigaction="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_sigaction="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_SIGINTERRUPT
|
|
dnl -------------------------------------------------
|
|
dnl Verify if siginterrupt is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_siginterrupt, then
|
|
dnl HAVE_SIGINTERRUPT will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_SIGINTERRUPT], [
|
|
AC_REQUIRE([CURL_INCLUDES_SIGNAL])dnl
|
|
#
|
|
tst_links_siginterrupt="unknown"
|
|
tst_proto_siginterrupt="unknown"
|
|
tst_compi_siginterrupt="unknown"
|
|
tst_allow_siginterrupt="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if siginterrupt can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([siginterrupt])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_siginterrupt="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_siginterrupt="no"
|
|
])
|
|
#
|
|
if test "$tst_links_siginterrupt" = "yes"; then
|
|
AC_MSG_CHECKING([if siginterrupt is prototyped])
|
|
AC_EGREP_CPP([siginterrupt],[
|
|
$curl_includes_signal
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_siginterrupt="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_siginterrupt="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_siginterrupt" = "yes"; then
|
|
AC_MSG_CHECKING([if siginterrupt is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_signal
|
|
]],[[
|
|
if(0 != siginterrupt(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_siginterrupt="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_siginterrupt="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_siginterrupt" = "yes"; then
|
|
AC_MSG_CHECKING([if siginterrupt usage allowed])
|
|
if test "x$curl_disallow_siginterrupt" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_siginterrupt="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_siginterrupt="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if siginterrupt might be used])
|
|
if test "$tst_links_siginterrupt" = "yes" &&
|
|
test "$tst_proto_siginterrupt" = "yes" &&
|
|
test "$tst_compi_siginterrupt" = "yes" &&
|
|
test "$tst_allow_siginterrupt" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_SIGINTERRUPT, 1,
|
|
[Define to 1 if you have the siginterrupt function.])
|
|
curl_cv_func_siginterrupt="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_siginterrupt="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_SIGNAL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if signal is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_signal, then
|
|
dnl HAVE_SIGNAL will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_SIGNAL], [
|
|
AC_REQUIRE([CURL_INCLUDES_SIGNAL])dnl
|
|
#
|
|
tst_links_signal="unknown"
|
|
tst_proto_signal="unknown"
|
|
tst_compi_signal="unknown"
|
|
tst_allow_signal="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if signal can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([signal])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_signal="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_signal="no"
|
|
])
|
|
#
|
|
if test "$tst_links_signal" = "yes"; then
|
|
AC_MSG_CHECKING([if signal is prototyped])
|
|
AC_EGREP_CPP([signal],[
|
|
$curl_includes_signal
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_signal="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_signal="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_signal" = "yes"; then
|
|
AC_MSG_CHECKING([if signal is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_signal
|
|
]],[[
|
|
if(0 != signal(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_signal="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_signal="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_signal" = "yes"; then
|
|
AC_MSG_CHECKING([if signal usage allowed])
|
|
if test "x$curl_disallow_signal" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_signal="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_signal="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if signal might be used])
|
|
if test "$tst_links_signal" = "yes" &&
|
|
test "$tst_proto_signal" = "yes" &&
|
|
test "$tst_compi_signal" = "yes" &&
|
|
test "$tst_allow_signal" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_SIGNAL, 1,
|
|
[Define to 1 if you have the signal function.])
|
|
curl_cv_func_signal="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_signal="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_SIGSETJMP
|
|
dnl -------------------------------------------------
|
|
dnl Verify if sigsetjmp is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_sigsetjmp, then
|
|
dnl HAVE_SIGSETJMP will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_SIGSETJMP], [
|
|
AC_REQUIRE([CURL_INCLUDES_SETJMP])dnl
|
|
#
|
|
tst_links_sigsetjmp="unknown"
|
|
tst_macro_sigsetjmp="unknown"
|
|
tst_proto_sigsetjmp="unknown"
|
|
tst_compi_sigsetjmp="unknown"
|
|
tst_allow_sigsetjmp="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if sigsetjmp can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([sigsetjmp])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_sigsetjmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_sigsetjmp="no"
|
|
])
|
|
#
|
|
if test "$tst_links_sigsetjmp" = "no"; then
|
|
AC_MSG_CHECKING([if sigsetjmp seems a macro])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_setjmp
|
|
]],[[
|
|
sigjmp_buf env;
|
|
if(0 != sigsetjmp(env, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_macro_sigsetjmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_macro_sigsetjmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_links_sigsetjmp" = "yes"; then
|
|
AC_MSG_CHECKING([if sigsetjmp is prototyped])
|
|
AC_EGREP_CPP([sigsetjmp],[
|
|
$curl_includes_setjmp
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_sigsetjmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_sigsetjmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_sigsetjmp" = "yes" ||
|
|
test "$tst_macro_sigsetjmp" = "yes"; then
|
|
AC_MSG_CHECKING([if sigsetjmp is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_setjmp
|
|
]],[[
|
|
sigjmp_buf env;
|
|
if(0 != sigsetjmp(env, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_sigsetjmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_sigsetjmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_sigsetjmp" = "yes"; then
|
|
AC_MSG_CHECKING([if sigsetjmp usage allowed])
|
|
if test "x$curl_disallow_sigsetjmp" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_sigsetjmp="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_sigsetjmp="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if sigsetjmp might be used])
|
|
if (test "$tst_proto_sigsetjmp" = "yes" ||
|
|
test "$tst_macro_sigsetjmp" = "yes") &&
|
|
test "$tst_compi_sigsetjmp" = "yes" &&
|
|
test "$tst_allow_sigsetjmp" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_SIGSETJMP, 1,
|
|
[Define to 1 if you have the sigsetjmp function or macro.])
|
|
curl_cv_func_sigsetjmp="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_sigsetjmp="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_SOCKET
|
|
dnl -------------------------------------------------
|
|
dnl Verify if socket is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_socket, then
|
|
dnl HAVE_SOCKET will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_SOCKET], [
|
|
AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_SOCKET])dnl
|
|
#
|
|
tst_links_socket="unknown"
|
|
tst_proto_socket="unknown"
|
|
tst_compi_socket="unknown"
|
|
tst_allow_socket="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if socket can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
$curl_includes_socket
|
|
]],[[
|
|
if(0 != socket(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_socket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_socket="no"
|
|
])
|
|
#
|
|
if test "$tst_links_socket" = "yes"; then
|
|
AC_MSG_CHECKING([if socket is prototyped])
|
|
AC_EGREP_CPP([socket],[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
$curl_includes_socket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_socket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_socket="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_socket" = "yes"; then
|
|
AC_MSG_CHECKING([if socket is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_winsock2
|
|
$curl_includes_bsdsocket
|
|
$curl_includes_sys_socket
|
|
$curl_includes_socket
|
|
]],[[
|
|
if(0 != socket(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_socket="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_socket="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_socket" = "yes"; then
|
|
AC_MSG_CHECKING([if socket usage allowed])
|
|
if test "x$curl_disallow_socket" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_socket="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_socket="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if socket might be used])
|
|
if test "$tst_links_socket" = "yes" &&
|
|
test "$tst_proto_socket" = "yes" &&
|
|
test "$tst_compi_socket" = "yes" &&
|
|
test "$tst_allow_socket" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_SOCKET, 1,
|
|
[Define to 1 if you have the socket function.])
|
|
curl_cv_func_socket="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_socket="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_SOCKETPAIR
|
|
dnl -------------------------------------------------
|
|
dnl Verify if socketpair is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_socketpair, then
|
|
dnl HAVE_SOCKETPAIR will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_SOCKETPAIR], [
|
|
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_SOCKET])dnl
|
|
#
|
|
tst_links_socketpair="unknown"
|
|
tst_proto_socketpair="unknown"
|
|
tst_compi_socketpair="unknown"
|
|
tst_allow_socketpair="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if socketpair can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([socketpair])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_socketpair="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_socketpair="no"
|
|
])
|
|
#
|
|
if test "$tst_links_socketpair" = "yes"; then
|
|
AC_MSG_CHECKING([if socketpair is prototyped])
|
|
AC_EGREP_CPP([socketpair],[
|
|
$curl_includes_sys_socket
|
|
$curl_includes_socket
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_socketpair="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_socketpair="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_socketpair" = "yes"; then
|
|
AC_MSG_CHECKING([if socketpair is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_sys_socket
|
|
$curl_includes_socket
|
|
]],[[
|
|
int sv[2];
|
|
if(0 != socketpair(0, 0, 0, sv))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_socketpair="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_socketpair="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_socketpair" = "yes"; then
|
|
AC_MSG_CHECKING([if socketpair usage allowed])
|
|
if test "x$curl_disallow_socketpair" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_socketpair="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_socketpair="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if socketpair might be used])
|
|
if test "$tst_links_socketpair" = "yes" &&
|
|
test "$tst_proto_socketpair" = "yes" &&
|
|
test "$tst_compi_socketpair" = "yes" &&
|
|
test "$tst_allow_socketpair" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_SOCKETPAIR, 1,
|
|
[Define to 1 if you have the socketpair function.])
|
|
curl_cv_func_socketpair="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_socketpair="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_STRCASECMP
|
|
dnl -------------------------------------------------
|
|
dnl Verify if strcasecmp is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_strcasecmp, then
|
|
dnl HAVE_STRCASECMP will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRCASECMP], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_strcasecmp="unknown"
|
|
tst_proto_strcasecmp="unknown"
|
|
tst_compi_strcasecmp="unknown"
|
|
tst_allow_strcasecmp="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if strcasecmp can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([strcasecmp])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_strcasecmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_strcasecmp="no"
|
|
])
|
|
#
|
|
if test "$tst_links_strcasecmp" = "yes"; then
|
|
AC_MSG_CHECKING([if strcasecmp is prototyped])
|
|
AC_EGREP_CPP([strcasecmp],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_strcasecmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_strcasecmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_strcasecmp" = "yes"; then
|
|
AC_MSG_CHECKING([if strcasecmp is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != strcasecmp(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_strcasecmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_strcasecmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strcasecmp" = "yes"; then
|
|
AC_MSG_CHECKING([if strcasecmp usage allowed])
|
|
if test "x$curl_disallow_strcasecmp" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_strcasecmp="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_strcasecmp="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if strcasecmp might be used])
|
|
if test "$tst_links_strcasecmp" = "yes" &&
|
|
test "$tst_proto_strcasecmp" = "yes" &&
|
|
test "$tst_compi_strcasecmp" = "yes" &&
|
|
test "$tst_allow_strcasecmp" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_STRCASECMP, 1,
|
|
[Define to 1 if you have the strcasecmp function.])
|
|
curl_cv_func_strcasecmp="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_strcasecmp="no"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_CHECK_FUNC_STRCMPI
|
|
dnl -------------------------------------------------
|
|
dnl Verify if strcmpi is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_strcmpi, then
|
|
dnl HAVE_STRCMPI will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRCMPI], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_strcmpi="unknown"
|
|
tst_proto_strcmpi="unknown"
|
|
tst_compi_strcmpi="unknown"
|
|
tst_allow_strcmpi="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if strcmpi can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([strcmpi])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_strcmpi="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_strcmpi="no"
|
|
])
|
|
#
|
|
if test "$tst_links_strcmpi" = "yes"; then
|
|
AC_MSG_CHECKING([if strcmpi is prototyped])
|
|
AC_EGREP_CPP([strcmpi],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_strcmpi="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_strcmpi="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_strcmpi" = "yes"; then
|
|
AC_MSG_CHECKING([if strcmpi is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != strcmpi(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_strcmpi="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_strcmpi="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strcmpi" = "yes"; then
|
|
AC_MSG_CHECKING([if strcmpi usage allowed])
|
|
if test "x$curl_disallow_strcmpi" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_strcmpi="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_strcmpi="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if strcmpi might be used])
|
|
if test "$tst_links_strcmpi" = "yes" &&
|
|
test "$tst_proto_strcmpi" = "yes" &&
|
|
test "$tst_compi_strcmpi" = "yes" &&
|
|
test "$tst_allow_strcmpi" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_STRCMPI, 1,
|
|
[Define to 1 if you have the strcmpi function.])
|
|
curl_cv_func_strcmpi="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_strcmpi="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_STRDUP
|
|
dnl -------------------------------------------------
|
|
dnl Verify if strdup is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_strdup, then
|
|
dnl HAVE_STRDUP will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRDUP], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_strdup="unknown"
|
|
tst_proto_strdup="unknown"
|
|
tst_compi_strdup="unknown"
|
|
tst_allow_strdup="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if strdup can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([strdup])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_strdup="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_strdup="no"
|
|
])
|
|
#
|
|
if test "$tst_links_strdup" = "yes"; then
|
|
AC_MSG_CHECKING([if strdup is prototyped])
|
|
AC_EGREP_CPP([strdup],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_strdup="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_strdup="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_strdup" = "yes"; then
|
|
AC_MSG_CHECKING([if strdup is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != strdup(0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_strdup="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_strdup="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strdup" = "yes"; then
|
|
AC_MSG_CHECKING([if strdup usage allowed])
|
|
if test "x$curl_disallow_strdup" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_strdup="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_strdup="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if strdup might be used])
|
|
if test "$tst_links_strdup" = "yes" &&
|
|
test "$tst_proto_strdup" = "yes" &&
|
|
test "$tst_compi_strdup" = "yes" &&
|
|
test "$tst_allow_strdup" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_STRDUP, 1,
|
|
[Define to 1 if you have the strdup function.])
|
|
curl_cv_func_strdup="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_strdup="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_STRERROR_R
|
|
dnl -------------------------------------------------
|
|
dnl Verify if strerror_r is available, prototyped, can be compiled and
|
|
dnl seems to work. If all of these are true, and usage has not been
|
|
dnl previously disallowed with shell variable curl_disallow_strerror_r,
|
|
dnl then HAVE_STRERROR_R will be defined, as well as one of
|
|
dnl HAVE_GLIBC_STRERROR_R or HAVE_POSIX_STRERROR_R.
|
|
dnl
|
|
dnl glibc-style strerror_r:
|
|
dnl
|
|
dnl char *strerror_r(int errnum, char *workbuf, size_t bufsize);
|
|
dnl
|
|
dnl glibc-style strerror_r returns a pointer to the error string,
|
|
dnl and might use the provided workbuf as a scratch area if needed. A
|
|
dnl quick test on a few systems shows that it's usually not used at all.
|
|
dnl
|
|
dnl POSIX-style strerror_r:
|
|
dnl
|
|
dnl int strerror_r(int errnum, char *resultbuf, size_t bufsize);
|
|
dnl
|
|
dnl POSIX-style strerror_r returns 0 upon successful completion and the
|
|
dnl error string in the provided resultbuf.
|
|
dnl
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRERROR_R], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_strerror_r="unknown"
|
|
tst_proto_strerror_r="unknown"
|
|
tst_compi_strerror_r="unknown"
|
|
tst_glibc_strerror_r="unknown"
|
|
tst_posix_strerror_r="unknown"
|
|
tst_allow_strerror_r="unknown"
|
|
tst_works_glibc_strerror_r="unknown"
|
|
tst_works_posix_strerror_r="unknown"
|
|
tst_glibc_strerror_r_type_arg3="unknown"
|
|
tst_posix_strerror_r_type_arg3="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if strerror_r can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([strerror_r])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_strerror_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_strerror_r="no"
|
|
])
|
|
#
|
|
if test "$tst_links_strerror_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strerror_r is prototyped])
|
|
AC_EGREP_CPP([strerror_r],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_strerror_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_strerror_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_strerror_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strerror_r is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != strerror_r(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_strerror_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_strerror_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strerror_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strerror_r is glibc like])
|
|
tst_glibc_strerror_r_type_arg3="unknown"
|
|
for arg3 in 'size_t' 'int' 'unsigned int'; do
|
|
if test "$tst_glibc_strerror_r_type_arg3" = "unknown"; then
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
char *strerror_r(int errnum, char *workbuf, $arg3 bufsize);
|
|
]],[[
|
|
if(0 != strerror_r(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
tst_glibc_strerror_r_type_arg3="$arg3"
|
|
])
|
|
fi
|
|
done
|
|
case "$tst_glibc_strerror_r_type_arg3" in
|
|
unknown)
|
|
AC_MSG_RESULT([no])
|
|
tst_glibc_strerror_r="no"
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT([yes])
|
|
tst_glibc_strerror_r="yes"
|
|
;;
|
|
esac
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_glibc_strerror_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strerror_r seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_string
|
|
# include <errno.h>
|
|
]],[[
|
|
char buffer[1024];
|
|
char *string = 0;
|
|
buffer[0] = '\0';
|
|
string = strerror_r(EACCES, buffer, sizeof(buffer));
|
|
if(!string)
|
|
exit(1); /* fail */
|
|
if(!string[0])
|
|
exit(1); /* fail */
|
|
else
|
|
exit(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_glibc_strerror_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_glibc_strerror_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strerror_r" = "yes" &&
|
|
test "$tst_works_glibc_strerror_r" != "yes"; then
|
|
AC_MSG_CHECKING([if strerror_r is POSIX like])
|
|
tst_posix_strerror_r_type_arg3="unknown"
|
|
for arg3 in 'size_t' 'int' 'unsigned int'; do
|
|
if test "$tst_posix_strerror_r_type_arg3" = "unknown"; then
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
int strerror_r(int errnum, char *resultbuf, $arg3 bufsize);
|
|
]],[[
|
|
if(0 != strerror_r(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
tst_posix_strerror_r_type_arg3="$arg3"
|
|
])
|
|
fi
|
|
done
|
|
case "$tst_posix_strerror_r_type_arg3" in
|
|
unknown)
|
|
AC_MSG_RESULT([no])
|
|
tst_posix_strerror_r="no"
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT([yes])
|
|
tst_posix_strerror_r="yes"
|
|
;;
|
|
esac
|
|
fi
|
|
#
|
|
dnl only do runtime verification when not cross-compiling
|
|
if test "x$cross_compiling" != "xyes" &&
|
|
test "$tst_posix_strerror_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strerror_r seems to work])
|
|
CURL_RUN_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
$curl_includes_string
|
|
# include <errno.h>
|
|
]],[[
|
|
char buffer[1024];
|
|
int error = 1;
|
|
buffer[0] = '\0';
|
|
error = strerror_r(EACCES, buffer, sizeof(buffer));
|
|
if(error)
|
|
exit(1); /* fail */
|
|
if(buffer[0] == '\0')
|
|
exit(1); /* fail */
|
|
else
|
|
exit(0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_works_posix_strerror_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_works_posix_strerror_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_works_glibc_strerror_r" = "yes"; then
|
|
tst_posix_strerror_r="no"
|
|
fi
|
|
if test "$tst_works_posix_strerror_r" = "yes"; then
|
|
tst_glibc_strerror_r="no"
|
|
fi
|
|
if test "$tst_glibc_strerror_r" = "yes" &&
|
|
test "$tst_works_glibc_strerror_r" != "no" &&
|
|
test "$tst_posix_strerror_r" != "yes"; then
|
|
tst_allow_strerror_r="check"
|
|
fi
|
|
if test "$tst_posix_strerror_r" = "yes" &&
|
|
test "$tst_works_posix_strerror_r" != "no" &&
|
|
test "$tst_glibc_strerror_r" != "yes"; then
|
|
tst_allow_strerror_r="check"
|
|
fi
|
|
if test "$tst_allow_strerror_r" = "check"; then
|
|
AC_MSG_CHECKING([if strerror_r usage allowed])
|
|
if test "x$curl_disallow_strerror_r" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_strerror_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_strerror_r="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if strerror_r might be used])
|
|
if test "$tst_links_strerror_r" = "yes" &&
|
|
test "$tst_proto_strerror_r" = "yes" &&
|
|
test "$tst_compi_strerror_r" = "yes" &&
|
|
test "$tst_allow_strerror_r" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
if test "$tst_glibc_strerror_r" = "yes"; then
|
|
AC_DEFINE_UNQUOTED(HAVE_STRERROR_R, 1,
|
|
[Define to 1 if you have the strerror_r function.])
|
|
AC_DEFINE_UNQUOTED(HAVE_GLIBC_STRERROR_R, 1,
|
|
[Define to 1 if you have a working glibc-style strerror_r function.])
|
|
fi
|
|
if test "$tst_posix_strerror_r" = "yes"; then
|
|
AC_DEFINE_UNQUOTED(HAVE_STRERROR_R, 1,
|
|
[Define to 1 if you have the strerror_r function.])
|
|
AC_DEFINE_UNQUOTED(HAVE_POSIX_STRERROR_R, 1,
|
|
[Define to 1 if you have a working POSIX-style strerror_r function.])
|
|
fi
|
|
curl_cv_func_strerror_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_strerror_r="no"
|
|
fi
|
|
#
|
|
if test "$tst_compi_strerror_r" = "yes" &&
|
|
test "$tst_allow_strerror_r" = "unknown"; then
|
|
AC_MSG_WARN([cannot determine strerror_r() style: edit lib/curl_config.h manually.])
|
|
fi
|
|
#
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_STRICMP
|
|
dnl -------------------------------------------------
|
|
dnl Verify if stricmp is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_stricmp, then
|
|
dnl HAVE_STRICMP will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRICMP], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_stricmp="unknown"
|
|
tst_proto_stricmp="unknown"
|
|
tst_compi_stricmp="unknown"
|
|
tst_allow_stricmp="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if stricmp can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([stricmp])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_stricmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_stricmp="no"
|
|
])
|
|
#
|
|
if test "$tst_links_stricmp" = "yes"; then
|
|
AC_MSG_CHECKING([if stricmp is prototyped])
|
|
AC_EGREP_CPP([stricmp],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_stricmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_stricmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_stricmp" = "yes"; then
|
|
AC_MSG_CHECKING([if stricmp is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != stricmp(0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_stricmp="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_stricmp="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_stricmp" = "yes"; then
|
|
AC_MSG_CHECKING([if stricmp usage allowed])
|
|
if test "x$curl_disallow_stricmp" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_stricmp="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_stricmp="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if stricmp might be used])
|
|
if test "$tst_links_stricmp" = "yes" &&
|
|
test "$tst_proto_stricmp" = "yes" &&
|
|
test "$tst_compi_stricmp" = "yes" &&
|
|
test "$tst_allow_stricmp" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_STRICMP, 1,
|
|
[Define to 1 if you have the stricmp function.])
|
|
curl_cv_func_stricmp="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_stricmp="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_STRTOK_R
|
|
dnl -------------------------------------------------
|
|
dnl Verify if strtok_r is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_strtok_r, then
|
|
dnl HAVE_STRTOK_R will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRTOK_R], [
|
|
AC_REQUIRE([CURL_INCLUDES_STRING])dnl
|
|
#
|
|
tst_links_strtok_r="unknown"
|
|
tst_proto_strtok_r="unknown"
|
|
tst_compi_strtok_r="unknown"
|
|
tst_allow_strtok_r="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if strtok_r can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([strtok_r])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_strtok_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_strtok_r="no"
|
|
])
|
|
#
|
|
if test "$tst_links_strtok_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strtok_r is prototyped])
|
|
AC_EGREP_CPP([strtok_r],[
|
|
$curl_includes_string
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_strtok_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_strtok_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_strtok_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strtok_r is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_string
|
|
]],[[
|
|
if(0 != strtok_r(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_strtok_r="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_strtok_r="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strtok_r" = "yes"; then
|
|
AC_MSG_CHECKING([if strtok_r usage allowed])
|
|
if test "x$curl_disallow_strtok_r" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_strtok_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_strtok_r="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if strtok_r might be used])
|
|
if test "$tst_links_strtok_r" = "yes" &&
|
|
test "$tst_proto_strtok_r" = "yes" &&
|
|
test "$tst_compi_strtok_r" = "yes" &&
|
|
test "$tst_allow_strtok_r" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_STRTOK_R, 1,
|
|
[Define to 1 if you have the strtok_r function.])
|
|
curl_cv_func_strtok_r="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_strtok_r="no"
|
|
fi
|
|
])
|
|
|
|
|
|
dnl CURL_CHECK_FUNC_STRTOLL
|
|
dnl -------------------------------------------------
|
|
dnl Verify if strtoll is available, prototyped, and
|
|
dnl can be compiled. If all of these are true, and
|
|
dnl usage has not been previously disallowed with
|
|
dnl shell variable curl_disallow_strtoll, then
|
|
dnl HAVE_STRTOLL will be defined.
|
|
|
|
AC_DEFUN([CURL_CHECK_FUNC_STRTOLL], [
|
|
AC_REQUIRE([CURL_INCLUDES_STDLIB])dnl
|
|
#
|
|
tst_links_strtoll="unknown"
|
|
tst_proto_strtoll="unknown"
|
|
tst_compi_strtoll="unknown"
|
|
tst_allow_strtoll="unknown"
|
|
#
|
|
AC_MSG_CHECKING([if strtoll can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([strtoll])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_strtoll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_strtoll="no"
|
|
])
|
|
#
|
|
if test "$tst_links_strtoll" = "yes"; then
|
|
AC_MSG_CHECKING([if strtoll is prototyped])
|
|
AC_EGREP_CPP([strtoll],[
|
|
$curl_includes_stdlib
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_proto_strtoll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_proto_strtoll="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_proto_strtoll" = "yes"; then
|
|
AC_MSG_CHECKING([if strtoll is compilable])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_stdlib
|
|
]],[[
|
|
if(0 != strtoll(0, 0, 0))
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_compi_strtoll="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_compi_strtoll="no"
|
|
])
|
|
fi
|
|
#
|
|
if test "$tst_compi_strtoll" = "yes"; then
|
|
AC_MSG_CHECKING([if strtoll usage allowed])
|
|
if test "x$curl_disallow_strtoll" != "xyes"; then
|
|
AC_MSG_RESULT([yes])
|
|
tst_allow_strtoll="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
tst_allow_strtoll="no"
|
|
fi
|
|
fi
|
|
#
|
|
AC_MSG_CHECKING([if strtoll might be used])
|
|
if test "$tst_links_strtoll" = "yes" &&
|
|
test "$tst_proto_strtoll" = "yes" &&
|
|
test "$tst_compi_strtoll" = "yes" &&
|
|
test "$tst_allow_strtoll" = "yes"; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_STRTOLL, 1,
|
|
[Define to 1 if you have the strtoll function.])
|
|
curl_cv_func_strtoll="yes"
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
curl_cv_func_strtoll="no"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_RUN_IFELSE
|
|
dnl -------------------------------------------------
|
|
dnl Wrapper macro to use instead of AC_RUN_IFELSE. It
|
|
dnl sets LD_LIBRARY_PATH locally for this run only, from the
|
|
dnl CURL_LIBRARY_PATH variable. It keeps the LD_LIBRARY_PATH
|
|
dnl changes contained within this macro.
|
|
|
|
AC_DEFUN([CURL_RUN_IFELSE], [
|
|
case $host_os in
|
|
darwin*)
|
|
AC_RUN_IFELSE([AC_LANG_SOURCE([$1])], $2, $3, $4)
|
|
;;
|
|
*)
|
|
oldcc=$CC
|
|
old=$LD_LIBRARY_PATH
|
|
CC="sh ./run-compiler"
|
|
LD_LIBRARY_PATH=$CURL_LIBRARY_PATH:$old
|
|
export LD_LIBRARY_PATH
|
|
AC_RUN_IFELSE([AC_LANG_SOURCE([$1])], $2, $3, $4)
|
|
LD_LIBRARY_PATH=$old # restore
|
|
CC=$oldcc
|
|
;;
|
|
esac
|
|
])
|
|
|
|
dnl CURL_COVERAGE
|
|
dnl --------------------------------------------------
|
|
dnl Switch on options and libs to build with gcc's code coverage.
|
|
dnl
|
|
|
|
AC_DEFUN([CURL_COVERAGE],[
|
|
AC_REQUIRE([AC_PROG_SED])
|
|
AC_REQUIRE([AC_ARG_ENABLE])
|
|
AC_MSG_CHECKING([for code coverage support])
|
|
coverage="no"
|
|
curl_coverage_msg="disabled"
|
|
|
|
dnl check if enabled by argument
|
|
AC_ARG_ENABLE(code-coverage,
|
|
AS_HELP_STRING([--enable-code-coverage], [Provide code coverage]),
|
|
coverage="$enableval")
|
|
|
|
dnl if not gcc switch off again
|
|
AS_IF([ test "$GCC" != "yes" ], coverage="no" )
|
|
AC_MSG_RESULT($coverage)
|
|
|
|
if test "x$coverage" = "xyes"; then
|
|
curl_coverage_msg="enabled"
|
|
|
|
AC_CHECK_TOOL([GCOV], [gcov], [gcov])
|
|
if test -z "$GCOV"; then
|
|
AC_MSG_ERROR([needs gcov for code coverage])
|
|
fi
|
|
AC_CHECK_PROG([LCOV], [lcov], [lcov])
|
|
if test -z "$LCOV"; then
|
|
AC_MSG_ERROR([needs lcov for code coverage])
|
|
fi
|
|
|
|
CPPFLAGS="$CPPFLAGS -DNDEBUG"
|
|
CFLAGS="$CFLAGS -O0 -g -fprofile-arcs -ftest-coverage"
|
|
LIBS="$LIBS -lgcov"
|
|
fi
|
|
])
|
|
|
|
dnl CURL_ATOMIC
|
|
dnl -------------------------------------------------------------
|
|
dnl Check if _Atomic works. But only check if stdatomic.h exists.
|
|
dnl
|
|
AC_DEFUN([CURL_ATOMIC],[
|
|
AC_CHECK_HEADERS(stdatomic.h, [
|
|
AC_MSG_CHECKING([if _Atomic is available])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
$curl_includes_unistd
|
|
]],[[
|
|
_Atomic int i = 0;
|
|
i = 4; // Force an atomic-write operation.
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_ATOMIC, 1,
|
|
[Define to 1 if you have _Atomic support.])
|
|
tst_atomic="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_atomic="no"
|
|
])
|
|
])
|
|
])
|
|
|
|
# Rewrite inspired by the functionality once provided by
|
|
# AX_COMPILE_CHECK_SIZEOF. Uses the switch() "trick" to find the size of the
|
|
# given type.
|
|
#
|
|
# This code fails to compile:
|
|
#
|
|
# switch() { case 0: case 0: }
|
|
#
|
|
# By making the second case number a boolean check, it fails to compile the
|
|
# test code when the boolean is false and thus creating a zero, making it a
|
|
# duplicated case label. If the boolean equals true, it becomes a one, the
|
|
# code compiles and we know it was a match.
|
|
#
|
|
# The check iterates over all possible sizes and stops as soon it compiles
|
|
# error-free.
|
|
#
|
|
# Usage:
|
|
#
|
|
# CURL_SIZEOF(TYPE, [HEADERS])
|
|
#
|
|
|
|
AC_DEFUN([CURL_SIZEOF], [
|
|
dnl The #define name to make autoheader put the name in curl_config.h.in
|
|
define(TYPE, translit(sizeof_$1, [a-z *], [A-Z_P]))dnl
|
|
|
|
AC_MSG_CHECKING(size of $1)
|
|
r=0
|
|
dnl Check the sizes in a reasonable order
|
|
for typesize in 8 4 2 16 1; do
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
#include <sys/types.h>
|
|
$2
|
|
]],
|
|
[switch(0) {
|
|
case 0:
|
|
case (sizeof($1) == $typesize):;
|
|
}
|
|
]) ],
|
|
[
|
|
r=$typesize],
|
|
[
|
|
r=0])
|
|
dnl get out of the loop once matched
|
|
if test $r -gt 0; then
|
|
break;
|
|
fi
|
|
done
|
|
if test $r -eq 0; then
|
|
AC_MSG_ERROR([Failed to find size of $1])
|
|
fi
|
|
AC_MSG_RESULT($r)
|
|
dnl lowercase and underscore instead of space
|
|
tname=$(echo "ac_cv_sizeof_$1" | tr A-Z a-z | tr " " "_")
|
|
eval "$tname=$r"
|
|
|
|
AC_DEFINE_UNQUOTED(TYPE, [$r], [Size of $1 in number of bytes])
|
|
|
|
])
|