5494 строки
160 KiB
Plaintext
Executable File
5494 строки
160 KiB
Plaintext
Executable File
#***************************************************************************
|
|
# _ _ ____ _
|
|
# Project ___| | | | _ \| |
|
|
# / __| | | | |_) | |
|
|
# | (__| |_| | _ <| |___
|
|
# \___|\___/|_| \_\_____|
|
|
#
|
|
# Copyright (C) 1998 - 2021, 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.
|
|
#
|
|
#***************************************************************************
|
|
dnl Process this file with autoconf to produce a configure script.
|
|
|
|
AC_PREREQ(2.57)
|
|
|
|
dnl We don't know the version number "statically" so we use a dash here
|
|
AC_INIT([curl], [-], [a suitable curl mailing list: https://curl.se/mail/])
|
|
|
|
XC_OVR_ZZ50
|
|
XC_OVR_ZZ60
|
|
CURL_OVERRIDE_AUTOCONF
|
|
|
|
dnl configure script copyright
|
|
AC_COPYRIGHT([Copyright (c) 1998 - 2021 Daniel Stenberg, <daniel@haxx.se>
|
|
This configure script may be copied, distributed and modified under the
|
|
terms of the curl license; see COPYING for more details])
|
|
|
|
AC_CONFIG_SRCDIR([lib/urldata.h])
|
|
AC_CONFIG_HEADERS(lib/curl_config.h)
|
|
AC_CONFIG_MACRO_DIR([m4])
|
|
AM_MAINTAINER_MODE
|
|
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
|
|
|
|
CURL_CHECK_OPTION_DEBUG
|
|
CURL_CHECK_OPTION_OPTIMIZE
|
|
CURL_CHECK_OPTION_WARNINGS
|
|
CURL_CHECK_OPTION_WERROR
|
|
CURL_CHECK_OPTION_CURLDEBUG
|
|
CURL_CHECK_OPTION_SYMBOL_HIDING
|
|
CURL_CHECK_OPTION_ARES
|
|
CURL_CHECK_OPTION_RT
|
|
CURL_CHECK_OPTION_ECH
|
|
|
|
XC_CHECK_PATH_SEPARATOR
|
|
|
|
#
|
|
# save the configure arguments
|
|
#
|
|
CONFIGURE_OPTIONS="\"$ac_configure_args\""
|
|
AC_SUBST(CONFIGURE_OPTIONS)
|
|
|
|
dnl SED is mandatory for configure process and libtool.
|
|
dnl Set it now, allowing it to be changed later.
|
|
if test -z "$SED"; then
|
|
dnl allow it to be overridden
|
|
AC_PATH_PROG([SED], [sed], [not_found],
|
|
[$PATH:/usr/bin:/usr/local/bin])
|
|
if test -z "$SED" || test "$SED" = "not_found"; then
|
|
AC_MSG_ERROR([sed not found in PATH. Cannot continue without sed.])
|
|
fi
|
|
fi
|
|
AC_SUBST([SED])
|
|
|
|
dnl GREP is mandatory for configure process and libtool.
|
|
dnl Set it now, allowing it to be changed later.
|
|
if test -z "$GREP"; then
|
|
dnl allow it to be overridden
|
|
AC_PATH_PROG([GREP], [grep], [not_found],
|
|
[$PATH:/usr/bin:/usr/local/bin])
|
|
if test -z "$GREP" || test "$GREP" = "not_found"; then
|
|
AC_MSG_ERROR([grep not found in PATH. Cannot continue without grep.])
|
|
fi
|
|
fi
|
|
AC_SUBST([GREP])
|
|
|
|
dnl EGREP is mandatory for configure process and libtool.
|
|
dnl Set it now, allowing it to be changed later.
|
|
if test -z "$EGREP"; then
|
|
dnl allow it to be overridden
|
|
if echo a | ($GREP -E '(a|b)') >/dev/null 2>&1; then
|
|
AC_MSG_CHECKING([for egrep])
|
|
EGREP="$GREP -E"
|
|
AC_MSG_RESULT([$EGREP])
|
|
else
|
|
AC_PATH_PROG([EGREP], [egrep], [not_found],
|
|
[$PATH:/usr/bin:/usr/local/bin])
|
|
fi
|
|
fi
|
|
if test -z "$EGREP" || test "$EGREP" = "not_found"; then
|
|
AC_MSG_ERROR([egrep not found in PATH. Cannot continue without egrep.])
|
|
fi
|
|
AC_SUBST([EGREP])
|
|
|
|
dnl AR is mandatory for configure process and libtool.
|
|
dnl This is target dependent, so check it as a tool.
|
|
if test -z "$AR"; then
|
|
dnl allow it to be overridden
|
|
AC_PATH_TOOL([AR], [ar], [not_found],
|
|
[$PATH:/usr/bin:/usr/local/bin])
|
|
if test -z "$AR" || test "$AR" = "not_found"; then
|
|
AC_MSG_ERROR([ar not found in PATH. Cannot continue without ar.])
|
|
fi
|
|
fi
|
|
AC_SUBST([AR])
|
|
|
|
AC_SUBST(libext)
|
|
|
|
dnl figure out the libcurl version
|
|
CURLVERSION=`$SED -ne 's/^#define LIBCURL_VERSION "\(.*\)".*/\1/p' ${srcdir}/include/curl/curlver.h`
|
|
XC_CHECK_PROG_CC
|
|
|
|
dnl for --enable-code-coverage
|
|
CURL_COVERAGE
|
|
|
|
XC_AUTOMAKE
|
|
AC_MSG_CHECKING([curl version])
|
|
AC_MSG_RESULT($CURLVERSION)
|
|
|
|
AC_SUBST(CURLVERSION)
|
|
|
|
dnl
|
|
dnl we extract the numerical version for curl-config only
|
|
VERSIONNUM=`$SED -ne 's/^#define LIBCURL_VERSION_NUM 0x\([0-9A-Fa-f]*\).*/\1/p' ${srcdir}/include/curl/curlver.h`
|
|
AC_SUBST(VERSIONNUM)
|
|
|
|
dnl Solaris pkgadd support definitions
|
|
PKGADD_PKG="HAXXcurl"
|
|
PKGADD_NAME="curl - a client that groks URLs"
|
|
PKGADD_VENDOR="curl.se"
|
|
AC_SUBST(PKGADD_PKG)
|
|
AC_SUBST(PKGADD_NAME)
|
|
AC_SUBST(PKGADD_VENDOR)
|
|
|
|
dnl
|
|
dnl initialize all the info variables
|
|
curl_ssl_msg="no (--with-{ssl,gnutls,nss,mbedtls,wolfssl,schannel,secure-transport,mesalink,amissl,bearssl,rustls} )"
|
|
curl_ssh_msg="no (--with-{libssh,libssh2})"
|
|
curl_zlib_msg="no (--with-zlib)"
|
|
curl_brotli_msg="no (--with-brotli)"
|
|
curl_zstd_msg="no (--with-zstd)"
|
|
curl_gss_msg="no (--with-gssapi)"
|
|
curl_gsasl_msg="no (--with-gsasl)"
|
|
curl_tls_srp_msg="no (--enable-tls-srp)"
|
|
curl_res_msg="default (--enable-ares / --enable-threaded-resolver)"
|
|
curl_ipv6_msg="no (--enable-ipv6)"
|
|
curl_unix_sockets_msg="no (--enable-unix-sockets)"
|
|
curl_idn_msg="no (--with-{libidn2,winidn})"
|
|
curl_manual_msg="no (--enable-manual)"
|
|
curl_libcurl_msg="enabled (--disable-libcurl-option)"
|
|
curl_verbose_msg="enabled (--disable-verbose)"
|
|
curl_sspi_msg="no (--enable-sspi)"
|
|
curl_ldap_msg="no (--enable-ldap / --with-ldap-lib / --with-lber-lib)"
|
|
curl_ldaps_msg="no (--enable-ldaps)"
|
|
curl_rtsp_msg="no (--enable-rtsp)"
|
|
curl_rtmp_msg="no (--with-librtmp)"
|
|
curl_mtlnk_msg="no (--with-libmetalink)"
|
|
curl_psl_msg="no (--with-libpsl)"
|
|
curl_altsvc_msg="enabled";
|
|
ssl_backends=
|
|
curl_h1_msg="enabled (--with-hyper)"
|
|
curl_h2_msg="no (--with-nghttp2)"
|
|
curl_h3_msg="no (--with-ngtcp2, --with-quiche)"
|
|
|
|
enable_altsvc="yes"
|
|
|
|
dnl
|
|
dnl Save some initial values the user might have provided
|
|
dnl
|
|
INITIAL_LDFLAGS=$LDFLAGS
|
|
INITIAL_LIBS=$LIBS
|
|
|
|
dnl
|
|
dnl Detect the canonical host and target build environment
|
|
dnl
|
|
|
|
AC_CANONICAL_HOST
|
|
dnl Get system canonical name
|
|
AC_DEFINE_UNQUOTED(OS, "${host}", [cpu-machine-OS])
|
|
|
|
# Silence warning: ar: 'u' modifier ignored since 'D' is the default
|
|
AC_SUBST(AR_FLAGS, [cr])
|
|
|
|
dnl This defines _ALL_SOURCE for AIX
|
|
CURL_CHECK_AIX_ALL_SOURCE
|
|
|
|
dnl Our configure and build reentrant settings
|
|
CURL_CONFIGURE_THREAD_SAFE
|
|
CURL_CONFIGURE_REENTRANT
|
|
|
|
dnl check for how to do large files
|
|
AC_SYS_LARGEFILE
|
|
|
|
XC_LIBTOOL
|
|
|
|
#
|
|
# Automake conditionals based on libtool related checks
|
|
#
|
|
|
|
AM_CONDITIONAL([CURL_LT_SHLIB_USE_VERSION_INFO],
|
|
[test "x$xc_lt_shlib_use_version_info" = 'xyes'])
|
|
AM_CONDITIONAL([CURL_LT_SHLIB_USE_NO_UNDEFINED],
|
|
[test "x$xc_lt_shlib_use_no_undefined" = 'xyes'])
|
|
AM_CONDITIONAL([CURL_LT_SHLIB_USE_MIMPURE_TEXT],
|
|
[test "x$xc_lt_shlib_use_mimpure_text" = 'xyes'])
|
|
|
|
#
|
|
# Due to libtool and automake machinery limitations of not allowing
|
|
# specifying separate CPPFLAGS or CFLAGS when compiling objects for
|
|
# inclusion of these in shared or static libraries, we are forced to
|
|
# build using separate configure runs for shared and static libraries
|
|
# on systems where different CPPFLAGS or CFLAGS are mandatory in order
|
|
# to compile objects for each kind of library. Notice that relying on
|
|
# the '-DPIC' CFLAG that libtool provides is not valid given that the
|
|
# user might for example choose to build static libraries with PIC.
|
|
#
|
|
|
|
#
|
|
# Make our Makefile.am files use the staticlib CPPFLAG only when strictly
|
|
# targeting a static library and not building its shared counterpart.
|
|
#
|
|
|
|
AM_CONDITIONAL([USE_CPPFLAG_CURL_STATICLIB],
|
|
[test "x$xc_lt_build_static_only" = 'xyes'])
|
|
|
|
#
|
|
# Make staticlib CPPFLAG variable and its definition visible in output
|
|
# files unconditionally, providing an empty definition unless strictly
|
|
# targeting a static library and not building its shared counterpart.
|
|
#
|
|
|
|
CPPFLAG_CURL_STATICLIB=
|
|
if test "x$xc_lt_build_static_only" = 'xyes'; then
|
|
CPPFLAG_CURL_STATICLIB='-DCURL_STATICLIB'
|
|
fi
|
|
AC_SUBST([CPPFLAG_CURL_STATICLIB])
|
|
|
|
|
|
# Determine whether all dependent libraries must be specified when linking
|
|
if test "X$enable_shared" = "Xyes" -a "X$link_all_deplibs" = "Xno"
|
|
then
|
|
REQUIRE_LIB_DEPS=no
|
|
else
|
|
REQUIRE_LIB_DEPS=yes
|
|
fi
|
|
AC_SUBST(REQUIRE_LIB_DEPS)
|
|
AM_CONDITIONAL(USE_EXPLICIT_LIB_DEPS, test x$REQUIRE_LIB_DEPS = xyes)
|
|
|
|
dnl check if there's a way to force code inline
|
|
AC_C_INLINE
|
|
|
|
dnl **********************************************************************
|
|
dnl platform/compiler/architecture specific checks/flags
|
|
dnl **********************************************************************
|
|
|
|
CURL_CHECK_COMPILER
|
|
CURL_SET_COMPILER_BASIC_OPTS
|
|
CURL_SET_COMPILER_DEBUG_OPTS
|
|
CURL_SET_COMPILER_OPTIMIZE_OPTS
|
|
CURL_SET_COMPILER_WARNING_OPTS
|
|
|
|
if test "$compiler_id" = "INTEL_UNIX_C"; then
|
|
#
|
|
if test "$compiler_num" -ge "1000"; then
|
|
dnl icc 10.X or later
|
|
CFLAGS="$CFLAGS -shared-intel"
|
|
elif test "$compiler_num" -ge "900"; then
|
|
dnl icc 9.X specific
|
|
CFLAGS="$CFLAGS -i-dynamic"
|
|
fi
|
|
#
|
|
fi
|
|
|
|
CURL_CFLAG_EXTRAS=""
|
|
if test X"$want_werror" = Xyes; then
|
|
CURL_CFLAG_EXTRAS="-Werror"
|
|
if test "$compiler_id" = "GNU_C"; then
|
|
dnl enable -pedantic-errors for GCC 5 and later,
|
|
dnl as before that it was the same as -Werror=pedantic
|
|
if test "$compiler_num" -ge "500"; then
|
|
CURL_CFLAG_EXTRAS="$CURL_CFLAG_EXTRAS -pedantic-errors"
|
|
fi
|
|
fi
|
|
fi
|
|
AC_SUBST(CURL_CFLAG_EXTRAS)
|
|
|
|
CURL_CHECK_COMPILER_HALT_ON_ERROR
|
|
CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE
|
|
CURL_CHECK_COMPILER_PROTOTYPE_MISMATCH
|
|
CURL_CHECK_COMPILER_SYMBOL_HIDING
|
|
|
|
CURL_CHECK_CURLDEBUG
|
|
AM_CONDITIONAL(CURLDEBUG, test x$want_curldebug = xyes)
|
|
|
|
supports_unittests=yes
|
|
# cross-compilation of unit tests static library/programs fails when
|
|
# libcurl shared library is built. This might be due to a libtool or
|
|
# automake issue. In this case we disable unit tests.
|
|
if test "x$cross_compiling" != "xno" &&
|
|
test "x$enable_shared" != "xno"; then
|
|
supports_unittests=no
|
|
fi
|
|
|
|
# IRIX 6.5.24 gcc 3.3 autobuilds fail unittests library compilation due to
|
|
# a problem related with OpenSSL headers and library versions not matching.
|
|
# Disable unit tests while time to further investigate this is found.
|
|
case $host in
|
|
mips-sgi-irix6.5)
|
|
if test "$compiler_id" = "GNU_C"; then
|
|
supports_unittests=no
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
# All AIX autobuilds fails unit tests linking against unittests library
|
|
# due to unittests library being built with no symbols or members. Libtool ?
|
|
# Disable unit tests while time to further investigate this is found.
|
|
case $host_os in
|
|
aix*)
|
|
supports_unittests=no
|
|
;;
|
|
esac
|
|
|
|
dnl Build unit tests when option --enable-debug is given.
|
|
if test "x$want_debug" = "xyes" &&
|
|
test "x$supports_unittests" = "xyes"; then
|
|
want_unittests=yes
|
|
else
|
|
want_unittests=no
|
|
fi
|
|
AM_CONDITIONAL(BUILD_UNITTESTS, test x$want_unittests = xyes)
|
|
|
|
dnl **********************************************************************
|
|
dnl Compilation based checks should not be done before this point.
|
|
dnl **********************************************************************
|
|
|
|
dnl **********************************************************************
|
|
dnl Make sure that our checks for headers windows.h winsock.h winsock2.h
|
|
dnl and ws2tcpip.h take precedence over any other further checks which
|
|
dnl could be done later using AC_CHECK_HEADER or AC_CHECK_HEADERS for
|
|
dnl this specific header files. And do them before its results are used.
|
|
dnl **********************************************************************
|
|
|
|
CURL_CHECK_HEADER_WINDOWS
|
|
CURL_CHECK_NATIVE_WINDOWS
|
|
case X-"$curl_cv_native_windows" in
|
|
X-yes)
|
|
CURL_CHECK_HEADER_WINSOCK
|
|
CURL_CHECK_HEADER_WINSOCK2
|
|
CURL_CHECK_HEADER_WS2TCPIP
|
|
CURL_CHECK_HEADER_WINLDAP
|
|
CURL_CHECK_HEADER_WINBER
|
|
;;
|
|
*)
|
|
curl_cv_header_winsock_h="no"
|
|
curl_cv_header_winsock2_h="no"
|
|
curl_cv_header_ws2tcpip_h="no"
|
|
curl_cv_header_winldap_h="no"
|
|
curl_cv_header_winber_h="no"
|
|
;;
|
|
esac
|
|
CURL_CHECK_WIN32_LARGEFILE
|
|
|
|
CURL_MAC_CFLAGS
|
|
CURL_SUPPORTS_BUILTIN_AVAILABLE
|
|
|
|
|
|
dnl ************************************************************
|
|
dnl switch off particular protocols
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support http])
|
|
AC_ARG_ENABLE(http,
|
|
AC_HELP_STRING([--enable-http],[Enable HTTP support])
|
|
AC_HELP_STRING([--disable-http],[Disable HTTP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_HTTP, 1, [to disable HTTP])
|
|
disable_http="yes"
|
|
AC_MSG_WARN([disable HTTP disables FTP over proxy and RTSP])
|
|
AC_SUBST(CURL_DISABLE_HTTP, [1])
|
|
AC_DEFINE(CURL_DISABLE_RTSP, 1, [to disable RTSP])
|
|
AC_SUBST(CURL_DISABLE_RTSP, [1])
|
|
dnl toggle off alt-svc too when HTTP is disabled
|
|
AC_DEFINE(CURL_DISABLE_ALTSVC, 1, [disable alt-svc])
|
|
curl_h1_msg="no (--enable-http, --with-hyper)"
|
|
curl_altsvc_msg="no";
|
|
enable_altsvc="no"
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
AC_MSG_CHECKING([whether to support ftp])
|
|
AC_ARG_ENABLE(ftp,
|
|
AC_HELP_STRING([--enable-ftp],[Enable FTP support])
|
|
AC_HELP_STRING([--disable-ftp],[Disable FTP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_FTP, 1, [to disable FTP])
|
|
AC_SUBST(CURL_DISABLE_FTP, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
AC_MSG_CHECKING([whether to support file])
|
|
AC_ARG_ENABLE(file,
|
|
AC_HELP_STRING([--enable-file],[Enable FILE support])
|
|
AC_HELP_STRING([--disable-file],[Disable FILE support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_FILE, 1, [to disable FILE])
|
|
AC_SUBST(CURL_DISABLE_FILE, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
AC_MSG_CHECKING([whether to support ldap])
|
|
AC_ARG_ENABLE(ldap,
|
|
AC_HELP_STRING([--enable-ldap],[Enable LDAP support])
|
|
AC_HELP_STRING([--disable-ldap],[Disable LDAP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
|
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],[
|
|
AC_MSG_RESULT(yes) ]
|
|
)
|
|
AC_MSG_CHECKING([whether to support ldaps])
|
|
AC_ARG_ENABLE(ldaps,
|
|
AC_HELP_STRING([--enable-ldaps],[Enable LDAPS support])
|
|
AC_HELP_STRING([--disable-ldaps],[Disable LDAPS support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
|
;;
|
|
*) if test "x$CURL_DISABLE_LDAP" = "x1" ; then
|
|
AC_MSG_RESULT(LDAP needs to be enabled to support LDAPS)
|
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_LDAP_SSL, 1, [Use LDAPS implementation])
|
|
AC_SUBST(HAVE_LDAP_SSL, [1])
|
|
fi
|
|
;;
|
|
esac ],[
|
|
if test "x$CURL_DISABLE_LDAP" = "x1" ; then
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_LDAP_SSL, 1, [Use LDAPS implementation])
|
|
AC_SUBST(HAVE_LDAP_SSL, [1])
|
|
fi ]
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support rtsp])
|
|
AC_ARG_ENABLE(rtsp,
|
|
AC_HELP_STRING([--enable-rtsp],[Enable RTSP support])
|
|
AC_HELP_STRING([--disable-rtsp],[Disable RTSP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_RTSP, 1, [to disable RTSP])
|
|
AC_SUBST(CURL_DISABLE_RTSP, [1])
|
|
;;
|
|
*) if test x$CURL_DISABLE_HTTP = x1 ; then
|
|
AC_MSG_ERROR(HTTP support needs to be enabled in order to enable RTSP support!)
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
curl_rtsp_msg="enabled"
|
|
fi
|
|
;;
|
|
esac ],
|
|
if test "x$CURL_DISABLE_HTTP" != "x1"; then
|
|
AC_MSG_RESULT(yes)
|
|
curl_rtsp_msg="enabled"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support proxies])
|
|
AC_ARG_ENABLE(proxy,
|
|
AC_HELP_STRING([--enable-proxy],[Enable proxy support])
|
|
AC_HELP_STRING([--disable-proxy],[Disable proxy support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_PROXY, 1, [to disable proxies])
|
|
AC_SUBST(CURL_DISABLE_PROXY, [1])
|
|
https_proxy="no"
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support dict])
|
|
AC_ARG_ENABLE(dict,
|
|
AC_HELP_STRING([--enable-dict],[Enable DICT support])
|
|
AC_HELP_STRING([--disable-dict],[Disable DICT support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_DICT, 1, [to disable DICT])
|
|
AC_SUBST(CURL_DISABLE_DICT, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
AC_MSG_CHECKING([whether to support telnet])
|
|
AC_ARG_ENABLE(telnet,
|
|
AC_HELP_STRING([--enable-telnet],[Enable TELNET support])
|
|
AC_HELP_STRING([--disable-telnet],[Disable TELNET support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_TELNET, 1, [to disable TELNET])
|
|
AC_SUBST(CURL_DISABLE_TELNET, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
AC_MSG_CHECKING([whether to support tftp])
|
|
AC_ARG_ENABLE(tftp,
|
|
AC_HELP_STRING([--enable-tftp],[Enable TFTP support])
|
|
AC_HELP_STRING([--disable-tftp],[Disable TFTP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_TFTP, 1, [to disable TFTP])
|
|
AC_SUBST(CURL_DISABLE_TFTP, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support pop3])
|
|
AC_ARG_ENABLE(pop3,
|
|
AC_HELP_STRING([--enable-pop3],[Enable POP3 support])
|
|
AC_HELP_STRING([--disable-pop3],[Disable POP3 support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_POP3, 1, [to disable POP3])
|
|
AC_SUBST(CURL_DISABLE_POP3, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
|
|
AC_MSG_CHECKING([whether to support imap])
|
|
AC_ARG_ENABLE(imap,
|
|
AC_HELP_STRING([--enable-imap],[Enable IMAP support])
|
|
AC_HELP_STRING([--disable-imap],[Disable IMAP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_IMAP, 1, [to disable IMAP])
|
|
AC_SUBST(CURL_DISABLE_IMAP, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
|
|
AC_MSG_CHECKING([whether to support smb])
|
|
AC_ARG_ENABLE(smb,
|
|
AC_HELP_STRING([--enable-smb],[Enable SMB/CIFS support])
|
|
AC_HELP_STRING([--disable-smb],[Disable SMB/CIFS support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_SMB, 1, [to disable SMB/CIFS])
|
|
AC_SUBST(CURL_DISABLE_SMB, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support smtp])
|
|
AC_ARG_ENABLE(smtp,
|
|
AC_HELP_STRING([--enable-smtp],[Enable SMTP support])
|
|
AC_HELP_STRING([--disable-smtp],[Disable SMTP support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_SMTP, 1, [to disable SMTP])
|
|
AC_SUBST(CURL_DISABLE_SMTP, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support gopher])
|
|
AC_ARG_ENABLE(gopher,
|
|
AC_HELP_STRING([--enable-gopher],[Enable Gopher support])
|
|
AC_HELP_STRING([--disable-gopher],[Disable Gopher support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable Gopher])
|
|
AC_SUBST(CURL_DISABLE_GOPHER, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
AC_MSG_CHECKING([whether to support mqtt])
|
|
AC_ARG_ENABLE(mqtt,
|
|
AC_HELP_STRING([--enable-mqtt],[Enable MQTT support])
|
|
AC_HELP_STRING([--disable-mqtt],[Disable MQTT support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_MQTT, 1, [to disable MQTT])
|
|
AC_SUBST(CURL_DISABLE_MQTT, [1])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(no)
|
|
)
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for built-in manual
|
|
dnl **********************************************************************
|
|
|
|
AC_MSG_CHECKING([whether to provide built-in manual])
|
|
AC_ARG_ENABLE(manual,
|
|
AC_HELP_STRING([--enable-manual],[Enable built-in manual])
|
|
AC_HELP_STRING([--disable-manual],[Disable built-in manual]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
USE_MANUAL="1"
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
USE_MANUAL="1"
|
|
)
|
|
dnl The actual use of the USE_MANUAL variable is done much later in this
|
|
dnl script to allow other actions to disable it as well.
|
|
|
|
dnl ************************************************************
|
|
dnl disable C code generation support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to enable generation of C code])
|
|
AC_ARG_ENABLE(libcurl_option,
|
|
AC_HELP_STRING([--enable-libcurl-option],[Enable --libcurl C code generation support])
|
|
AC_HELP_STRING([--disable-libcurl-option],[Disable --libcurl C code generation support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_LIBCURL_OPTION, 1, [to disable --libcurl C code generation option])
|
|
curl_libcurl_msg="no"
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl **********************************************************************
|
|
dnl Checks for libraries.
|
|
dnl **********************************************************************
|
|
|
|
AC_MSG_CHECKING([whether to use libgcc])
|
|
AC_ARG_ENABLE(libgcc,
|
|
AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]),
|
|
[ case "$enableval" in
|
|
yes)
|
|
LIBS="-lgcc $LIBS"
|
|
AC_MSG_RESULT(yes)
|
|
;;
|
|
*) AC_MSG_RESULT(no)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(no)
|
|
)
|
|
|
|
CURL_CHECK_LIB_XNET
|
|
|
|
dnl gethostbyname without lib or in the nsl lib?
|
|
AC_CHECK_FUNC(gethostbyname,
|
|
[HAVE_GETHOSTBYNAME="1"
|
|
],
|
|
[ AC_CHECK_LIB(nsl, gethostbyname,
|
|
[HAVE_GETHOSTBYNAME="1"
|
|
LIBS="-lnsl $LIBS"
|
|
])
|
|
])
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl gethostbyname in the socket lib?
|
|
AC_CHECK_LIB(socket, gethostbyname,
|
|
[HAVE_GETHOSTBYNAME="1"
|
|
LIBS="-lsocket $LIBS"
|
|
])
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl gethostbyname in the watt lib?
|
|
AC_CHECK_LIB(watt, gethostbyname,
|
|
[HAVE_GETHOSTBYNAME="1"
|
|
CPPFLAGS="-I/dev/env/WATT_ROOT/inc"
|
|
LDFLAGS="-L/dev/env/WATT_ROOT/lib"
|
|
LIBS="-lwatt $LIBS"
|
|
])
|
|
fi
|
|
|
|
dnl At least one system has been identified to require BOTH nsl and socket
|
|
dnl libs at the same time to link properly.
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
AC_MSG_CHECKING([for gethostbyname with both nsl and socket libs])
|
|
my_ac_save_LIBS=$LIBS
|
|
LIBS="-lnsl -lsocket $LIBS"
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
]],[[
|
|
gethostbyname();
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
HAVE_GETHOSTBYNAME="1"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
LIBS=$my_ac_save_LIBS
|
|
])
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl This is for winsock systems
|
|
if test "$curl_cv_header_windows_h" = "yes"; then
|
|
if test "$curl_cv_header_winsock_h" = "yes"; then
|
|
case $host in
|
|
*-*-mingw32ce*)
|
|
winsock_LIB="-lwinsock"
|
|
;;
|
|
*)
|
|
winsock_LIB="-lwsock32"
|
|
;;
|
|
esac
|
|
fi
|
|
if test "$curl_cv_header_winsock2_h" = "yes"; then
|
|
winsock_LIB="-lws2_32"
|
|
fi
|
|
if test ! -z "$winsock_LIB"; then
|
|
my_ac_save_LIBS=$LIBS
|
|
LIBS="$winsock_LIB $LIBS"
|
|
AC_MSG_CHECKING([for gethostbyname in $winsock_LIB])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#ifdef HAVE_WINDOWS_H
|
|
#ifndef WIN32_LEAN_AND_MEAN
|
|
#define WIN32_LEAN_AND_MEAN
|
|
#endif
|
|
#include <windows.h>
|
|
#ifdef HAVE_WINSOCK2_H
|
|
#include <winsock2.h>
|
|
#else
|
|
#ifdef HAVE_WINSOCK_H
|
|
#include <winsock.h>
|
|
#endif
|
|
#endif
|
|
#endif
|
|
]],[[
|
|
gethostbyname("www.dummysite.com");
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
HAVE_GETHOSTBYNAME="1"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
winsock_LIB=""
|
|
LIBS=$my_ac_save_LIBS
|
|
])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl This is for Minix 3.1
|
|
AC_MSG_CHECKING([for gethostbyname for Minix 3])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
/* Older Minix versions may need <net/gen/netdb.h> here instead */
|
|
#include <netdb.h>
|
|
]],[[
|
|
gethostbyname("www.dummysite.com");
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
HAVE_GETHOSTBYNAME="1"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl This is for eCos with a stubbed DNS implementation
|
|
AC_MSG_CHECKING([for gethostbyname for eCos])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <stdio.h>
|
|
#include <netdb.h>
|
|
]],[[
|
|
gethostbyname("www.dummysite.com");
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
HAVE_GETHOSTBYNAME="1"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1" -o "${with_amissl+set}" = set
|
|
then
|
|
dnl This is for AmigaOS with bsdsocket.library - needs testing before -lnet
|
|
AC_MSG_CHECKING([for gethostbyname for AmigaOS bsdsocket.library])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <proto/bsdsocket.h>
|
|
struct Library *SocketBase = NULL;
|
|
]],[[
|
|
gethostbyname("www.dummysite.com");
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
HAVE_GETHOSTBYNAME="1"
|
|
HAVE_PROTO_BSDSOCKET_H="1"
|
|
AC_DEFINE(HAVE_PROTO_BSDSOCKET_H, 1, [if Amiga bsdsocket.library is in use])
|
|
AC_SUBST(HAVE_PROTO_BSDSOCKET_H, [1])
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl gethostbyname in the network lib - for Haiku OS
|
|
AC_CHECK_LIB(network, gethostbyname,
|
|
[HAVE_GETHOSTBYNAME="1"
|
|
LIBS="-lnetwork $LIBS"
|
|
])
|
|
fi
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
|
then
|
|
dnl gethostbyname in the net lib - for BeOS
|
|
AC_CHECK_LIB(net, gethostbyname,
|
|
[HAVE_GETHOSTBYNAME="1"
|
|
LIBS="-lnet $LIBS"
|
|
])
|
|
fi
|
|
|
|
|
|
if test "$HAVE_GETHOSTBYNAME" != "1"; then
|
|
AC_MSG_ERROR([couldn't find libraries for gethostbyname()])
|
|
fi
|
|
|
|
CURL_CHECK_LIBS_CONNECT
|
|
|
|
CURL_NETWORK_LIBS=$LIBS
|
|
|
|
dnl **********************************************************************
|
|
dnl In case that function clock_gettime with monotonic timer is available,
|
|
dnl check for additional required libraries.
|
|
dnl **********************************************************************
|
|
CURL_CHECK_LIBS_CLOCK_GETTIME_MONOTONIC
|
|
|
|
dnl **********************************************************************
|
|
dnl The preceding library checks are all potentially useful for test
|
|
dnl servers and libtest cases which require networking and clock_gettime
|
|
dnl support. Save the list of required libraries at this point for use
|
|
dnl while linking those test servers and programs.
|
|
dnl **********************************************************************
|
|
CURL_NETWORK_AND_TIME_LIBS=$LIBS
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the presence of ZLIB libraries and headers
|
|
dnl **********************************************************************
|
|
|
|
dnl Check for & handle argument to --with-zlib.
|
|
|
|
clean_CPPFLAGS=$CPPFLAGS
|
|
clean_LDFLAGS=$LDFLAGS
|
|
clean_LIBS=$LIBS
|
|
ZLIB_LIBS=""
|
|
AC_ARG_WITH(zlib,
|
|
AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH])
|
|
AC_HELP_STRING([--without-zlib],[disable use of zlib]),
|
|
[OPT_ZLIB="$withval"])
|
|
|
|
if test "$OPT_ZLIB" = "no" ; then
|
|
AC_MSG_WARN([zlib disabled])
|
|
else
|
|
if test "$OPT_ZLIB" = "yes" ; then
|
|
OPT_ZLIB=""
|
|
fi
|
|
|
|
if test -z "$OPT_ZLIB" ; then
|
|
CURL_CHECK_PKGCONFIG(zlib)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIBS="`$PKGCONFIG --libs-only-l zlib` $LIBS"
|
|
LDFLAGS="$LDFLAGS `$PKGCONFIG --libs-only-L zlib`"
|
|
CPPFLAGS="$CPPFLAGS `$PKGCONFIG --cflags-only-I zlib`"
|
|
OPT_ZLIB=""
|
|
HAVE_LIBZ="1"
|
|
fi
|
|
|
|
if test -z "$HAVE_LIBZ"; then
|
|
|
|
dnl Check for the lib without setting any new path, since many
|
|
dnl people have it in the default path
|
|
|
|
AC_CHECK_LIB(z, inflateEnd,
|
|
dnl libz found, set the variable
|
|
[HAVE_LIBZ="1"
|
|
LIBS="-lz $LIBS"],
|
|
dnl if no lib found, try /usr/local
|
|
[OPT_ZLIB="/usr/local"])
|
|
fi
|
|
fi
|
|
|
|
dnl Add a nonempty path to the compiler flags
|
|
if test -n "$OPT_ZLIB"; then
|
|
CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include"
|
|
LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib$libsuff"
|
|
fi
|
|
|
|
AC_CHECK_HEADER(zlib.h,
|
|
[
|
|
dnl zlib.h was found
|
|
HAVE_ZLIB_H="1"
|
|
dnl if the lib wasn't found already, try again with the new paths
|
|
if test "$HAVE_LIBZ" != "1"; then
|
|
AC_CHECK_LIB(z, gzread,
|
|
[
|
|
dnl the lib was found!
|
|
HAVE_LIBZ="1"
|
|
LIBS="-lz $LIBS"
|
|
],
|
|
[ CPPFLAGS=$clean_CPPFLAGS
|
|
LDFLAGS=$clean_LDFLAGS])
|
|
fi
|
|
],
|
|
[
|
|
dnl zlib.h was not found, restore the flags
|
|
CPPFLAGS=$clean_CPPFLAGS
|
|
LDFLAGS=$clean_LDFLAGS]
|
|
)
|
|
|
|
if test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" != "1"
|
|
then
|
|
AC_MSG_WARN([configure found only the libz lib, not the header file!])
|
|
HAVE_LIBZ=""
|
|
CPPFLAGS=$clean_CPPFLAGS
|
|
LDFLAGS=$clean_LDFLAGS
|
|
LIBS=$clean_LIBS
|
|
elif test "$HAVE_LIBZ" != "1" && test "$HAVE_ZLIB_H" = "1"
|
|
then
|
|
AC_MSG_WARN([configure found only the libz header file, not the lib!])
|
|
CPPFLAGS=$clean_CPPFLAGS
|
|
LDFLAGS=$clean_LDFLAGS
|
|
LIBS=$clean_LIBS
|
|
elif test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" = "1"
|
|
then
|
|
dnl both header and lib were found!
|
|
AC_SUBST(HAVE_LIBZ)
|
|
AC_DEFINE(HAVE_ZLIB_H, 1, [if you have the zlib.h header file])
|
|
AC_DEFINE(HAVE_LIBZ, 1, [if zlib is available])
|
|
|
|
ZLIB_LIBS="-lz"
|
|
LIBS="-lz $clean_LIBS"
|
|
|
|
dnl replace 'HAVE_LIBZ' in the automake makefile.ams
|
|
AMFIXLIB="1"
|
|
AC_MSG_NOTICE([found both libz and libz.h header])
|
|
curl_zlib_msg="enabled"
|
|
fi
|
|
fi
|
|
|
|
dnl set variable for use in automakefile(s)
|
|
AM_CONDITIONAL(HAVE_LIBZ, test x"$AMFIXLIB" = x1)
|
|
AC_SUBST(ZLIB_LIBS)
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the presence of BROTLI decoder libraries and headers
|
|
dnl **********************************************************************
|
|
|
|
dnl Brotli project home page: https://github.com/google/brotli
|
|
|
|
dnl Default to compiler & linker defaults for BROTLI files & libraries.
|
|
OPT_BROTLI=off
|
|
AC_ARG_WITH(brotli,dnl
|
|
AC_HELP_STRING([--with-brotli=PATH],[Where to look for brotli, PATH points to the BROTLI installation; when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--without-brotli], [disable BROTLI]),
|
|
OPT_BROTLI=$withval)
|
|
|
|
if test X"$OPT_BROTLI" != Xno; then
|
|
dnl backup the pre-brotli variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
case "$OPT_BROTLI" in
|
|
yes)
|
|
dnl --with-brotli (without path) used
|
|
CURL_CHECK_PKGCONFIG(libbrotlidec)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_BROTLI=`$PKGCONFIG --libs-only-l libbrotlidec`
|
|
LD_BROTLI=`$PKGCONFIG --libs-only-L libbrotlidec`
|
|
CPP_BROTLI=`$PKGCONFIG --cflags-only-I libbrotlidec`
|
|
version=`$PKGCONFIG --modversion libbrotlidec`
|
|
DIR_BROTLI=`echo $LD_BROTLI | $SED -e 's/^-L//'`
|
|
fi
|
|
|
|
;;
|
|
off)
|
|
dnl no --with-brotli option given, just check default places
|
|
;;
|
|
*)
|
|
dnl use the given --with-brotli spot
|
|
PREFIX_BROTLI=$OPT_BROTLI
|
|
;;
|
|
esac
|
|
|
|
dnl if given with a prefix, we set -L and -I based on that
|
|
if test -n "$PREFIX_BROTLI"; then
|
|
LIB_BROTLI="-lbrotlidec"
|
|
LD_BROTLI=-L${PREFIX_BROTLI}/lib$libsuff
|
|
CPP_BROTLI=-I${PREFIX_BROTLI}/include
|
|
DIR_BROTLI=${PREFIX_BROTLI}/lib$libsuff
|
|
fi
|
|
|
|
LDFLAGS="$LDFLAGS $LD_BROTLI"
|
|
CPPFLAGS="$CPPFLAGS $CPP_BROTLI"
|
|
LIBS="$LIB_BROTLI $LIBS"
|
|
|
|
AC_CHECK_LIB(brotlidec, BrotliDecoderDecompress)
|
|
|
|
AC_CHECK_HEADERS(brotli/decode.h,
|
|
curl_brotli_msg="enabled (libbrotlidec)"
|
|
HAVE_BROTLI=1
|
|
AC_DEFINE(HAVE_BROTLI, 1, [if BROTLI is in use])
|
|
AC_SUBST(HAVE_BROTLI, [1])
|
|
)
|
|
|
|
if test X"$OPT_BROTLI" != Xoff &&
|
|
test "$HAVE_BROTLI" != "1"; then
|
|
AC_MSG_ERROR([BROTLI libs and/or directories were not found where specified!])
|
|
fi
|
|
|
|
if test "$HAVE_BROTLI" = "1"; then
|
|
if test -n "$DIR_BROTLI"; then
|
|
dnl when the brotli shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to CURL_LIBRARY_PATH
|
|
dnl to prevent further configure tests to fail due to this
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_BROTLI"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_BROTLI to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
else
|
|
dnl no brotli, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for libzstd
|
|
dnl **********************************************************************
|
|
|
|
dnl Default to compiler & linker defaults for libzstd
|
|
OPT_ZSTD=off
|
|
AC_ARG_WITH(zstd,dnl
|
|
AC_HELP_STRING([--with-zstd=PATH],[Where to look for libzstd, PATH points to the libzstd installation; when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--without-zstd], [disable libzstd]),
|
|
OPT_ZSTD=$withval)
|
|
|
|
if test X"$OPT_ZSTD" != Xno; then
|
|
dnl backup the pre-zstd variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
case "$OPT_ZSTD" in
|
|
yes)
|
|
dnl --with-zstd (without path) used
|
|
CURL_CHECK_PKGCONFIG(libzstd)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_ZSTD=`$PKGCONFIG --libs-only-l libzstd`
|
|
LD_ZSTD=`$PKGCONFIG --libs-only-L libzstd`
|
|
CPP_ZSTD=`$PKGCONFIG --cflags-only-I libzstd`
|
|
version=`$PKGCONFIG --modversion libzstd`
|
|
DIR_ZSTD=`echo $LD_ZSTD | $SED -e 's/-L//'`
|
|
fi
|
|
|
|
;;
|
|
off)
|
|
dnl no --with-zstd option given, just check default places
|
|
;;
|
|
*)
|
|
dnl use the given --with-zstd spot
|
|
PREFIX_ZSTD=$OPT_ZSTD
|
|
;;
|
|
esac
|
|
|
|
dnl if given with a prefix, we set -L and -I based on that
|
|
if test -n "$PREFIX_ZSTD"; then
|
|
LIB_ZSTD="-lzstd"
|
|
LD_ZSTD=-L${PREFIX_ZSTD}/lib$libsuff
|
|
CPP_ZSTD=-I${PREFIX_ZSTD}/include
|
|
DIR_ZSTD=${PREFIX_ZSTD}/lib$libsuff
|
|
fi
|
|
|
|
LDFLAGS="$LDFLAGS $LD_ZSTD"
|
|
CPPFLAGS="$CPPFLAGS $CPP_ZSTD"
|
|
LIBS="$LIB_ZSTD $LIBS"
|
|
|
|
AC_CHECK_LIB(zstd, ZSTD_createDStream)
|
|
|
|
AC_CHECK_HEADERS(zstd.h,
|
|
curl_zstd_msg="enabled (libzstd)"
|
|
HAVE_ZSTD=1
|
|
AC_DEFINE(HAVE_ZSTD, 1, [if libzstd is in use])
|
|
AC_SUBST(HAVE_ZSTD, [1])
|
|
)
|
|
|
|
if test X"$OPT_ZSTD" != Xoff &&
|
|
test "$HAVE_ZSTD" != "1"; then
|
|
AC_MSG_ERROR([libzstd was not found where specified!])
|
|
fi
|
|
|
|
if test "$HAVE_ZSTD" = "1"; then
|
|
if test -n "$DIR_ZSTD"; then
|
|
dnl when the zstd shared lib were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail due to
|
|
dnl this
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_ZSTD"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_ZSTD to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
else
|
|
dnl no zstd, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for LDAP
|
|
dnl **********************************************************************
|
|
|
|
LDAPLIBNAME=""
|
|
AC_ARG_WITH(ldap-lib,
|
|
AC_HELP_STRING([--with-ldap-lib=libname],[Specify name of ldap lib file]),
|
|
[LDAPLIBNAME="$withval"])
|
|
|
|
LBERLIBNAME=""
|
|
AC_ARG_WITH(lber-lib,
|
|
AC_HELP_STRING([--with-lber-lib=libname],[Specify name of lber lib file]),
|
|
[LBERLIBNAME="$withval"])
|
|
|
|
if test x$CURL_DISABLE_LDAP != x1 ; then
|
|
|
|
CURL_CHECK_HEADER_LBER
|
|
CURL_CHECK_HEADER_LDAP
|
|
CURL_CHECK_HEADER_LDAPSSL
|
|
CURL_CHECK_HEADER_LDAP_SSL
|
|
|
|
if test -z "$LDAPLIBNAME" ; then
|
|
if test "$curl_cv_native_windows" = "yes"; then
|
|
dnl Windows uses a single and unique LDAP library name
|
|
LDAPLIBNAME="wldap32"
|
|
LBERLIBNAME="no"
|
|
fi
|
|
fi
|
|
|
|
if test "$LDAPLIBNAME" ; then
|
|
AC_CHECK_LIB("$LDAPLIBNAME", ldap_init,, [
|
|
AC_MSG_WARN(["$LDAPLIBNAME" is not an LDAP library: LDAP disabled])
|
|
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
|
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])])
|
|
else
|
|
dnl Try to find the right ldap libraries for this system
|
|
CURL_CHECK_LIBS_LDAP
|
|
case X-"$curl_cv_ldap_LIBS" in
|
|
X-unknown)
|
|
AC_MSG_WARN([Cannot find libraries for LDAP support: LDAP disabled])
|
|
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
|
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
|
;;
|
|
esac
|
|
fi
|
|
fi
|
|
|
|
if test x$CURL_DISABLE_LDAP != x1 ; then
|
|
|
|
if test "$LBERLIBNAME" ; then
|
|
dnl If name is "no" then don't define this library at all
|
|
dnl (it's only needed if libldap.so's dependencies are broken).
|
|
if test "$LBERLIBNAME" != "no" ; then
|
|
AC_CHECK_LIB("$LBERLIBNAME", ber_free,, [
|
|
AC_MSG_WARN(["$LBERLIBNAME" is not an LBER library: LDAP disabled])
|
|
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
|
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test x$CURL_DISABLE_LDAP != x1 ; then
|
|
AC_CHECK_FUNCS([ldap_url_parse ldap_init_fd])
|
|
|
|
if test "$LDAPLIBNAME" = "wldap32"; then
|
|
curl_ldap_msg="enabled (winldap)"
|
|
AC_DEFINE(USE_WIN32_LDAP, 1, [Use Windows LDAP implementation])
|
|
else
|
|
curl_ldap_msg="enabled (OpenLDAP)"
|
|
if test "x$ac_cv_func_ldap_init_fd" = "xyes"; then
|
|
AC_DEFINE(USE_OPENLDAP, 1, [Use OpenLDAP-specific code])
|
|
AC_SUBST(USE_OPENLDAP, [1])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test x$CURL_DISABLE_LDAPS != x1 ; then
|
|
curl_ldaps_msg="enabled"
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Checks for IPv6
|
|
dnl **********************************************************************
|
|
|
|
AC_MSG_CHECKING([whether to enable IPv6])
|
|
AC_ARG_ENABLE(ipv6,
|
|
AC_HELP_STRING([--enable-ipv6],[Enable IPv6 (with IPv4) support])
|
|
AC_HELP_STRING([--disable-ipv6],[Disable IPv6 support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
ipv6=no
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
ipv6=yes
|
|
;;
|
|
esac ],
|
|
|
|
AC_TRY_RUN([ /* are AF_INET6 and sockaddr_in6 available? */
|
|
#include <sys/types.h>
|
|
#ifdef HAVE_WINSOCK2_H
|
|
#include <winsock2.h>
|
|
#include <ws2tcpip.h>
|
|
#else
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#if defined (__TANDEM)
|
|
# include <netinet/in6.h>
|
|
#endif
|
|
#endif
|
|
#include <stdlib.h> /* for exit() */
|
|
main()
|
|
{
|
|
struct sockaddr_in6 s;
|
|
(void)s;
|
|
if (socket(AF_INET6, SOCK_STREAM, 0) < 0)
|
|
exit(1);
|
|
else
|
|
exit(0);
|
|
}
|
|
],
|
|
AC_MSG_RESULT(yes)
|
|
ipv6=yes,
|
|
AC_MSG_RESULT(no)
|
|
ipv6=no,
|
|
AC_MSG_RESULT(yes)
|
|
ipv6=yes
|
|
))
|
|
|
|
if test "$ipv6" = yes; then
|
|
curl_ipv6_msg="enabled"
|
|
AC_DEFINE(ENABLE_IPV6, 1, [Define if you want to enable IPv6 support])
|
|
IPV6_ENABLED=1
|
|
AC_SUBST(IPV6_ENABLED)
|
|
|
|
AC_MSG_CHECKING([if struct sockaddr_in6 has sin6_scope_id member])
|
|
AC_TRY_COMPILE([
|
|
#include <sys/types.h>
|
|
#ifdef HAVE_WINSOCK2_H
|
|
#include <winsock2.h>
|
|
#include <ws2tcpip.h>
|
|
#else
|
|
#include <netinet/in.h>
|
|
#if defined (__TANDEM)
|
|
# include <netinet/in6.h>
|
|
#endif
|
|
#endif] ,
|
|
struct sockaddr_in6 s; s.sin6_scope_id = 0; , have_sin6_scope_id=yes)
|
|
if test "$have_sin6_scope_id" = yes; then
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID, 1, [Define to 1 if struct sockaddr_in6 has the sin6_scope_id member])
|
|
else
|
|
AC_MSG_RESULT([no])
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check if the operating system allows programs to write to their own argv[]
|
|
dnl **********************************************************************
|
|
|
|
AC_MSG_CHECKING([if argv can be written to])
|
|
CURL_RUN_IFELSE([[
|
|
int main(int argc, char **argv)
|
|
{
|
|
(void)argc;
|
|
argv[0][0] = ' ';
|
|
return (argv[0][0] == ' ')?0:1;
|
|
}
|
|
]],[
|
|
curl_cv_writable_argv=yes
|
|
],[
|
|
curl_cv_writable_argv=no
|
|
],[
|
|
curl_cv_writable_argv=cross
|
|
])
|
|
case $curl_cv_writable_argv in
|
|
yes)
|
|
AC_DEFINE(HAVE_WRITABLE_ARGV, 1, [Define this symbol if your OS supports changing the contents of argv])
|
|
AC_MSG_RESULT(yes)
|
|
;;
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
;;
|
|
*)
|
|
AC_MSG_RESULT(no)
|
|
AC_MSG_WARN([the previous check could not be made default was used])
|
|
;;
|
|
esac
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for GSS-API libraries
|
|
dnl **********************************************************************
|
|
|
|
dnl check for GSS-API stuff in the /usr as default
|
|
|
|
GSSAPI_ROOT="/usr"
|
|
AC_ARG_WITH(gssapi-includes,
|
|
AC_HELP_STRING([--with-gssapi-includes=DIR],
|
|
[Specify location of GSS-API headers]),
|
|
[ GSSAPI_INCS="-I$withval"
|
|
want_gss="yes" ]
|
|
)
|
|
|
|
AC_ARG_WITH(gssapi-libs,
|
|
AC_HELP_STRING([--with-gssapi-libs=DIR],
|
|
[Specify location of GSS-API libs]),
|
|
[ GSSAPI_LIB_DIR="-L$withval"
|
|
want_gss="yes" ]
|
|
)
|
|
|
|
AC_ARG_WITH(gssapi,
|
|
AC_HELP_STRING([--with-gssapi=DIR],
|
|
[Where to look for GSS-API]), [
|
|
GSSAPI_ROOT="$withval"
|
|
if test x"$GSSAPI_ROOT" != xno; then
|
|
want_gss="yes"
|
|
if test x"$GSSAPI_ROOT" = xyes; then
|
|
dnl if yes, then use default root
|
|
GSSAPI_ROOT="/usr"
|
|
fi
|
|
fi
|
|
])
|
|
|
|
: ${KRB5CONFIG:="$GSSAPI_ROOT/bin/krb5-config"}
|
|
|
|
save_CPPFLAGS="$CPPFLAGS"
|
|
AC_MSG_CHECKING([if GSS-API support is requested])
|
|
if test x"$want_gss" = xyes; then
|
|
AC_MSG_RESULT(yes)
|
|
|
|
if test -z "$GSSAPI_INCS"; then
|
|
if test -n "$host_alias" -a -f "$GSSAPI_ROOT/bin/$host_alias-krb5-config"; then
|
|
GSSAPI_INCS=`$GSSAPI_ROOT/bin/$host_alias-krb5-config --cflags gssapi`
|
|
elif test -f "$KRB5CONFIG"; then
|
|
GSSAPI_INCS=`$KRB5CONFIG --cflags gssapi`
|
|
elif test "$GSSAPI_ROOT" != "yes"; then
|
|
GSSAPI_INCS="-I$GSSAPI_ROOT/include"
|
|
fi
|
|
fi
|
|
|
|
CPPFLAGS="$CPPFLAGS $GSSAPI_INCS"
|
|
|
|
AC_CHECK_HEADER(gss.h,
|
|
[
|
|
dnl found in the given dirs
|
|
AC_DEFINE(HAVE_GSSGNU, 1, [if you have GNU GSS])
|
|
gnu_gss=yes
|
|
],
|
|
[
|
|
dnl not found, check Heimdal or MIT
|
|
AC_CHECK_HEADERS([gssapi/gssapi.h], [], [not_mit=1])
|
|
AC_CHECK_HEADERS(
|
|
[gssapi/gssapi_generic.h gssapi/gssapi_krb5.h],
|
|
[],
|
|
[not_mit=1],
|
|
[
|
|
AC_INCLUDES_DEFAULT
|
|
#ifdef HAVE_GSSAPI_GSSAPI_H
|
|
#include <gssapi/gssapi.h>
|
|
#endif
|
|
])
|
|
if test "x$not_mit" = "x1"; then
|
|
dnl MIT not found, check for Heimdal
|
|
AC_CHECK_HEADER(gssapi.h,
|
|
[
|
|
dnl found
|
|
AC_DEFINE(HAVE_GSSHEIMDAL, 1, [if you have Heimdal])
|
|
],
|
|
[
|
|
dnl no header found, disabling GSS
|
|
want_gss=no
|
|
AC_MSG_WARN(disabling GSS-API support since no header files were found)
|
|
]
|
|
)
|
|
else
|
|
dnl MIT found
|
|
AC_DEFINE(HAVE_GSSMIT, 1, [if you have MIT Kerberos])
|
|
dnl check if we have a really old MIT Kerberos version (<= 1.2)
|
|
AC_MSG_CHECKING([if GSS-API headers declare GSS_C_NT_HOSTBASED_SERVICE])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <gssapi/gssapi.h>
|
|
#include <gssapi/gssapi_generic.h>
|
|
#include <gssapi/gssapi_krb5.h>
|
|
]],[[
|
|
gss_import_name(
|
|
(OM_uint32 *)0,
|
|
(gss_buffer_t)0,
|
|
GSS_C_NT_HOSTBASED_SERVICE,
|
|
(gss_name_t *)0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
AC_DEFINE(HAVE_OLD_GSSMIT, 1,
|
|
[if you have an old MIT Kerberos version, lacking GSS_C_NT_HOSTBASED_SERVICE])
|
|
])
|
|
fi
|
|
]
|
|
)
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
if test x"$want_gss" = xyes; then
|
|
AC_DEFINE(HAVE_GSSAPI, 1, [if you have GSS-API libraries])
|
|
HAVE_GSSAPI=1
|
|
curl_gss_msg="enabled (MIT Kerberos/Heimdal)"
|
|
|
|
if test -n "$gnu_gss"; then
|
|
curl_gss_msg="enabled (GNU GSS)"
|
|
LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR"
|
|
LIBS="-lgss $LIBS"
|
|
elif test -z "$GSSAPI_LIB_DIR"; then
|
|
case $host in
|
|
*-*-darwin*)
|
|
LIBS="-lgssapi_krb5 -lresolv $LIBS"
|
|
;;
|
|
*)
|
|
if test -n "$host_alias" -a -f "$GSSAPI_ROOT/bin/$host_alias-krb5-config"; then
|
|
dnl krb5-config doesn't have --libs-only-L or similar, put everything
|
|
dnl into LIBS
|
|
gss_libs=`$GSSAPI_ROOT/bin/$host_alias-krb5-config --libs gssapi`
|
|
LIBS="$gss_libs $LIBS"
|
|
elif test -f "$KRB5CONFIG"; then
|
|
dnl krb5-config doesn't have --libs-only-L or similar, put everything
|
|
dnl into LIBS
|
|
gss_libs=`$KRB5CONFIG --libs gssapi`
|
|
LIBS="$gss_libs $LIBS"
|
|
else
|
|
case $host in
|
|
*-hp-hpux*)
|
|
gss_libname="gss"
|
|
;;
|
|
*)
|
|
gss_libname="gssapi"
|
|
;;
|
|
esac
|
|
|
|
if test "$GSSAPI_ROOT" != "yes"; then
|
|
LDFLAGS="$LDFLAGS -L$GSSAPI_ROOT/lib$libsuff"
|
|
LIBS="-l$gss_libname $LIBS"
|
|
else
|
|
LIBS="-l$gss_libname $LIBS"
|
|
fi
|
|
fi
|
|
;;
|
|
esac
|
|
else
|
|
LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR"
|
|
case $host in
|
|
*-hp-hpux*)
|
|
LIBS="-lgss $LIBS"
|
|
;;
|
|
*)
|
|
LIBS="-lgssapi $LIBS"
|
|
;;
|
|
esac
|
|
fi
|
|
else
|
|
CPPFLAGS="$save_CPPFLAGS"
|
|
fi
|
|
|
|
build_libstubgss=no
|
|
if test x"$want_gss" = "xyes"; then
|
|
build_libstubgss=yes
|
|
fi
|
|
|
|
AM_CONDITIONAL(BUILD_STUB_GSS, test "x$build_libstubgss" = "xyes")
|
|
|
|
dnl -------------------------------------------------------------
|
|
dnl parse --with-default-ssl-backend so it can be validated below
|
|
dnl -------------------------------------------------------------
|
|
|
|
DEFAULT_SSL_BACKEND=no
|
|
VALID_DEFAULT_SSL_BACKEND=
|
|
AC_ARG_WITH(default-ssl-backend,
|
|
AC_HELP_STRING([--with-default-ssl-backend=NAME],[Use NAME as default SSL backend])
|
|
AC_HELP_STRING([--without-default-ssl-backend],[Use implicit default SSL backend]),
|
|
[DEFAULT_SSL_BACKEND=$withval])
|
|
case "$DEFAULT_SSL_BACKEND" in
|
|
no)
|
|
dnl --without-default-ssl-backend option used
|
|
;;
|
|
default|yes)
|
|
dnl --with-default-ssl-backend option used without name
|
|
AC_MSG_ERROR([The name of the default SSL backend is required.])
|
|
;;
|
|
*)
|
|
dnl --with-default-ssl-backend option used with name
|
|
AC_SUBST(DEFAULT_SSL_BACKEND)
|
|
dnl needs to be validated below
|
|
VALID_DEFAULT_SSL_BACKEND=no
|
|
;;
|
|
esac
|
|
|
|
dnl **********************************************************************
|
|
|
|
dnl -------------------------------------------------
|
|
dnl check winssl option before other SSL libraries
|
|
dnl -------------------------------------------------
|
|
|
|
OPT_SCHANNEL=no
|
|
AC_ARG_WITH(winssl,dnl
|
|
AC_HELP_STRING([--with-winssl],[enable Windows native SSL/TLS])
|
|
AC_HELP_STRING([--without-winssl], [disable Windows native SSL/TLS]),
|
|
OPT_SCHANNEL=$withval)
|
|
|
|
AC_ARG_WITH(schannel,dnl
|
|
AC_HELP_STRING([--with-schannel],[enable Windows native SSL/TLS])
|
|
AC_HELP_STRING([--without-schannel], [disable Windows native SSL/TLS]),
|
|
OPT_SCHANNEL=$withval)
|
|
|
|
AC_MSG_CHECKING([whether to enable Windows native SSL/TLS (Windows native builds only)])
|
|
if test -z "$ssl_backends" -o "x$OPT_SCHANNEL" != xno; then
|
|
ssl_msg=
|
|
if test "x$OPT_SCHANNEL" != "xno" &&
|
|
test "x$curl_cv_native_windows" = "xyes"; then
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(USE_SCHANNEL, 1, [to enable Windows native SSL/TLS support])
|
|
AC_SUBST(USE_SCHANNEL, [1])
|
|
ssl_msg="Windows-native"
|
|
test schannel != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
SCHANNEL_ENABLED=1
|
|
# --with-schannel implies --enable-sspi
|
|
AC_DEFINE(USE_WINDOWS_SSPI, 1, [to enable SSPI support])
|
|
AC_SUBST(USE_WINDOWS_SSPI, [1])
|
|
curl_sspi_msg="enabled"
|
|
LIBS="-lcrypt32 $LIBS"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
OPT_SECURETRANSPORT=no
|
|
AC_ARG_WITH(darwinssl,dnl
|
|
AC_HELP_STRING([--with-darwinssl],[enable Apple OS native SSL/TLS])
|
|
AC_HELP_STRING([--without-darwinssl], [disable Apple OS native SSL/TLS]),
|
|
OPT_SECURETRANSPORT=$withval)
|
|
|
|
AC_ARG_WITH(secure-transport,dnl
|
|
AC_HELP_STRING([--with-secure-transport],[enable Apple OS native SSL/TLS])
|
|
AC_HELP_STRING([--without-secure-transport], [disable Apple OS native SSL/TLS]),
|
|
OPT_SECURETRANSPORT=$withval)
|
|
|
|
AC_MSG_CHECKING([whether to enable Secure Transport])
|
|
if test -z "$ssl_backends" -o "x$OPT_SECURETRANSPORT" != xno; then
|
|
if test "x$OPT_SECURETRANSPORT" != "xno" &&
|
|
(test "x$cross_compiling" != "xno" || test -d "/System/Library/Frameworks/Security.framework"); then
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(USE_SECTRANSP, 1, [enable Secure Transport])
|
|
AC_SUBST(USE_SECTRANSP, [1])
|
|
ssl_msg="Secure Transport"
|
|
test secure-transport != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
SECURETRANSPORT_ENABLED=1
|
|
LDFLAGS="$LDFLAGS -framework CoreFoundation -framework Security"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
OPT_AMISSL=no
|
|
AC_ARG_WITH(amissl,dnl
|
|
AC_HELP_STRING([--with-amissl],[enable Amiga native SSL/TLS (AmiSSL)])
|
|
AC_HELP_STRING([--without-amissl], [disable Amiga native SSL/TLS (AmiSSL)]),
|
|
OPT_AMISSL=$withval)
|
|
|
|
AC_MSG_CHECKING([whether to enable Amiga native SSL/TLS (AmiSSL)])
|
|
if test "$HAVE_PROTO_BSDSOCKET_H" = "1"; then
|
|
if test -z "$ssl_backends" -o "x$OPT_AMISSL" != xno; then
|
|
ssl_msg=
|
|
if test "x$OPT_AMISSL" != "xno"; then
|
|
AC_MSG_RESULT(yes)
|
|
ssl_msg="AmiSSL"
|
|
test amissl != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
AMISSL_ENABLED=1
|
|
LIBS="-lamisslauto $LIBS"
|
|
AC_DEFINE(USE_AMISSL, 1, [if AmiSSL is in use])
|
|
AC_DEFINE(USE_OPENSSL, 1, [if OpenSSL is in use])
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the presence of SSL libraries and headers
|
|
dnl **********************************************************************
|
|
|
|
dnl Default to compiler & linker defaults for SSL files & libraries.
|
|
OPT_SSL=off
|
|
dnl Default to no CA bundle
|
|
ca="no"
|
|
AC_ARG_WITH(ssl,dnl
|
|
AC_HELP_STRING([--with-ssl=PATH],[Where to look for OpenSSL, PATH points to the SSL installation (default: /usr/local/ssl); when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--without-ssl], [disable OpenSSL]),
|
|
OPT_SSL=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_SSL" != xno &&
|
|
test X"$OPT_SSL" != Xno; then
|
|
ssl_msg=
|
|
|
|
dnl backup the pre-ssl variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
dnl This is for Msys/Mingw
|
|
case $host in
|
|
*-*-msys* | *-*-mingw*)
|
|
AC_MSG_CHECKING([for gdi32])
|
|
my_ac_save_LIBS=$LIBS
|
|
LIBS="-lgdi32 $LIBS"
|
|
AC_TRY_LINK([#include <windef.h>
|
|
#include <wingdi.h>],
|
|
[GdiFlush();],
|
|
[ dnl worked!
|
|
AC_MSG_RESULT([yes])],
|
|
[ dnl failed, restore LIBS
|
|
LIBS=$my_ac_save_LIBS
|
|
AC_MSG_RESULT(no)]
|
|
)
|
|
;;
|
|
esac
|
|
|
|
case "$OPT_SSL" in
|
|
yes)
|
|
dnl --with-ssl (without path) used
|
|
PKGTEST="yes"
|
|
PREFIX_OPENSSL=/usr/local/ssl
|
|
LIB_OPENSSL="$PREFIX_OPENSSL/lib$libsuff"
|
|
;;
|
|
off)
|
|
dnl no --with-ssl option given, just check default places
|
|
PKGTEST="yes"
|
|
PREFIX_OPENSSL=
|
|
;;
|
|
*)
|
|
dnl check the given --with-ssl spot
|
|
PKGTEST="no"
|
|
PREFIX_OPENSSL=$OPT_SSL
|
|
|
|
dnl Try pkg-config even when cross-compiling. Since we
|
|
dnl specify PKG_CONFIG_LIBDIR we're only looking where
|
|
dnl the user told us to look
|
|
OPENSSL_PCDIR="$OPT_SSL/lib/pkgconfig"
|
|
if test -f "$OPENSSL_PCDIR/openssl.pc"; then
|
|
AC_MSG_NOTICE([PKG_CONFIG_LIBDIR will be set to "$OPENSSL_PCDIR"])
|
|
PKGTEST="yes"
|
|
elif test ! -f "$PREFIX_OPENSSL/include/openssl/ssl.h"; then
|
|
AC_MSG_ERROR([$PREFIX_OPENSSL is a bad --with-ssl prefix!])
|
|
fi
|
|
|
|
dnl in case pkg-config comes up empty, use what we got
|
|
dnl via --with-ssl
|
|
LIB_OPENSSL="$PREFIX_OPENSSL/lib$libsuff"
|
|
if test "$PREFIX_OPENSSL" != "/usr" ; then
|
|
SSL_LDFLAGS="-L$LIB_OPENSSL"
|
|
SSL_CPPFLAGS="-I$PREFIX_OPENSSL/include"
|
|
fi
|
|
SSL_CPPFLAGS="$SSL_CPPFLAGS -I$PREFIX_OPENSSL/include/openssl"
|
|
;;
|
|
esac
|
|
|
|
if test "$PKGTEST" = "yes"; then
|
|
|
|
CURL_CHECK_PKGCONFIG(openssl, [$OPENSSL_PCDIR])
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
SSL_LIBS=`CURL_EXPORT_PCDIR([$OPENSSL_PCDIR]) dnl
|
|
$PKGCONFIG --libs-only-l --libs-only-other openssl 2>/dev/null`
|
|
|
|
SSL_LDFLAGS=`CURL_EXPORT_PCDIR([$OPENSSL_PCDIR]) dnl
|
|
$PKGCONFIG --libs-only-L openssl 2>/dev/null`
|
|
|
|
SSL_CPPFLAGS=`CURL_EXPORT_PCDIR([$OPENSSL_PCDIR]) dnl
|
|
$PKGCONFIG --cflags-only-I openssl 2>/dev/null`
|
|
|
|
AC_SUBST(SSL_LIBS)
|
|
AC_MSG_NOTICE([pkg-config: SSL_LIBS: "$SSL_LIBS"])
|
|
AC_MSG_NOTICE([pkg-config: SSL_LDFLAGS: "$SSL_LDFLAGS"])
|
|
AC_MSG_NOTICE([pkg-config: SSL_CPPFLAGS: "$SSL_CPPFLAGS"])
|
|
|
|
LIB_OPENSSL=`echo $SSL_LDFLAGS | sed -e 's/^-L//'`
|
|
|
|
dnl use the values pkg-config reported. This is here
|
|
dnl instead of below with CPPFLAGS and LDFLAGS because we only
|
|
dnl learn about this via pkg-config. If we only have
|
|
dnl the argument to --with-ssl we don't know what
|
|
dnl additional libs may be necessary. Hope that we
|
|
dnl don't need any.
|
|
LIBS="$SSL_LIBS $LIBS"
|
|
fi
|
|
fi
|
|
|
|
dnl finally, set flags to use SSL
|
|
CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS"
|
|
LDFLAGS="$LDFLAGS $SSL_LDFLAGS"
|
|
|
|
AC_CHECK_LIB(crypto, HMAC_Update,[
|
|
HAVECRYPTO="yes"
|
|
LIBS="-lcrypto $LIBS"
|
|
],[
|
|
LDFLAGS="$CLEANLDFLAGS -L$LIB_OPENSSL"
|
|
if test "$PKGCONFIG" = "no" ; then
|
|
# only set this if pkg-config wasn't used
|
|
CPPFLAGS="$CLEANCPPFLAGS -I$PREFIX_OPENSSL/include/openssl -I$PREFIX_OPENSSL/include"
|
|
fi
|
|
# Linking previously failed, try extra paths from --with-ssl or pkg-config.
|
|
# Use a different function name to avoid reusing the earlier cached result.
|
|
AC_CHECK_LIB(crypto, HMAC_Init_ex,[
|
|
HAVECRYPTO="yes"
|
|
LIBS="-lcrypto $LIBS"], [
|
|
|
|
dnl still no, but what about with -ldl?
|
|
AC_MSG_CHECKING([OpenSSL linking with -ldl])
|
|
LIBS="$CLEANLIBS -lcrypto -ldl"
|
|
AC_TRY_LINK(
|
|
[
|
|
#include <openssl/err.h>
|
|
],
|
|
[
|
|
ERR_clear_error();
|
|
],
|
|
[
|
|
AC_MSG_RESULT(yes)
|
|
HAVECRYPTO="yes"
|
|
],
|
|
[
|
|
AC_MSG_RESULT(no)
|
|
dnl ok, so what about both -ldl and -lpthread?
|
|
dnl This may be necessary for static libraries.
|
|
|
|
AC_MSG_CHECKING([OpenSSL linking with -ldl and -lpthread])
|
|
LIBS="$CLEANLIBS -lcrypto -ldl -lpthread"
|
|
AC_TRY_LINK(
|
|
[
|
|
#include <openssl/err.h>
|
|
],
|
|
[
|
|
ERR_clear_error();
|
|
],
|
|
[
|
|
AC_MSG_RESULT(yes)
|
|
HAVECRYPTO="yes"
|
|
],
|
|
[
|
|
AC_MSG_RESULT(no)
|
|
LDFLAGS="$CLEANLDFLAGS"
|
|
CPPFLAGS="$CLEANCPPFLAGS"
|
|
LIBS="$CLEANLIBS"
|
|
|
|
])
|
|
|
|
])
|
|
|
|
])
|
|
])
|
|
|
|
if test X"$HAVECRYPTO" = X"yes"; then
|
|
dnl This is only reasonable to do if crypto actually is there: check for
|
|
dnl SSL libs NOTE: it is important to do this AFTER the crypto lib
|
|
|
|
AC_CHECK_LIB(ssl, SSL_connect)
|
|
|
|
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
|
dnl we didn't find the SSL lib, try the RSAglue/rsaref stuff
|
|
AC_MSG_CHECKING(for ssl with RSAglue/rsaref libs in use);
|
|
OLIBS=$LIBS
|
|
LIBS="-lRSAglue -lrsaref $LIBS"
|
|
AC_CHECK_LIB(ssl, SSL_connect)
|
|
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
|
dnl still no SSL_connect
|
|
AC_MSG_RESULT(no)
|
|
LIBS=$OLIBS
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
fi
|
|
|
|
else
|
|
|
|
dnl Have the libraries--check for OpenSSL headers
|
|
AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \
|
|
openssl/pem.h openssl/ssl.h openssl/err.h,
|
|
ssl_msg="OpenSSL"
|
|
test openssl != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
OPENSSL_ENABLED=1
|
|
AC_DEFINE(USE_OPENSSL, 1, [if OpenSSL is in use]))
|
|
|
|
if test $ac_cv_header_openssl_x509_h = no; then
|
|
dnl we don't use the "action" part of the AC_CHECK_HEADERS macro
|
|
dnl since 'err.h' might in fact find a krb4 header with the same
|
|
dnl name
|
|
AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h)
|
|
|
|
if test $ac_cv_header_x509_h = yes &&
|
|
test $ac_cv_header_crypto_h = yes &&
|
|
test $ac_cv_header_ssl_h = yes; then
|
|
dnl three matches
|
|
ssl_msg="OpenSSL"
|
|
OPENSSL_ENABLED=1
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test X"$OPENSSL_ENABLED" != X"1"; then
|
|
LIBS="$CLEANLIBS"
|
|
fi
|
|
|
|
if test X"$OPT_SSL" != Xoff &&
|
|
test "$OPENSSL_ENABLED" != "1"; then
|
|
AC_MSG_ERROR([OpenSSL libs and/or directories were not found where specified!])
|
|
fi
|
|
fi
|
|
|
|
if test X"$OPENSSL_ENABLED" = X"1"; then
|
|
dnl These can only exist if OpenSSL exists
|
|
dnl OpenSSL_version is introduced in 3.0.0
|
|
|
|
AC_CHECK_FUNCS( RAND_egd \
|
|
SSLv2_client_method \
|
|
OpenSSL_version )
|
|
|
|
AC_MSG_CHECKING([for BoringSSL])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <openssl/base.h>
|
|
]],[[
|
|
#ifndef OPENSSL_IS_BORINGSSL
|
|
#error not boringssl
|
|
#endif
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_BORINGSSL, 1,
|
|
[Define to 1 if using BoringSSL.])
|
|
ssl_msg="BoringSSL"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
|
|
AC_MSG_CHECKING([for libressl])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <openssl/opensslv.h>
|
|
]],[[
|
|
int dummy = LIBRESSL_VERSION_NUMBER;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_LIBRESSL, 1,
|
|
[Define to 1 if using libressl.])
|
|
ssl_msg="libressl"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
|
|
AC_MSG_CHECKING([for OpenSSL >= v3])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <openssl/opensslv.h>
|
|
]],[[
|
|
#if defined(OPENSSL_VERSION_MAJOR) && (OPENSSL_VERSION_MAJOR >= 3)
|
|
return 0;
|
|
#else
|
|
#error older than 3
|
|
#endif
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE_UNQUOTED(HAVE_OPENSSL3, 1,
|
|
[Define to 1 if using OpenSSL 3 or later.])
|
|
dnl OpenSSLv3 marks the DES functions deprecated but we have no
|
|
dnl replacements (yet) so tell the compiler to not warn for them
|
|
dnl
|
|
dnl Ask OpenSSL to suppress the warnings.
|
|
CPPFLAGS="$CPPFLAGS -DOPENSSL_SUPPRESS_DEPRECATED"
|
|
ssl_msg="OpenSSL v3+"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
fi
|
|
|
|
if test "$OPENSSL_ENABLED" = "1"; then
|
|
if test -n "$LIB_OPENSSL"; then
|
|
dnl when the ssl shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to CURL_LIBRARY_PATH
|
|
dnl to prevent further configure tests to fail due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$LIB_OPENSSL"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $LIB_OPENSSL to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
CURL_CHECK_OPENSSL_API
|
|
check_for_ca_bundle=1
|
|
fi
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
if test X"$OPT_SSL" != Xoff &&
|
|
test X"$OPT_SSL" != Xno &&
|
|
test "$OPENSSL_ENABLED" != "1"; then
|
|
AC_MSG_NOTICE([OPT_SSL: $OPT_SSL])
|
|
AC_MSG_NOTICE([OPENSSL_ENABLED: $OPENSSL_ENABLED])
|
|
AC_MSG_ERROR([--with-ssl was given but OpenSSL could not be detected])
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the random seed preferences
|
|
dnl **********************************************************************
|
|
|
|
if test X"$OPENSSL_ENABLED" = X"1"; then
|
|
AC_ARG_WITH(egd-socket,
|
|
AC_HELP_STRING([--with-egd-socket=FILE],
|
|
[Entropy Gathering Daemon socket pathname]),
|
|
[ EGD_SOCKET="$withval" ]
|
|
)
|
|
if test -n "$EGD_SOCKET" ; then
|
|
AC_DEFINE_UNQUOTED(EGD_SOCKET, "$EGD_SOCKET",
|
|
[your Entropy Gathering Daemon socket pathname] )
|
|
fi
|
|
|
|
dnl Check for user-specified random device
|
|
AC_ARG_WITH(random,
|
|
AC_HELP_STRING([--with-random=FILE],
|
|
[read randomness from FILE (default=/dev/urandom)]),
|
|
[ RANDOM_FILE="$withval" ],
|
|
[
|
|
if test x$cross_compiling != xyes; then
|
|
dnl Check for random device
|
|
AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] )
|
|
else
|
|
AC_MSG_WARN([skipped the /dev/urandom detection when cross-compiling])
|
|
fi
|
|
]
|
|
)
|
|
if test -n "$RANDOM_FILE" && test X"$RANDOM_FILE" != Xno ; then
|
|
AC_SUBST(RANDOM_FILE)
|
|
AC_DEFINE_UNQUOTED(RANDOM_FILE, "$RANDOM_FILE",
|
|
[a suitable file to read random data from])
|
|
fi
|
|
fi
|
|
|
|
dnl ---
|
|
dnl We require OpenSSL with SRP support.
|
|
dnl ---
|
|
if test "$OPENSSL_ENABLED" = "1"; then
|
|
AC_CHECK_LIB(crypto, SRP_Calc_client_key,
|
|
[
|
|
AC_DEFINE(HAVE_OPENSSL_SRP, 1, [if you have the function SRP_Calc_client_key])
|
|
AC_SUBST(HAVE_OPENSSL_SRP, [1])
|
|
])
|
|
fi
|
|
|
|
dnl ---
|
|
dnl Whether the OpenSSL configuration will be loaded automatically
|
|
dnl ---
|
|
if test X"$OPENSSL_ENABLED" = X"1"; then
|
|
AC_ARG_ENABLE(openssl-auto-load-config,
|
|
AC_HELP_STRING([--enable-openssl-auto-load-config],[Enable automatic loading of OpenSSL configuration])
|
|
AC_HELP_STRING([--disable-openssl-auto-load-config],[Disable automatic loading of OpenSSL configuration]),
|
|
[ if test X"$enableval" = X"no"; then
|
|
AC_MSG_NOTICE([automatic loading of OpenSSL configuration disabled])
|
|
AC_DEFINE(CURL_DISABLE_OPENSSL_AUTO_LOAD_CONFIG, 1, [if the OpenSSL configuration won't be loaded automatically])
|
|
fi
|
|
])
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl check for GnuTLS
|
|
dnl ----------------------------------------------------
|
|
|
|
dnl Default to compiler & linker defaults for GnuTLS files & libraries.
|
|
OPT_GNUTLS=no
|
|
|
|
AC_ARG_WITH(gnutls,dnl
|
|
AC_HELP_STRING([--with-gnutls=PATH],[where to look for GnuTLS, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-gnutls], [disable GnuTLS detection]),
|
|
OPT_GNUTLS=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_GNUTLS" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_GNUTLS" != Xno; then
|
|
|
|
addld=""
|
|
addlib=""
|
|
gtlslib=""
|
|
version=""
|
|
addcflags=""
|
|
|
|
if test "x$OPT_GNUTLS" = "xyes"; then
|
|
dnl this is with no partiular path given
|
|
CURL_CHECK_PKGCONFIG(gnutls)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
addlib=`$PKGCONFIG --libs-only-l gnutls`
|
|
addld=`$PKGCONFIG --libs-only-L gnutls`
|
|
addcflags=`$PKGCONFIG --cflags-only-I gnutls`
|
|
version=`$PKGCONFIG --modversion gnutls`
|
|
gtlslib=`echo $addld | $SED -e 's/^-L//'`
|
|
else
|
|
dnl without pkg-config, we try libgnutls-config as that was how it
|
|
dnl used to be done
|
|
check=`libgnutls-config --version 2>/dev/null`
|
|
if test -n "$check"; then
|
|
addlib=`libgnutls-config --libs`
|
|
addcflags=`libgnutls-config --cflags`
|
|
version=`libgnutls-config --version`
|
|
gtlslib=`libgnutls-config --prefix`/lib$libsuff
|
|
fi
|
|
fi
|
|
else
|
|
dnl this is with a given path, first check if there's a libgnutls-config
|
|
dnl there and if not, make an educated guess
|
|
cfg=$OPT_GNUTLS/bin/libgnutls-config
|
|
check=`$cfg --version 2>/dev/null`
|
|
if test -n "$check"; then
|
|
addlib=`$cfg --libs`
|
|
addcflags=`$cfg --cflags`
|
|
version=`$cfg --version`
|
|
gtlslib=`$cfg --prefix`/lib$libsuff
|
|
else
|
|
dnl without pkg-config and libgnutls-config, we guess a lot!
|
|
addlib=-lgnutls
|
|
addld=-L$OPT_GNUTLS/lib$libsuff
|
|
addcflags=-I$OPT_GNUTLS/include
|
|
version="" # we just don't know
|
|
gtlslib=$OPT_GNUTLS/lib$libsuff
|
|
fi
|
|
fi
|
|
|
|
if test -z "$version"; then
|
|
dnl lots of efforts, still no go
|
|
version="unknown"
|
|
fi
|
|
|
|
if test -n "$addlib"; then
|
|
|
|
CLEANLIBS="$LIBS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
|
|
LIBS="$addlib $LIBS"
|
|
LDFLAGS="$LDFLAGS $addld"
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
fi
|
|
|
|
dnl this function is selected since it was introduced in 3.1.10
|
|
AC_CHECK_LIB(gnutls, gnutls_x509_crt_get_dn2,
|
|
[
|
|
AC_DEFINE(USE_GNUTLS, 1, [if GnuTLS is enabled])
|
|
AC_SUBST(USE_GNUTLS, [1])
|
|
GNUTLS_ENABLED=1
|
|
USE_GNUTLS="yes"
|
|
ssl_msg="GnuTLS"
|
|
test gnutls != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
LIBS="$CLEANLIBS"
|
|
CPPFLAGS="$CLEANCPPFLAGS"
|
|
])
|
|
|
|
if test "x$USE_GNUTLS" = "xyes"; then
|
|
AC_MSG_NOTICE([detected GnuTLS version $version])
|
|
check_for_ca_bundle=1
|
|
if test -n "$gtlslib"; then
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$gtlslib"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $gtlslib to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
fi
|
|
|
|
fi dnl GNUTLS not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
dnl ---
|
|
dnl Check which crypto backend GnuTLS uses
|
|
dnl ---
|
|
|
|
if test "$GNUTLS_ENABLED" = "1"; then
|
|
USE_GNUTLS_NETTLE=
|
|
# First check if we can detect either crypto library via transitive linking
|
|
AC_CHECK_LIB(gnutls, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ])
|
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
|
AC_CHECK_LIB(gnutls, gcry_control, [ USE_GNUTLS_NETTLE=0 ])
|
|
fi
|
|
# If not, try linking directly to both of them to see if they are available
|
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
|
AC_CHECK_LIB(nettle, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ])
|
|
fi
|
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
|
AC_CHECK_LIB(gcrypt, gcry_control, [ USE_GNUTLS_NETTLE=0 ])
|
|
fi
|
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
|
AC_MSG_ERROR([GnuTLS found, but neither gcrypt nor nettle found])
|
|
fi
|
|
if test "$USE_GNUTLS_NETTLE" = "1"; then
|
|
AC_DEFINE(USE_GNUTLS_NETTLE, 1, [if GnuTLS uses nettle as crypto backend])
|
|
AC_SUBST(USE_GNUTLS_NETTLE, [1])
|
|
LIBS="-lnettle $LIBS"
|
|
else
|
|
LIBS="-lgcrypt $LIBS"
|
|
fi
|
|
fi
|
|
|
|
dnl ---
|
|
dnl We require GnuTLS with SRP support.
|
|
dnl ---
|
|
if test "$GNUTLS_ENABLED" = "1"; then
|
|
AC_CHECK_LIB(gnutls, gnutls_srp_verifier,
|
|
[
|
|
AC_DEFINE(HAVE_GNUTLS_SRP, 1, [if you have the function gnutls_srp_verifier])
|
|
AC_SUBST(HAVE_GNUTLS_SRP, [1])
|
|
])
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl check for mbedTLS
|
|
dnl ----------------------------------------------------
|
|
|
|
OPT_MBEDTLS=no
|
|
|
|
_cppflags=$CPPFLAGS
|
|
_ldflags=$LDFLAGS
|
|
AC_ARG_WITH(mbedtls,dnl
|
|
AC_HELP_STRING([--with-mbedtls=PATH],[where to look for mbedTLS, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-mbedtls], [disable mbedTLS detection]),
|
|
OPT_MBEDTLS=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_MBEDTLS" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_MBEDTLS" != Xno; then
|
|
|
|
if test "$OPT_MBEDTLS" = "yes"; then
|
|
OPT_MBEDTLS=""
|
|
fi
|
|
|
|
if test -z "$OPT_MBEDTLS" ; then
|
|
dnl check for lib first without setting any new path
|
|
|
|
AC_CHECK_LIB(mbedtls, mbedtls_havege_init,
|
|
dnl libmbedtls found, set the variable
|
|
[
|
|
AC_DEFINE(USE_MBEDTLS, 1, [if mbedTLS is enabled])
|
|
AC_SUBST(USE_MBEDTLS, [1])
|
|
MBEDTLS_ENABLED=1
|
|
USE_MBEDTLS="yes"
|
|
ssl_msg="mbedTLS"
|
|
test mbedtls != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
], [], -lmbedx509 -lmbedcrypto)
|
|
fi
|
|
|
|
addld=""
|
|
addlib=""
|
|
addcflags=""
|
|
mbedtlslib=""
|
|
|
|
if test "x$USE_MBEDTLS" != "xyes"; then
|
|
dnl add the path and test again
|
|
addld=-L$OPT_MBEDTLS/lib$libsuff
|
|
addcflags=-I$OPT_MBEDTLS/include
|
|
mbedtlslib=$OPT_MBEDTLS/lib$libsuff
|
|
|
|
LDFLAGS="$LDFLAGS $addld"
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
fi
|
|
|
|
AC_CHECK_LIB(mbedtls, mbedtls_ssl_init,
|
|
[
|
|
AC_DEFINE(USE_MBEDTLS, 1, [if mbedTLS is enabled])
|
|
AC_SUBST(USE_MBEDTLS, [1])
|
|
MBEDTLS_ENABLED=1
|
|
USE_MBEDTLS="yes"
|
|
ssl_msg="mbedTLS"
|
|
test mbedtls != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
CPPFLAGS=$_cppflags
|
|
LDFLAGS=$_ldflags
|
|
], -lmbedx509 -lmbedcrypto)
|
|
fi
|
|
|
|
if test "x$USE_MBEDTLS" = "xyes"; then
|
|
AC_MSG_NOTICE([detected mbedTLS])
|
|
check_for_ca_bundle=1
|
|
|
|
LIBS="-lmbedtls -lmbedx509 -lmbedcrypto $LIBS"
|
|
|
|
if test -n "$mbedtlslib"; then
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$mbedtlslib"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $mbedtlslib to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
fi dnl mbedTLS not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl check for wolfSSL
|
|
dnl ----------------------------------------------------
|
|
|
|
dnl Default to compiler & linker defaults for wolfSSL files & libraries.
|
|
OPT_WOLFSSL=no
|
|
|
|
_cppflags=$CPPFLAGS
|
|
_ldflags=$LDFLAGS
|
|
|
|
AC_ARG_WITH(wolfssl,dnl
|
|
AC_HELP_STRING([--with-wolfssl=PATH],[where to look for WolfSSL, PATH points to the installation root (default: system lib default)])
|
|
AC_HELP_STRING([--without-wolfssl], [disable WolfSSL detection]),
|
|
OPT_WOLFSSL=$withval)
|
|
|
|
case "$OPT_WOLFSSL" in
|
|
yes|no)
|
|
wolfpkg=""
|
|
;;
|
|
*)
|
|
wolfpkg="$withval/lib/pkgconfig"
|
|
;;
|
|
esac
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_WOLFSSL" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_WOLFSSL" != Xno; then
|
|
|
|
if test "$OPT_WOLFSSL" = "yes"; then
|
|
OPT_WOLFSSL=""
|
|
fi
|
|
|
|
dnl try pkg-config magic
|
|
CURL_CHECK_PKGCONFIG(wolfssl, [$wolfpkg])
|
|
AC_MSG_NOTICE([Check dir $wolfpkg])
|
|
|
|
addld=""
|
|
addlib=""
|
|
addcflags=""
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
addlib=`CURL_EXPORT_PCDIR([$wolfpkg])
|
|
$PKGCONFIG --libs-only-l wolfssl`
|
|
addld=`CURL_EXPORT_PCDIR([$wolfpkg])
|
|
$PKGCONFIG --libs-only-L wolfssl`
|
|
addcflags=`CURL_EXPORT_PCDIR([$wolfpkg])
|
|
$PKGCONFIG --cflags-only-I wolfssl`
|
|
version=`CURL_EXPORT_PCDIR([$wolfpkg])
|
|
$PKGCONFIG --modversion wolfssl`
|
|
wolfssllibpath=`echo $addld | $SED -e 's/^-L//'`
|
|
else
|
|
addlib=-lwolfssl
|
|
dnl use system defaults if user does not supply a path
|
|
if test -n "$OPT_WOLFSSL"; then
|
|
addld=-L$OPT_WOLFSSL/lib$libsuff
|
|
addcflags=-I$OPT_WOLFSSL/include
|
|
wolfssllibpath=$OPT_WOLFSSL/lib$libsuff
|
|
fi
|
|
fi
|
|
|
|
if test "x$USE_WOLFSSL" != "xyes"; then
|
|
|
|
LDFLAGS="$LDFLAGS $addld"
|
|
AC_MSG_NOTICE([Add $addld to LDFLAGS])
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
AC_MSG_NOTICE([Add $addcflags to CPPFLAGS])
|
|
fi
|
|
|
|
my_ac_save_LIBS="$LIBS"
|
|
LIBS="$addlib $LIBS"
|
|
AC_MSG_NOTICE([Add $addlib to LIBS])
|
|
|
|
AC_MSG_CHECKING([for wolfSSL_Init in -lwolfssl])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
/* These aren't needed for detection and confuse WolfSSL.
|
|
They are set up properly later if it is detected. */
|
|
#undef SIZEOF_LONG
|
|
#undef SIZEOF_LONG_LONG
|
|
#include <wolfssl/ssl.h>
|
|
]],[[
|
|
return wolfSSL_Init();
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(USE_WOLFSSL, 1, [if wolfSSL is enabled])
|
|
AC_SUBST(USE_WOLFSSL, [1])
|
|
WOLFSSL_ENABLED=1
|
|
USE_WOLFSSL="yes"
|
|
ssl_msg="WolfSSL"
|
|
test wolfssl != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
AC_MSG_RESULT(no)
|
|
CPPFLAGS=$_cppflags
|
|
LDFLAGS=$_ldflags
|
|
wolfssllibpath=""
|
|
])
|
|
LIBS="$my_ac_save_LIBS"
|
|
fi
|
|
|
|
if test "x$USE_WOLFSSL" = "xyes"; then
|
|
AC_MSG_NOTICE([detected wolfSSL])
|
|
check_for_ca_bundle=1
|
|
|
|
dnl wolfssl/ctaocrypt/types.h needs SIZEOF_LONG_LONG defined!
|
|
AX_COMPILE_CHECK_SIZEOF(long long)
|
|
|
|
LIBS="$addlib -lm $LIBS"
|
|
|
|
dnl Recent WolfSSL versions build without SSLv3 by default
|
|
dnl WolfSSL needs configure --enable-opensslextra to have *get_peer*
|
|
dnl DES* is needed for NTLM support and lives in the OpenSSL compatibility
|
|
dnl layer
|
|
AC_CHECK_FUNCS(wolfSSLv3_client_method \
|
|
wolfSSL_get_peer_certificate \
|
|
wolfSSL_UseALPN )
|
|
|
|
dnl if this symbol is present, we want the include path to include the
|
|
dnl OpenSSL API root as well
|
|
AC_CHECK_FUNC(wolfSSL_DES_ecb_encrypt,
|
|
[
|
|
AC_DEFINE(HAVE_WOLFSSL_DES_ECB_ENCRYPT, 1,
|
|
[if you have wolfSSL_DES_ecb_encrypt])
|
|
if test -n "$addcflags"; then
|
|
dnl use a for loop to strip off whitespace
|
|
for f in $addcflags; do
|
|
CPPFLAGS="$f/wolfssl $CPPFLAGS"
|
|
AC_MSG_NOTICE([Add $f/wolfssl to CPPFLAGS])
|
|
break
|
|
done
|
|
else
|
|
dnl user didn't give a path, so guess/hope they installed wolfssl
|
|
dnl headers to system default location
|
|
CPPFLAGS="-I$includedir/wolfssl $CPPFLAGS"
|
|
AC_MSG_NOTICE([Add $includedir/wolfssl to CPPFLAGS])
|
|
fi
|
|
WOLFSSL_NTLM=1
|
|
]
|
|
)
|
|
|
|
if test -n "$wolfssllibpath"; then
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$wolfssllibpath"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $wolfssllibpath to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
|
|
fi
|
|
|
|
fi dnl wolfSSL not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl check for MesaLink
|
|
dnl ----------------------------------------------------
|
|
|
|
dnl Default to compiler & linker defaults for MesaLink files & libraries.
|
|
OPT_MESALINK=no
|
|
|
|
_cppflags=$CPPFLAGS
|
|
_ldflags=$LDFLAGS
|
|
AC_ARG_WITH(mesalink,dnl
|
|
AC_HELP_STRING([--with-mesalink=PATH],[where to look for MesaLink, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-mesalink], [disable MesaLink detection]),
|
|
OPT_MESALINK=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_MESALINK" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_MESALINK" != Xno; then
|
|
|
|
if test "$OPT_MESALINK" = "yes"; then
|
|
OPT_MESALINK=""
|
|
fi
|
|
|
|
if test -z "$OPT_MESALINK" ; then
|
|
dnl check for lib first without setting any new path
|
|
|
|
AC_CHECK_LIB(mesalink, mesalink_library_init,
|
|
dnl libmesalink found, set the variable
|
|
[
|
|
AC_DEFINE(USE_MESALINK, 1, [if MesaLink is enabled])
|
|
AC_SUBST(USE_MESALINK, [1])
|
|
MESALINK_ENABLED=1
|
|
USE_MESALINK="yes"
|
|
ssl_msg="MesaLink"
|
|
test mesalink != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
])
|
|
fi
|
|
|
|
addld=""
|
|
addlib=""
|
|
addcflags=""
|
|
mesalinklib=""
|
|
|
|
if test "x$USE_MESALINK" != "xyes"; then
|
|
dnl add the path and test again
|
|
addld=-L$OPT_MESALINK/lib$libsuff
|
|
addcflags=-I$OPT_MESALINK/include
|
|
mesalinklib=$OPT_MESALINK/lib$libsuff
|
|
|
|
LDFLAGS="$LDFLAGS $addld"
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
fi
|
|
|
|
AC_CHECK_LIB(mesalink, mesalink_library_init,
|
|
[
|
|
AC_DEFINE(USE_MESALINK, 1, [if MesaLink is enabled])
|
|
AC_SUBST(USE_MESALINK, [1])
|
|
MESALINK_ENABLED=1
|
|
USE_MESALINK="yes"
|
|
ssl_msg="MesaLink"
|
|
test mesalink != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
CPPFLAGS=$_cppflags
|
|
LDFLAGS=$_ldflags
|
|
])
|
|
fi
|
|
|
|
if test "x$USE_MESALINK" = "xyes"; then
|
|
AC_MSG_NOTICE([detected MesaLink])
|
|
|
|
LIBS="-lmesalink $LIBS"
|
|
|
|
if test -n "$mesalinklib"; then
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$mesalinklib"
|
|
export LD_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $mesalinklib to LD_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
fi dnl MesaLink not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl check for BearSSL
|
|
dnl ----------------------------------------------------
|
|
|
|
OPT_BEARSSL=no
|
|
|
|
_cppflags=$CPPFLAGS
|
|
_ldflags=$LDFLAGS
|
|
AC_ARG_WITH(bearssl,dnl
|
|
AC_HELP_STRING([--with-bearssl=PATH],[where to look for BearSSL, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-bearssl], [disable BearSSL detection]),
|
|
OPT_BEARSSL=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_BEARSSL" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_BEARSSL" != Xno; then
|
|
|
|
if test "$OPT_BEARSSL" = "yes"; then
|
|
OPT_BEARSSL=""
|
|
fi
|
|
|
|
if test -z "$OPT_BEARSSL" ; then
|
|
dnl check for lib first without setting any new path
|
|
|
|
AC_CHECK_LIB(bearssl, br_ssl_client_init_full,
|
|
dnl libbearssl found, set the variable
|
|
[
|
|
AC_DEFINE(USE_BEARSSL, 1, [if BearSSL is enabled])
|
|
AC_SUBST(USE_BEARSSL, [1])
|
|
BEARSSL_ENABLED=1
|
|
USE_BEARSSL="yes"
|
|
ssl_msg="BearSSL"
|
|
test bearssl != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
], [], -lbearssl)
|
|
fi
|
|
|
|
addld=""
|
|
addlib=""
|
|
addcflags=""
|
|
bearssllib=""
|
|
|
|
if test "x$USE_BEARSSL" != "xyes"; then
|
|
dnl add the path and test again
|
|
addld=-L$OPT_BEARSSL/lib$libsuff
|
|
addcflags=-I$OPT_BEARSSL/include
|
|
bearssllib=$OPT_BEARSSL/lib$libsuff
|
|
|
|
LDFLAGS="$LDFLAGS $addld"
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
fi
|
|
|
|
AC_CHECK_LIB(bearssl, br_ssl_client_init_full,
|
|
[
|
|
AC_DEFINE(USE_BEARSSL, 1, [if BearSSL is enabled])
|
|
AC_SUBST(USE_BEARSSL, [1])
|
|
BEARSSL_ENABLED=1
|
|
USE_BEARSSL="yes"
|
|
ssl_msg="BearSSL"
|
|
test bearssl != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
CPPFLAGS=$_cppflags
|
|
LDFLAGS=$_ldflags
|
|
], -lbearssl)
|
|
fi
|
|
|
|
if test "x$USE_BEARSSL" = "xyes"; then
|
|
AC_MSG_NOTICE([detected BearSSL])
|
|
check_for_ca_bundle=1
|
|
|
|
LIBS="-lbearssl $LIBS"
|
|
|
|
if test -n "$bearssllib"; then
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$bearssllib"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $bearssllib to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
fi dnl BearSSL not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl check for rustls
|
|
dnl ----------------------------------------------------
|
|
|
|
OPT_RUSTLS=no
|
|
|
|
_cppflags=$CPPFLAGS
|
|
_ldflags=$LDFLAGS
|
|
AC_ARG_WITH(rustls,dnl
|
|
AC_HELP_STRING([--with-rustls=PATH],[where to look for rustls, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-rustls], [disable rustls detection]),
|
|
OPT_RUSTLS=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_RUSTLS" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_RUSTLS" != Xno; then
|
|
|
|
if test "$OPT_RUSTLS" = "yes"; then
|
|
OPT_RUSTLS=""
|
|
fi
|
|
|
|
if test -z "$OPT_RUSTLS" ; then
|
|
dnl check for lib first without setting any new path
|
|
|
|
AC_CHECK_LIB(crustls, rustls_client_session_read,
|
|
dnl libcrustls found, set the variable
|
|
[
|
|
AC_DEFINE(USE_RUSTLS, 1, [if rustls is enabled])
|
|
AC_SUBST(USE_RUSTLS, [1])
|
|
RUSTLS_ENABLED=1
|
|
USE_RUSTLS="yes"
|
|
ssl_msg="rustls"
|
|
test rustls != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
], [], -lpthread -ldl)
|
|
fi
|
|
|
|
addld=""
|
|
addlib="-lpthread"
|
|
addcflags=""
|
|
bearssllib=""
|
|
|
|
if test "x$USE_RUSTLS" != "xyes"; then
|
|
dnl add the path and test again
|
|
addld=-L$OPT_RUSTLS/lib$libsuff
|
|
addcflags=-I$OPT_RUSTLS/include
|
|
rustlslib=$OPT_RUSTLS/lib$libsuff
|
|
|
|
LDFLAGS="$LDFLAGS $addld"
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
fi
|
|
|
|
AC_CHECK_LIB(crustls, rustls_client_session_read,
|
|
[
|
|
AC_DEFINE(USE_RUSTLS, 1, [if rustls is enabled])
|
|
AC_SUBST(USE_RUSTLS, [1])
|
|
RUSTLS_ENABLED=1
|
|
USE_RUSTLS="yes"
|
|
ssl_msg="rustls"
|
|
test rustls != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
CPPFLAGS=$_cppflags
|
|
LDFLAGS=$_ldflags
|
|
], -lpthread -ldl)
|
|
fi
|
|
|
|
if test "x$USE_RUSTLS" = "xyes"; then
|
|
AC_MSG_NOTICE([detected rustls])
|
|
check_for_ca_bundle=1
|
|
|
|
LIBS="-lcrustls -lpthread -ldl $LIBS"
|
|
|
|
if test -n "$rustlslib"; then
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$rustlslib"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $rustlslib to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
fi dnl rustls not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
dnl ----------------------------------------------------
|
|
dnl NSS. Only check if GnuTLS and OpenSSL are not enabled
|
|
dnl ----------------------------------------------------
|
|
|
|
dnl Default to compiler & linker defaults for NSS files & libraries.
|
|
OPT_NSS=no
|
|
|
|
AC_ARG_WITH(nss,dnl
|
|
AC_HELP_STRING([--with-nss=PATH],[where to look for NSS, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-nss], [disable NSS detection]),
|
|
OPT_NSS=$withval)
|
|
|
|
if test -z "$ssl_backends" -o "x$OPT_NSS" != xno; then
|
|
ssl_msg=
|
|
|
|
if test X"$OPT_NSS" != Xno; then
|
|
|
|
addld=""
|
|
addlib=""
|
|
addcflags=""
|
|
nssprefix=""
|
|
version=""
|
|
|
|
if test "x$OPT_NSS" = "xyes"; then
|
|
|
|
CURL_CHECK_PKGCONFIG(nss)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
addlib=`$PKGCONFIG --libs nss`
|
|
addcflags=`$PKGCONFIG --cflags nss`
|
|
version=`$PKGCONFIG --modversion nss`
|
|
nssprefix=`$PKGCONFIG --variable=prefix nss`
|
|
else
|
|
dnl Without pkg-config, we check for nss-config
|
|
|
|
check=`nss-config --version 2>/dev/null`
|
|
if test -n "$check"; then
|
|
addlib=`nss-config --libs`
|
|
addcflags=`nss-config --cflags`
|
|
version=`nss-config --version`
|
|
nssprefix=`nss-config --prefix`
|
|
else
|
|
addlib="-lnss3"
|
|
addcflags=""
|
|
version="unknown"
|
|
fi
|
|
fi
|
|
else
|
|
NSS_PCDIR="$OPT_NSS/lib/pkgconfig"
|
|
if test -f "$NSS_PCDIR/nss.pc"; then
|
|
CURL_CHECK_PKGCONFIG(nss, [$NSS_PCDIR])
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
addld=`CURL_EXPORT_PCDIR([$NSS_PCDIR]) $PKGCONFIG --libs-only-L nss`
|
|
addlib=`CURL_EXPORT_PCDIR([$NSS_PCDIR]) $PKGCONFIG --libs-only-l nss`
|
|
addcflags=`CURL_EXPORT_PCDIR([$NSS_PCDIR]) $PKGCONFIG --cflags nss`
|
|
version=`CURL_EXPORT_PCDIR([$NSS_PCDIR]) $PKGCONFIG --modversion nss`
|
|
nssprefix=`CURL_EXPORT_PCDIR([$NSS_PCDIR]) $PKGCONFIG --variable=prefix nss`
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test -z "$addlib"; then
|
|
# Without pkg-config, we'll kludge in some defaults
|
|
AC_MSG_WARN([Using hard-wired libraries and compilation flags for NSS.])
|
|
addld="-L$OPT_NSS/lib"
|
|
addlib="-lssl3 -lsmime3 -lnss3 -lplds4 -lplc4 -lnspr4"
|
|
addcflags="-I$OPT_NSS/include"
|
|
version="unknown"
|
|
nssprefix=$OPT_NSS
|
|
fi
|
|
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
|
|
LDFLAGS="$addld $LDFLAGS"
|
|
LIBS="$addlib $LIBS"
|
|
if test "$addcflags" != "-I/usr/include"; then
|
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
|
fi
|
|
|
|
dnl The function SSL_VersionRangeSet() is needed to enable TLS > 1.0
|
|
AC_CHECK_LIB(nss3, SSL_VersionRangeSet,
|
|
[
|
|
AC_DEFINE(USE_NSS, 1, [if NSS is enabled])
|
|
AC_SUBST(USE_NSS, [1])
|
|
USE_NSS="yes"
|
|
NSS_ENABLED=1
|
|
ssl_msg="NSS"
|
|
test nss != "$DEFAULT_SSL_BACKEND" || VALID_DEFAULT_SSL_BACKEND=yes
|
|
],
|
|
[
|
|
LDFLAGS="$CLEANLDFLAGS"
|
|
LIBS="$CLEANLIBS"
|
|
CPPFLAGS="$CLEANCPPFLAGS"
|
|
])
|
|
|
|
if test "x$USE_NSS" = "xyes"; then
|
|
AC_MSG_NOTICE([detected NSS version $version])
|
|
|
|
dnl PK11_CreateManagedGenericObject() was introduced in NSS 3.34 because
|
|
dnl PK11_DestroyGenericObject() does not release resources allocated by
|
|
dnl PK11_CreateGenericObject() early enough.
|
|
AC_CHECK_FUNC(PK11_CreateManagedGenericObject,
|
|
[
|
|
AC_DEFINE(HAVE_PK11_CREATEMANAGEDGENERICOBJECT, 1,
|
|
[if you have the PK11_CreateManagedGenericObject function])
|
|
])
|
|
|
|
dnl needed when linking the curl tool without USE_EXPLICIT_LIB_DEPS
|
|
NSS_LIBS=$addlib
|
|
AC_SUBST([NSS_LIBS])
|
|
|
|
dnl when shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to
|
|
dnl CURL_LIBRARY_PATH to prevent further configure tests to fail
|
|
dnl due to this
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$nssprefix/lib$libsuff"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to CURL_LIBRARY_PATH])
|
|
fi
|
|
|
|
fi dnl NSS found
|
|
|
|
fi dnl NSS not disabled
|
|
|
|
test -z "$ssl_msg" || ssl_backends="${ssl_backends:+$ssl_backends, }$ssl_msg"
|
|
fi
|
|
|
|
case "x$OPENSSL_ENABLED$GNUTLS_ENABLED$NSS_ENABLED$MBEDTLS_ENABLED$WOLFSSL_ENABLED$SCHANNEL_ENABLED$SECURETRANSPORT_ENABLED$MESALINK_ENABLED$BEARSSL_ENABLED$AMISSL_ENABLED$RUSTLS_ENABLED"
|
|
in
|
|
x)
|
|
AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.])
|
|
AC_MSG_WARN([Use --with-ssl, --with-gnutls, --with-wolfssl, --with-mbedtls, --with-nss, --with-schannel, --with-secure-transport, --with-mesalink, --with-amissl or --with-bearssl to address this.])
|
|
;;
|
|
x1)
|
|
# one SSL backend is enabled
|
|
AC_SUBST(SSL_ENABLED)
|
|
SSL_ENABLED="1"
|
|
AC_MSG_NOTICE([built with one SSL backend])
|
|
;;
|
|
*)
|
|
# more than one SSL backend is enabled
|
|
AC_SUBST(SSL_ENABLED)
|
|
SSL_ENABLED="1"
|
|
AC_SUBST(CURL_WITH_MULTI_SSL)
|
|
CURL_WITH_MULTI_SSL="1"
|
|
AC_DEFINE(CURL_WITH_MULTI_SSL, 1, [built with multiple SSL backends])
|
|
AC_MSG_NOTICE([built with multiple SSL backends])
|
|
;;
|
|
esac
|
|
|
|
if test -n "$ssl_backends"; then
|
|
curl_ssl_msg="enabled ($ssl_backends)"
|
|
fi
|
|
|
|
if test no = "$VALID_DEFAULT_SSL_BACKEND"
|
|
then
|
|
if test -n "$SSL_ENABLED"
|
|
then
|
|
AC_MSG_ERROR([Default SSL backend $DEFAULT_SSL_BACKEND not enabled!])
|
|
else
|
|
AC_MSG_ERROR([Default SSL backend requires SSL!])
|
|
fi
|
|
elif test yes = "$VALID_DEFAULT_SSL_BACKEND"
|
|
then
|
|
AC_DEFINE_UNQUOTED([CURL_DEFAULT_SSL_BACKEND], ["$DEFAULT_SSL_BACKEND"], [Default SSL backend])
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the CA bundle
|
|
dnl **********************************************************************
|
|
|
|
if test -n "$check_for_ca_bundle"; then
|
|
CURL_CHECK_CA_BUNDLE
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for libpsl
|
|
dnl **********************************************************************
|
|
|
|
AC_ARG_WITH(libpsl,
|
|
AS_HELP_STRING([--without-libpsl],
|
|
[disable support for libpsl cookie checking]),
|
|
with_libpsl=$withval,
|
|
with_libpsl=yes)
|
|
if test $with_libpsl != "no"; then
|
|
AC_SEARCH_LIBS(psl_builtin, psl,
|
|
[curl_psl_msg="enabled";
|
|
AC_DEFINE([USE_LIBPSL], [1], [PSL support enabled])
|
|
],
|
|
[curl_psl_msg="no (libpsl not found)";
|
|
AC_MSG_WARN([libpsl was not found])
|
|
]
|
|
)
|
|
fi
|
|
AM_CONDITIONAL([USE_LIBPSL], [test "$curl_psl_msg" = "enabled"])
|
|
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for libgsasl
|
|
dnl **********************************************************************
|
|
|
|
AC_ARG_WITH(libgsasl,
|
|
AS_HELP_STRING([--without-libgsasl],
|
|
[disable libgsasl support for SCRAM]),
|
|
with_libgsasl=$withval,
|
|
with_libgsasl=yes)
|
|
if test $with_libgsasl != "no"; then
|
|
AC_SEARCH_LIBS(gsasl_init, gsasl,
|
|
[curl_gsasl_msg="enabled";
|
|
AC_DEFINE([USE_GSASL], [1], [GSASL support enabled])
|
|
],
|
|
[curl_gsasl_msg="no (libgsasl not found)";
|
|
AC_MSG_WARN([libgsasl was not found])
|
|
]
|
|
)
|
|
fi
|
|
AM_CONDITIONAL([USE_GSASL], [test "$curl_gsasl_msg" = "enabled"])
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for libmetalink
|
|
dnl **********************************************************************
|
|
|
|
OPT_LIBMETALINK=no
|
|
|
|
AC_ARG_WITH(libmetalink,dnl
|
|
AC_HELP_STRING([--with-libmetalink=PATH],[where to look for libmetalink, PATH points to the installation root])
|
|
AC_HELP_STRING([--without-libmetalink], [disable libmetalink detection]),
|
|
OPT_LIBMETALINK=$withval)
|
|
|
|
if test X"$OPT_LIBMETALINK" != Xno; then
|
|
|
|
addld=""
|
|
addlib=""
|
|
addcflags=""
|
|
version=""
|
|
libmetalinklib=""
|
|
|
|
PKGTEST="no"
|
|
if test "x$OPT_LIBMETALINK" = "xyes"; then
|
|
dnl this is with no partiular path given
|
|
PKGTEST="yes"
|
|
CURL_CHECK_PKGCONFIG(libmetalink)
|
|
else
|
|
dnl When particular path is given, set PKG_CONFIG_LIBDIR using the path.
|
|
LIBMETALINK_PCDIR="$OPT_LIBMETALINK/lib/pkgconfig"
|
|
AC_MSG_NOTICE([PKG_CONFIG_LIBDIR will be set to "$LIBMETALINK_PCDIR"])
|
|
if test -f "$LIBMETALINK_PCDIR/libmetalink.pc"; then
|
|
PKGTEST="yes"
|
|
fi
|
|
if test "$PKGTEST" = "yes"; then
|
|
CURL_CHECK_PKGCONFIG(libmetalink, [$LIBMETALINK_PCDIR])
|
|
fi
|
|
fi
|
|
if test "$PKGTEST" = "yes" && test "$PKGCONFIG" != "no"; then
|
|
addlib=`CURL_EXPORT_PCDIR([$LIBMETALINK_PCDIR]) dnl
|
|
$PKGCONFIG --libs-only-l libmetalink`
|
|
addld=`CURL_EXPORT_PCDIR([$LIBMETALINK_PCDIR]) dnl
|
|
$PKGCONFIG --libs-only-L libmetalink`
|
|
addcflags=`CURL_EXPORT_PCDIR([$LIBMETALINK_PCDIR]) dnl
|
|
$PKGCONFIG --cflags-only-I libmetalink`
|
|
version=`CURL_EXPORT_PCDIR([$LIBMETALINK_PCDIR]) dnl
|
|
$PKGCONFIG --modversion libmetalink`
|
|
libmetalinklib=`echo $addld | $SED -e 's/^-L//'`
|
|
fi
|
|
if test -n "$addlib"; then
|
|
|
|
clean_CPPFLAGS="$CPPFLAGS"
|
|
clean_LDFLAGS="$LDFLAGS"
|
|
clean_LIBS="$LIBS"
|
|
CPPFLAGS="$clean_CPPFLAGS $addcflags"
|
|
LDFLAGS="$clean_LDFLAGS $addld"
|
|
LIBS="$addlib $clean_LIBS"
|
|
AC_MSG_CHECKING([if libmetalink is recent enough])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
# include <metalink/metalink.h>
|
|
]],[[
|
|
if(0 != metalink_strerror(0)) /* added in 0.1.0 */
|
|
return 1;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes ($version)])
|
|
want_metalink="yes"
|
|
],[
|
|
AC_MSG_RESULT([no ($version)])
|
|
AC_MSG_NOTICE([libmetalink library defective or too old])
|
|
want_metalink="no"
|
|
])
|
|
if test "x$OPENSSL_ENABLED" != "x1" -a "x$USE_WINDOWS_SSPI" != "x1" \
|
|
-a "x$GNUTLS_ENABLED" != "x1" -a "x$NSS_ENABLED" != "x1" \
|
|
-a "x$SECURETRANSPORT_ENABLED" != "x1"; then
|
|
AC_MSG_WARN([metalink support requires a compatible SSL/TLS backend])
|
|
want_metalink="no"
|
|
fi
|
|
CPPFLAGS="$clean_CPPFLAGS"
|
|
LDFLAGS="$clean_LDFLAGS"
|
|
LIBS="$clean_LIBS"
|
|
if test "$want_metalink" = "yes"; then
|
|
dnl finally libmetalink will be used
|
|
AC_DEFINE(USE_METALINK, 1, [Define to enable metalink support])
|
|
LIBMETALINK_LIBS=$addlib
|
|
LIBMETALINK_LDFLAGS=$addld
|
|
LIBMETALINK_CPPFLAGS=$addcflags
|
|
AC_SUBST([LIBMETALINK_LIBS])
|
|
AC_SUBST([LIBMETALINK_LDFLAGS])
|
|
AC_SUBST([LIBMETALINK_CPPFLAGS])
|
|
curl_mtlnk_msg="enabled"
|
|
fi
|
|
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the presence of LIBSSH2 libraries and headers
|
|
dnl **********************************************************************
|
|
|
|
dnl Default to compiler & linker defaults for LIBSSH2 files & libraries.
|
|
OPT_LIBSSH2=off
|
|
AC_ARG_WITH(libssh2,dnl
|
|
AC_HELP_STRING([--with-libssh2=PATH],[Where to look for libssh2, PATH points to the libssh2 installation; when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--with-libssh2], [enable libssh2]),
|
|
OPT_LIBSSH2=$withval, OPT_LIBSSH2=no)
|
|
|
|
|
|
OPT_LIBSSH=off
|
|
AC_ARG_WITH(libssh,dnl
|
|
AC_HELP_STRING([--with-libssh=PATH],[Where to look for libssh, PATH points to the libssh installation; when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--with-libssh], [enable libssh]),
|
|
OPT_LIBSSH=$withval, OPT_LIBSSH=no)
|
|
|
|
OPT_WOLFSSH=off
|
|
AC_ARG_WITH(wolfssh,dnl
|
|
AC_HELP_STRING([--with-wolfssh=PATH],[Where to look for wolfssh, PATH points to the wolfSSH installation; when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--with-wolfssh], [enable wolfssh]),
|
|
OPT_WOLFSSH=$withval, OPT_WOLFSSH=no)
|
|
|
|
if test X"$OPT_LIBSSH2" != Xno; then
|
|
dnl backup the pre-libssh2 variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
case "$OPT_LIBSSH2" in
|
|
yes)
|
|
dnl --with-libssh2 (without path) used
|
|
CURL_CHECK_PKGCONFIG(libssh2)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_SSH2=`$PKGCONFIG --libs libssh2`
|
|
LD_SSH2=`$PKGCONFIG --libs-only-L libssh2`
|
|
CPP_SSH2=`$PKGCONFIG --cflags-only-I libssh2`
|
|
version=`$PKGCONFIG --modversion libssh2`
|
|
DIR_SSH2=`echo $LD_SSH2 | $SED -e 's/^-L//'`
|
|
fi
|
|
|
|
;;
|
|
off)
|
|
dnl no --with-libssh2 option given, just check default places
|
|
;;
|
|
*)
|
|
dnl use the given --with-libssh2 spot
|
|
PREFIX_SSH2=$OPT_LIBSSH2
|
|
;;
|
|
esac
|
|
|
|
dnl if given with a prefix, we set -L and -I based on that
|
|
if test -n "$PREFIX_SSH2"; then
|
|
LIB_SSH2="-lssh2"
|
|
LD_SSH2=-L${PREFIX_SSH2}/lib$libsuff
|
|
CPP_SSH2=-I${PREFIX_SSH2}/include
|
|
DIR_SSH2=${PREFIX_SSH2}/lib$libsuff
|
|
fi
|
|
|
|
LDFLAGS="$LDFLAGS $LD_SSH2"
|
|
CPPFLAGS="$CPPFLAGS $CPP_SSH2"
|
|
LIBS="$LIB_SSH2 $LIBS"
|
|
|
|
dnl check for function added in libssh2 version 1.0
|
|
AC_CHECK_LIB(ssh2, libssh2_session_block_directions)
|
|
|
|
AC_CHECK_HEADERS(libssh2.h,
|
|
curl_ssh_msg="enabled (libSSH2)"
|
|
LIBSSH2_ENABLED=1
|
|
AC_DEFINE(USE_LIBSSH2, 1, [if libSSH2 is in use])
|
|
AC_SUBST(USE_LIBSSH2, [1])
|
|
)
|
|
|
|
if test X"$OPT_LIBSSH2" != Xoff &&
|
|
test "$LIBSSH2_ENABLED" != "1"; then
|
|
AC_MSG_ERROR([libSSH2 libs and/or directories were not found where specified!])
|
|
fi
|
|
|
|
if test "$LIBSSH2_ENABLED" = "1"; then
|
|
if test -n "$DIR_SSH2"; then
|
|
dnl when the libssh2 shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to CURL_LIBRARY_PATH
|
|
dnl to prevent further configure tests to fail due to this
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_SSH2"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_SSH2 to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
else
|
|
dnl no libssh2, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
fi
|
|
elif test X"$OPT_LIBSSH" != Xno; then
|
|
dnl backup the pre-libssh variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
case "$OPT_LIBSSH" in
|
|
yes)
|
|
dnl --with-libssh (without path) used
|
|
CURL_CHECK_PKGCONFIG(libssh)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_SSH=`$PKGCONFIG --libs-only-l libssh`
|
|
LD_SSH=`$PKGCONFIG --libs-only-L libssh`
|
|
CPP_SSH=`$PKGCONFIG --cflags-only-I libssh`
|
|
version=`$PKGCONFIG --modversion libssh`
|
|
DIR_SSH=`echo $LD_SSH | $SED -e 's/^-L//'`
|
|
fi
|
|
|
|
;;
|
|
off)
|
|
dnl no --with-libssh option given, just check default places
|
|
;;
|
|
*)
|
|
dnl use the given --with-libssh spot
|
|
PREFIX_SSH=$OPT_LIBSSH
|
|
;;
|
|
esac
|
|
|
|
dnl if given with a prefix, we set -L and -I based on that
|
|
if test -n "$PREFIX_SSH"; then
|
|
LIB_SSH="-lssh"
|
|
LD_SSH=-L${PREFIX_SSH}/lib$libsuff
|
|
CPP_SSH=-I${PREFIX_SSH}/include
|
|
DIR_SSH=${PREFIX_SSH}/lib$libsuff
|
|
fi
|
|
|
|
LDFLAGS="$LDFLAGS $LD_SSH"
|
|
CPPFLAGS="$CPPFLAGS $CPP_SSH"
|
|
LIBS="$LIB_SSH $LIBS"
|
|
|
|
AC_CHECK_LIB(ssh, ssh_new)
|
|
|
|
AC_CHECK_HEADERS(libssh/libssh.h,
|
|
curl_ssh_msg="enabled (libSSH)"
|
|
LIBSSH_ENABLED=1
|
|
AC_DEFINE(USE_LIBSSH, 1, [if libSSH is in use])
|
|
AC_SUBST(USE_LIBSSH, [1])
|
|
)
|
|
|
|
if test X"$OPT_LIBSSH" != Xoff &&
|
|
test "$LIBSSH_ENABLED" != "1"; then
|
|
AC_MSG_ERROR([libSSH libs and/or directories were not found where specified!])
|
|
fi
|
|
|
|
if test "$LIBSSH_ENABLED" = "1"; then
|
|
if test -n "$DIR_SSH"; then
|
|
dnl when the libssh shared libs were found in a path that the run-time
|
|
dnl linker doesn't search through, we need to add it to CURL_LIBRARY_PATH
|
|
dnl to prevent further configure tests to fail due to this
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_SSH"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_SSH to CURL_LIBRARY_PATH])
|
|
fi
|
|
fi
|
|
else
|
|
dnl no libssh, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
fi
|
|
elif test X"$OPT_WOLFSSH" != Xno; then
|
|
dnl backup the pre-wolfssh variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
|
|
if test "$OPT_WOLFSSH" != yes; then
|
|
WOLFCONFIG="$OPT_WOLFSSH/bin/wolfssh-config"
|
|
LDFLAGS="$LDFLAGS `$WOLFCONFIG --libs`"
|
|
CPPFLAGS="$CPPFLAGS `$WOLFCONFIG --cflags`"
|
|
fi
|
|
|
|
AC_CHECK_LIB(wolfssh, wolfSSH_Init)
|
|
|
|
AC_CHECK_HEADERS(wolfssh/ssh.h,
|
|
curl_ssh_msg="enabled (wolfSSH)"
|
|
WOLFSSH_ENABLED=1
|
|
AC_DEFINE(USE_WOLFSSH, 1, [if wolfSSH is in use])
|
|
AC_SUBST(USE_WOLFSSH, [1])
|
|
)
|
|
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the presence of LIBRTMP libraries and headers
|
|
dnl **********************************************************************
|
|
|
|
dnl Default to compiler & linker defaults for LIBRTMP files & libraries.
|
|
OPT_LIBRTMP=off
|
|
AC_ARG_WITH(librtmp,dnl
|
|
AC_HELP_STRING([--with-librtmp=PATH],[Where to look for librtmp, PATH points to the LIBRTMP installation; when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
|
AC_HELP_STRING([--without-librtmp], [disable LIBRTMP]),
|
|
OPT_LIBRTMP=$withval)
|
|
|
|
if test X"$OPT_LIBRTMP" != Xno; then
|
|
dnl backup the pre-librtmp variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
case "$OPT_LIBRTMP" in
|
|
yes)
|
|
dnl --with-librtmp (without path) used
|
|
CURL_CHECK_PKGCONFIG(librtmp)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_RTMP=`$PKGCONFIG --libs-only-l librtmp`
|
|
LD_RTMP=`$PKGCONFIG --libs-only-L librtmp`
|
|
CPP_RTMP=`$PKGCONFIG --cflags-only-I librtmp`
|
|
version=`$PKGCONFIG --modversion librtmp`
|
|
DIR_RTMP=`echo $LD_RTMP | $SED -e 's/^-L//'`
|
|
else
|
|
dnl To avoid link errors, we do not allow --librtmp without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--librtmp was specified but could not find librtmp pkgconfig file.])
|
|
fi
|
|
|
|
;;
|
|
off)
|
|
dnl no --with-librtmp option given, just check default places
|
|
LIB_RTMP="-lrtmp"
|
|
;;
|
|
*)
|
|
dnl use the given --with-librtmp spot
|
|
LIB_RTMP="-lrtmp"
|
|
PREFIX_RTMP=$OPT_LIBRTMP
|
|
;;
|
|
esac
|
|
|
|
dnl if given with a prefix, we set -L and -I based on that
|
|
if test -n "$PREFIX_RTMP"; then
|
|
LD_RTMP=-L${PREFIX_RTMP}/lib$libsuff
|
|
CPP_RTMP=-I${PREFIX_RTMP}/include
|
|
DIR_RTMP=${PREFIX_RTMP}/lib$libsuff
|
|
fi
|
|
|
|
LDFLAGS="$LDFLAGS $LD_RTMP"
|
|
CPPFLAGS="$CPPFLAGS $CPP_RTMP"
|
|
LIBS="$LIB_RTMP $LIBS"
|
|
|
|
AC_CHECK_LIB(rtmp, RTMP_Init,
|
|
[
|
|
AC_CHECK_HEADERS(librtmp/rtmp.h,
|
|
curl_rtmp_msg="enabled (librtmp)"
|
|
LIBRTMP_ENABLED=1
|
|
AC_DEFINE(USE_LIBRTMP, 1, [if librtmp is in use])
|
|
AC_SUBST(USE_LIBRTMP, [1])
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
|
|
if test X"$OPT_LIBRTMP" != Xoff &&
|
|
test "$LIBRTMP_ENABLED" != "1"; then
|
|
AC_MSG_ERROR([librtmp libs and/or directories were not found where specified!])
|
|
fi
|
|
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for linker switch for versioned symbols
|
|
dnl **********************************************************************
|
|
|
|
versioned_symbols_flavour=
|
|
AC_MSG_CHECKING([whether versioned symbols are wanted])
|
|
AC_ARG_ENABLE(versioned-symbols,
|
|
AC_HELP_STRING([--enable-versioned-symbols], [Enable versioned symbols in shared library])
|
|
AC_HELP_STRING([--disable-versioned-symbols], [Disable versioned symbols in shared library]),
|
|
[ case "$enableval" in
|
|
yes) AC_MSG_RESULT(yes)
|
|
AC_MSG_CHECKING([if libraries can be versioned])
|
|
GLD=`$LD --help < /dev/null 2>/dev/null | grep version-script`
|
|
if test -z "$GLD"; then
|
|
AC_MSG_RESULT(no)
|
|
AC_MSG_WARN([You need an ld version supporting the --version-script option])
|
|
else
|
|
AC_MSG_RESULT(yes)
|
|
if test "x$CURL_WITH_MULTI_SSL" = "x1"; then
|
|
versioned_symbols_flavour="MULTISSL_"
|
|
elif test "x$OPENSSL_ENABLED" = "x1"; then
|
|
versioned_symbols_flavour="OPENSSL_"
|
|
elif test "x$GNUTLS_ENABLED" = "x1"; then
|
|
versioned_symbols_flavour="GNUTLS_"
|
|
elif test "x$NSS_ENABLED" = "x1"; then
|
|
versioned_symbols_flavour="NSS_"
|
|
elif test "x$WOLFSSL_ENABLED" = "x1"; then
|
|
versioned_symbols_flavour="WOLFSSL_"
|
|
elif test "x$SCHANNEL_ENABLED" = "x1"; then
|
|
versioned_symbols_flavour="SCHANNEL_"
|
|
elif test "x$SECURETRANSPORT_ENABLED" = "x1"; then
|
|
versioned_symbols_flavour="SECURE_TRANSPORT_"
|
|
else
|
|
versioned_symbols_flavour=""
|
|
fi
|
|
versioned_symbols="yes"
|
|
fi
|
|
;;
|
|
|
|
*) AC_MSG_RESULT(no)
|
|
;;
|
|
esac
|
|
], [
|
|
AC_MSG_RESULT(no)
|
|
]
|
|
)
|
|
|
|
AC_SUBST([CURL_LT_SHLIB_VERSIONED_FLAVOUR],
|
|
["$versioned_symbols_flavour"])
|
|
AM_CONDITIONAL([CURL_LT_SHLIB_USE_VERSIONED_SYMBOLS],
|
|
[test "x$versioned_symbols" = 'xyes'])
|
|
|
|
dnl -------------------------------------------------
|
|
dnl check winidn option before other IDN libraries
|
|
dnl -------------------------------------------------
|
|
|
|
AC_MSG_CHECKING([whether to enable Windows native IDN (Windows native builds only)])
|
|
OPT_WINIDN="default"
|
|
AC_ARG_WITH(winidn,
|
|
AC_HELP_STRING([--with-winidn=PATH],[enable Windows native IDN])
|
|
AC_HELP_STRING([--without-winidn], [disable Windows native IDN]),
|
|
OPT_WINIDN=$withval)
|
|
case "$OPT_WINIDN" in
|
|
no|default)
|
|
dnl --without-winidn option used or configure option not specified
|
|
want_winidn="no"
|
|
AC_MSG_RESULT([no])
|
|
;;
|
|
yes)
|
|
dnl --with-winidn option used without path
|
|
want_winidn="yes"
|
|
want_winidn_path="default"
|
|
AC_MSG_RESULT([yes])
|
|
;;
|
|
*)
|
|
dnl --with-winidn option used with path
|
|
want_winidn="yes"
|
|
want_winidn_path="$withval"
|
|
AC_MSG_RESULT([yes ($withval)])
|
|
;;
|
|
esac
|
|
|
|
if test "$want_winidn" = "yes"; then
|
|
dnl winidn library support has been requested
|
|
clean_CPPFLAGS="$CPPFLAGS"
|
|
clean_LDFLAGS="$LDFLAGS"
|
|
clean_LIBS="$LIBS"
|
|
WINIDN_LIBS="-lnormaliz"
|
|
WINIDN_CPPFLAGS="-DWINVER=0x0600"
|
|
#
|
|
if test "$want_winidn_path" != "default"; then
|
|
dnl path has been specified
|
|
dnl pkg-config not available or provides no info
|
|
WINIDN_LDFLAGS="-L$want_winidn_path/lib$libsuff"
|
|
WINIDN_CPPFLAGS="-I$want_winidn_path/include"
|
|
WINIDN_DIR="$want_winidn_path/lib$libsuff"
|
|
fi
|
|
#
|
|
CPPFLAGS="$CPPFLAGS $WINIDN_CPPFLAGS"
|
|
LDFLAGS="$LDFLAGS $WINIDN_LDFLAGS"
|
|
LIBS="$WINIDN_LIBS $LIBS"
|
|
#
|
|
AC_MSG_CHECKING([if IdnToUnicode can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
#include <windows.h>
|
|
]],[[
|
|
IdnToUnicode(0, NULL, 0, NULL, 0);
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_winidn="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_winidn="no"
|
|
])
|
|
#
|
|
if test "$tst_links_winidn" = "yes"; then
|
|
AC_DEFINE(USE_WIN32_IDN, 1, [Define to 1 if you have the `normaliz' (WinIDN) library (-lnormaliz).])
|
|
AC_DEFINE(WANT_IDN_PROTOTYPES, 1, [Define to 1 to provide own prototypes.])
|
|
AC_SUBST([IDN_ENABLED], [1])
|
|
curl_idn_msg="enabled (Windows-native)"
|
|
else
|
|
AC_MSG_WARN([Cannot find libraries for IDN support: IDN disabled])
|
|
CPPFLAGS="$clean_CPPFLAGS"
|
|
LDFLAGS="$clean_LDFLAGS"
|
|
LIBS="$clean_LIBS"
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for the presence of IDN libraries and headers
|
|
dnl **********************************************************************
|
|
|
|
AC_MSG_CHECKING([whether to build with libidn2])
|
|
OPT_IDN="default"
|
|
AC_ARG_WITH(libidn2,
|
|
AC_HELP_STRING([--with-libidn2=PATH],[Enable libidn2 usage])
|
|
AC_HELP_STRING([--without-libidn2],[Disable libidn2 usage]),
|
|
[OPT_IDN=$withval])
|
|
case "$OPT_IDN" in
|
|
no)
|
|
dnl --without-libidn2 option used
|
|
want_idn="no"
|
|
AC_MSG_RESULT([no])
|
|
;;
|
|
default)
|
|
dnl configure option not specified
|
|
want_idn="yes"
|
|
want_idn_path="default"
|
|
AC_MSG_RESULT([(assumed) yes])
|
|
;;
|
|
yes)
|
|
dnl --with-libidn2 option used without path
|
|
want_idn="yes"
|
|
want_idn_path="default"
|
|
AC_MSG_RESULT([yes])
|
|
;;
|
|
*)
|
|
dnl --with-libidn2 option used with path
|
|
want_idn="yes"
|
|
want_idn_path="$withval"
|
|
AC_MSG_RESULT([yes ($withval)])
|
|
;;
|
|
esac
|
|
|
|
if test "$want_idn" = "yes"; then
|
|
dnl idn library support has been requested
|
|
clean_CPPFLAGS="$CPPFLAGS"
|
|
clean_LDFLAGS="$LDFLAGS"
|
|
clean_LIBS="$LIBS"
|
|
PKGCONFIG="no"
|
|
#
|
|
if test "$want_idn_path" != "default"; then
|
|
dnl path has been specified
|
|
IDN_PCDIR="$want_idn_path/lib$libsuff/pkgconfig"
|
|
CURL_CHECK_PKGCONFIG(libidn2, [$IDN_PCDIR])
|
|
if test "$PKGCONFIG" != "no"; then
|
|
IDN_LIBS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl
|
|
$PKGCONFIG --libs-only-l libidn2 2>/dev/null`
|
|
IDN_LDFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl
|
|
$PKGCONFIG --libs-only-L libidn2 2>/dev/null`
|
|
IDN_CPPFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl
|
|
$PKGCONFIG --cflags-only-I libidn2 2>/dev/null`
|
|
IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/^-L//'`
|
|
else
|
|
dnl pkg-config not available or provides no info
|
|
IDN_LIBS="-lidn2"
|
|
IDN_LDFLAGS="-L$want_idn_path/lib$libsuff"
|
|
IDN_CPPFLAGS="-I$want_idn_path/include"
|
|
IDN_DIR="$want_idn_path/lib$libsuff"
|
|
fi
|
|
else
|
|
dnl path not specified
|
|
CURL_CHECK_PKGCONFIG(libidn2)
|
|
if test "$PKGCONFIG" != "no"; then
|
|
IDN_LIBS=`$PKGCONFIG --libs-only-l libidn2 2>/dev/null`
|
|
IDN_LDFLAGS=`$PKGCONFIG --libs-only-L libidn2 2>/dev/null`
|
|
IDN_CPPFLAGS=`$PKGCONFIG --cflags-only-I libidn2 2>/dev/null`
|
|
IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/^-L//'`
|
|
else
|
|
dnl pkg-config not available or provides no info
|
|
IDN_LIBS="-lidn2"
|
|
fi
|
|
fi
|
|
#
|
|
if test "$PKGCONFIG" != "no"; then
|
|
AC_MSG_NOTICE([pkg-config: IDN_LIBS: "$IDN_LIBS"])
|
|
AC_MSG_NOTICE([pkg-config: IDN_LDFLAGS: "$IDN_LDFLAGS"])
|
|
AC_MSG_NOTICE([pkg-config: IDN_CPPFLAGS: "$IDN_CPPFLAGS"])
|
|
AC_MSG_NOTICE([pkg-config: IDN_DIR: "$IDN_DIR"])
|
|
else
|
|
AC_MSG_NOTICE([IDN_LIBS: "$IDN_LIBS"])
|
|
AC_MSG_NOTICE([IDN_LDFLAGS: "$IDN_LDFLAGS"])
|
|
AC_MSG_NOTICE([IDN_CPPFLAGS: "$IDN_CPPFLAGS"])
|
|
AC_MSG_NOTICE([IDN_DIR: "$IDN_DIR"])
|
|
fi
|
|
#
|
|
CPPFLAGS="$CPPFLAGS $IDN_CPPFLAGS"
|
|
LDFLAGS="$LDFLAGS $IDN_LDFLAGS"
|
|
LIBS="$IDN_LIBS $LIBS"
|
|
#
|
|
AC_MSG_CHECKING([if idn2_lookup_ul can be linked])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_FUNC_LINK_TRY([idn2_lookup_ul])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
tst_links_libidn="yes"
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
tst_links_libidn="no"
|
|
])
|
|
#
|
|
AC_CHECK_HEADERS( idn2.h )
|
|
|
|
if test "$tst_links_libidn" = "yes"; then
|
|
AC_DEFINE(HAVE_LIBIDN2, 1, [Define to 1 if you have the `idn2' library (-lidn2).])
|
|
dnl different versions of libidn have different setups of these:
|
|
|
|
AC_SUBST([IDN_ENABLED], [1])
|
|
curl_idn_msg="enabled (libidn2)"
|
|
if test -n "$IDN_DIR" -a "x$cross_compiling" != "xyes"; then
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$IDN_DIR"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $IDN_DIR to CURL_LIBRARY_PATH])
|
|
fi
|
|
else
|
|
AC_MSG_WARN([Cannot find libraries for IDN support: IDN disabled])
|
|
CPPFLAGS="$clean_CPPFLAGS"
|
|
LDFLAGS="$clean_LDFLAGS"
|
|
LIBS="$clean_LIBS"
|
|
fi
|
|
fi
|
|
|
|
|
|
dnl Let's hope this split URL remains working:
|
|
dnl https://www15.software.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \
|
|
dnl genprogc/thread_quick_ref.htm
|
|
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for nghttp2
|
|
dnl **********************************************************************
|
|
|
|
OPT_H2="yes"
|
|
|
|
if test "x$disable_http" = "xyes"; then
|
|
# without HTTP, nghttp2 is no use
|
|
OPT_H2="no"
|
|
fi
|
|
|
|
AC_ARG_WITH(nghttp2,
|
|
AC_HELP_STRING([--with-nghttp2=PATH],[Enable nghttp2 usage])
|
|
AC_HELP_STRING([--without-nghttp2],[Disable nghttp2 usage]),
|
|
[OPT_H2=$withval])
|
|
case "$OPT_H2" in
|
|
no)
|
|
dnl --without-nghttp2 option used
|
|
want_h2="no"
|
|
;;
|
|
yes)
|
|
dnl --with-nghttp2 option used without path
|
|
want_h2="default"
|
|
want_h2_path=""
|
|
;;
|
|
*)
|
|
dnl --with-nghttp2 option used with path
|
|
want_h2="yes"
|
|
want_h2_path="$withval/lib/pkgconfig"
|
|
;;
|
|
esac
|
|
|
|
if test X"$want_h2" != Xno; then
|
|
dnl backup the pre-nghttp2 variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(libnghttp2, $want_h2_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_H2=`CURL_EXPORT_PCDIR([$want_h2_path])
|
|
$PKGCONFIG --libs-only-l libnghttp2`
|
|
AC_MSG_NOTICE([-l is $LIB_H2])
|
|
|
|
CPP_H2=`CURL_EXPORT_PCDIR([$want_h2_path]) dnl
|
|
$PKGCONFIG --cflags-only-I libnghttp2`
|
|
AC_MSG_NOTICE([-I is $CPP_H2])
|
|
|
|
LD_H2=`CURL_EXPORT_PCDIR([$want_h2_path])
|
|
$PKGCONFIG --libs-only-L libnghttp2`
|
|
AC_MSG_NOTICE([-L is $LD_H2])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_H2"
|
|
CPPFLAGS="$CPPFLAGS $CPP_H2"
|
|
LIBS="$LIB_H2 $LIBS"
|
|
|
|
# use nghttp2_session_set_local_window_size to require nghttp2
|
|
# >= 1.12.0
|
|
AC_CHECK_LIB(nghttp2, nghttp2_session_set_local_window_size,
|
|
[
|
|
AC_CHECK_HEADERS(nghttp2/nghttp2.h,
|
|
curl_h2_msg="enabled (nghttp2)"
|
|
NGHTTP2_ENABLED=1
|
|
AC_DEFINE(USE_NGHTTP2, 1, [if nghttp2 is in use])
|
|
AC_SUBST(USE_NGHTTP2, [1])
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
|
|
else
|
|
dnl no nghttp2 pkg-config found, deal with it
|
|
if test X"$want_h2" != Xdefault; then
|
|
dnl To avoid link errors, we do not allow --with-nghttp2 without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--with-nghttp2 was specified but could not find libnghttp2 pkg-config file.])
|
|
fi
|
|
fi
|
|
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for ngtcp2 (QUIC)
|
|
dnl **********************************************************************
|
|
|
|
OPT_TCP2="yes"
|
|
|
|
if test "x$disable_http" = "xyes"; then
|
|
# without HTTP, ngtcp2 is no use
|
|
OPT_TCP2="no"
|
|
fi
|
|
|
|
AC_ARG_WITH(ngtcp2,
|
|
AC_HELP_STRING([--with-ngtcp2=PATH],[Enable ngtcp2 usage])
|
|
AC_HELP_STRING([--without-ngtcp2],[Disable ngtcp2 usage]),
|
|
[OPT_TCP2=$withval])
|
|
case "$OPT_TCP2" in
|
|
no)
|
|
dnl --without-ngtcp2 option used
|
|
want_tcp2="no"
|
|
;;
|
|
yes)
|
|
dnl --with-ngtcp2 option used without path
|
|
want_tcp2="default"
|
|
want_tcp2_path=""
|
|
;;
|
|
*)
|
|
dnl --with-ngtcp2 option used with path
|
|
want_tcp2="yes"
|
|
want_tcp2_path="$withval/lib/pkgconfig"
|
|
;;
|
|
esac
|
|
|
|
curl_tcp2_msg="no (--with-ngtcp2)"
|
|
if test X"$want_tcp2" != Xno; then
|
|
dnl backup the pre-ngtcp2 variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(libngtcp2, $want_tcp2_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_TCP2=`CURL_EXPORT_PCDIR([$want_tcp2_path])
|
|
$PKGCONFIG --libs-only-l libngtcp2`
|
|
AC_MSG_NOTICE([-l is $LIB_TCP2])
|
|
|
|
CPP_TCP2=`CURL_EXPORT_PCDIR([$want_tcp2_path]) dnl
|
|
$PKGCONFIG --cflags-only-I libngtcp2`
|
|
AC_MSG_NOTICE([-I is $CPP_TCP2])
|
|
|
|
LD_TCP2=`CURL_EXPORT_PCDIR([$want_tcp2_path])
|
|
$PKGCONFIG --libs-only-L libngtcp2`
|
|
AC_MSG_NOTICE([-L is $LD_TCP2])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_TCP2"
|
|
CPPFLAGS="$CPPFLAGS $CPP_TCP2"
|
|
LIBS="$LIB_TCP2 $LIBS"
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
DIR_TCP2=`echo $LD_TCP2 | $SED -e 's/^-L//'`
|
|
fi
|
|
AC_CHECK_LIB(ngtcp2, ngtcp2_conn_client_new,
|
|
[
|
|
AC_CHECK_HEADERS(ngtcp2/ngtcp2.h,
|
|
NGTCP2_ENABLED=1
|
|
AC_DEFINE(USE_NGTCP2, 1, [if ngtcp2 is in use])
|
|
AC_SUBST(USE_NGTCP2, [1])
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_TCP2"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_TCP2 to CURL_LIBRARY_PATH])
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
|
|
else
|
|
dnl no ngtcp2 pkg-config found, deal with it
|
|
if test X"$want_tcp2" != Xdefault; then
|
|
dnl To avoid link errors, we do not allow --with-ngtcp2 without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--with-ngtcp2 was specified but could not find ngtcp2 pkg-config file.])
|
|
fi
|
|
fi
|
|
|
|
fi
|
|
|
|
if test "x$NGTCP2_ENABLED" = "x1" -a "x$OPENSSL_ENABLED" = "x1"; then
|
|
dnl backup the pre-ngtcp2_crypto_openssl variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(libngtcp2_crypto_openssl, $want_tcp2_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_NGTCP2_CRYPTO_OPENSSL=`CURL_EXPORT_PCDIR([$want_tcp2_path])
|
|
$PKGCONFIG --libs-only-l libngtcp2_crypto_openssl`
|
|
AC_MSG_NOTICE([-l is $LIB_NGTCP2_CRYPTO_OPENSSL])
|
|
|
|
CPP_NGTCP2_CRYPTO_OPENSSL=`CURL_EXPORT_PCDIR([$want_tcp2_path]) dnl
|
|
$PKGCONFIG --cflags-only-I libngtcp2_crypto_openssl`
|
|
AC_MSG_NOTICE([-I is $CPP_NGTCP2_CRYPTO_OPENSSL])
|
|
|
|
LD_NGTCP2_CRYPTO_OPENSSL=`CURL_EXPORT_PCDIR([$want_tcp2_path])
|
|
$PKGCONFIG --libs-only-L libngtcp2_crypto_openssl`
|
|
AC_MSG_NOTICE([-L is $LD_NGTCP2_CRYPTO_OPENSSL])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_NGTCP2_CRYPTO_OPENSSL"
|
|
CPPFLAGS="$CPPFLAGS $CPP_NGTCP2_CRYPTO_OPENSSL"
|
|
LIBS="$LIB_NGTCP2_CRYPTO_OPENSSL $LIBS"
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
DIR_NGTCP2_CRYPTO_OPENSSL=`echo $LD_NGTCP2_CRYPTO_OPENSSL | $SED -e 's/^-L//'`
|
|
fi
|
|
AC_CHECK_LIB(ngtcp2_crypto_openssl, ngtcp2_crypto_ctx_initial,
|
|
[
|
|
AC_CHECK_HEADERS(ngtcp2/ngtcp2_crypto.h,
|
|
NGTCP2_ENABLED=1
|
|
AC_DEFINE(USE_NGTCP2_CRYPTO_OPENSSL, 1, [if ngtcp2_crypto_openssl is in use])
|
|
AC_SUBST(USE_NGTCP2_CRYPTO_OPENSSL, [1])
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_NGTCP2_CRYPTO_OPENSSL"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_NGTCP2_CRYPTO_OPENSSL to CURL_LIBRARY_PATH])
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
|
|
else
|
|
dnl no ngtcp2_crypto_openssl pkg-config found, deal with it
|
|
if test X"$want_tcp2" != Xdefault; then
|
|
dnl To avoid link errors, we do not allow --with-ngtcp2 without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--with-ngtcp2 was specified but could not find ngtcp2_crypto_openssl pkg-config file.])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test "x$NGTCP2_ENABLED" = "x1" -a "x$GNUTLS_ENABLED" = "x1"; then
|
|
dnl backup the pre-ngtcp2_crypto_gnutls variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(libngtcp2_crypto_gnutls, $want_tcp2_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_NGTCP2_CRYPTO_GNUTLS=`CURL_EXPORT_PCDIR([$want_tcp2_path])
|
|
$PKGCONFIG --libs-only-l libngtcp2_crypto_gnutls`
|
|
AC_MSG_NOTICE([-l is $LIB_NGTCP2_CRYPTO_GNUTLS])
|
|
|
|
CPP_NGTCP2_CRYPTO_GNUTLS=`CURL_EXPORT_PCDIR([$want_tcp2_path]) dnl
|
|
$PKGCONFIG --cflags-only-I libngtcp2_crypto_gnutls`
|
|
AC_MSG_NOTICE([-I is $CPP_NGTCP2_CRYPTO_GNUTLS])
|
|
|
|
LD_NGTCP2_CRYPTO_GNUTLS=`CURL_EXPORT_PCDIR([$want_tcp2_path])
|
|
$PKGCONFIG --libs-only-L libngtcp2_crypto_gnutls`
|
|
AC_MSG_NOTICE([-L is $LD_NGTCP2_CRYPTO_GNUTLS])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_NGTCP2_CRYPTO_GNUTLS"
|
|
CPPFLAGS="$CPPFLAGS $CPP_NGTCP2_CRYPTO_GNUTLS"
|
|
LIBS="$LIB_NGTCP2_CRYPTO_GNUTLS $LIBS"
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
DIR_NGTCP2_CRYPTO_GNUTLS=`echo $LD_NGTCP2_CRYPTO_GNUTLS | $SED -e 's/^-L//'`
|
|
fi
|
|
AC_CHECK_LIB(ngtcp2_crypto_gnutls, ngtcp2_crypto_ctx_initial,
|
|
[
|
|
AC_CHECK_HEADERS(ngtcp2/ngtcp2_crypto.h,
|
|
NGTCP2_ENABLED=1
|
|
AC_DEFINE(USE_NGTCP2_CRYPTO_GNUTLS, 1, [if ngtcp2_crypto_gnutls is in use])
|
|
AC_SUBST(USE_NGTCP2_CRYPTO_GNUTLS, [1])
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_NGTCP2_CRYPTO_GNUTLS"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_NGTCP2_CRYPTO_GNUTLS to CURL_LIBRARY_PATH])
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
|
|
else
|
|
dnl no ngtcp2_crypto_gnutls pkg-config found, deal with it
|
|
if test X"$want_tcp2" != Xdefault; then
|
|
dnl To avoid link errors, we do not allow --with-ngtcp2 without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--with-ngtcp2 was specified but could not find ngtcp2_crypto_gnutls pkg-config file.])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for nghttp3 (HTTP/3 with ngtcp2)
|
|
dnl **********************************************************************
|
|
|
|
OPT_NGHTTP3="yes"
|
|
|
|
if test "x$NGTCP2_ENABLED" = "x"; then
|
|
# without ngtcp2, nghttp3 is of no use for us
|
|
OPT_NGHTTP3="no"
|
|
fi
|
|
|
|
AC_ARG_WITH(nghttp3,
|
|
AC_HELP_STRING([--with-nghttp3=PATH],[Enable nghttp3 usage])
|
|
AC_HELP_STRING([--without-nghttp3],[Disable nghttp3 usage]),
|
|
[OPT_NGHTTP3=$withval])
|
|
case "$OPT_NGHTTP3" in
|
|
no)
|
|
dnl --without-nghttp3 option used
|
|
want_nghttp3="no"
|
|
;;
|
|
yes)
|
|
dnl --with-nghttp3 option used without path
|
|
want_nghttp3="default"
|
|
want_nghttp3_path=""
|
|
;;
|
|
*)
|
|
dnl --with-nghttp3 option used with path
|
|
want_nghttp3="yes"
|
|
want_nghttp3_path="$withval/lib/pkgconfig"
|
|
;;
|
|
esac
|
|
|
|
curl_http3_msg="no (--with-nghttp3)"
|
|
if test X"$want_nghttp3" != Xno; then
|
|
dnl backup the pre-nghttp3 variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(libnghttp3, $want_nghttp3_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_NGHTTP3=`CURL_EXPORT_PCDIR([$want_nghttp3_path])
|
|
$PKGCONFIG --libs-only-l libnghttp3`
|
|
AC_MSG_NOTICE([-l is $LIB_NGHTTP3])
|
|
|
|
CPP_NGHTTP3=`CURL_EXPORT_PCDIR([$want_nghttp3_path]) dnl
|
|
$PKGCONFIG --cflags-only-I libnghttp3`
|
|
AC_MSG_NOTICE([-I is $CPP_NGHTTP3])
|
|
|
|
LD_NGHTTP3=`CURL_EXPORT_PCDIR([$want_nghttp3_path])
|
|
$PKGCONFIG --libs-only-L libnghttp3`
|
|
AC_MSG_NOTICE([-L is $LD_NGHTTP3])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_NGHTTP3"
|
|
CPPFLAGS="$CPPFLAGS $CPP_NGHTTP3"
|
|
LIBS="$LIB_NGHTTP3 $LIBS"
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
DIR_NGHTTP3=`echo $LD_NGHTTP3 | $SED -e 's/^-L//'`
|
|
fi
|
|
AC_CHECK_LIB(nghttp3, nghttp3_conn_client_new,
|
|
[
|
|
AC_CHECK_HEADERS(nghttp3/nghttp3.h,
|
|
curl_h3_msg="enabled (ngtcp2 + nghttp3)"
|
|
NGHTTP3_ENABLED=1
|
|
AC_DEFINE(USE_NGHTTP3, 1, [if nghttp3 is in use])
|
|
AC_SUBST(USE_NGHTTP3, [1])
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_NGHTTP3"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_NGHTTP3 to CURL_LIBRARY_PATH])
|
|
experimental="$experimental HTTP3"
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
|
|
else
|
|
dnl no nghttp3 pkg-config found, deal with it
|
|
if test X"$want_nghttp3" != Xdefault; then
|
|
dnl To avoid link errors, we do not allow --with-nghttp3 without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--with-nghttp3 was specified but could not find nghttp3 pkg-config file.])
|
|
fi
|
|
fi
|
|
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for quiche (QUIC)
|
|
dnl **********************************************************************
|
|
|
|
OPT_QUICHE="yes"
|
|
|
|
if test "x$disable_http" = "xyes" -o "x$USE_NGTCP" = "x1"; then
|
|
# without HTTP or with ngtcp2, quiche is no use
|
|
OPT_QUICHE="no"
|
|
fi
|
|
|
|
AC_ARG_WITH(quiche,
|
|
AC_HELP_STRING([--with-quiche=PATH],[Enable quiche usage])
|
|
AC_HELP_STRING([--without-quiche],[Disable quiche usage]),
|
|
[OPT_QUICHE=$withval])
|
|
case "$OPT_QUICHE" in
|
|
no)
|
|
dnl --without-quiche option used
|
|
want_quiche="no"
|
|
;;
|
|
yes)
|
|
dnl --with-quiche option used without path
|
|
want_quiche="default"
|
|
want_quiche_path=""
|
|
;;
|
|
*)
|
|
dnl --with-quiche option used with path
|
|
want_quiche="yes"
|
|
want_quiche_path="$withval"
|
|
;;
|
|
esac
|
|
|
|
if test X"$want_quiche" != Xno; then
|
|
dnl backup the pre-quiche variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(quiche, $want_quiche_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_QUICHE=`CURL_EXPORT_PCDIR([$want_quiche_path])
|
|
$PKGCONFIG --libs-only-l quiche`
|
|
AC_MSG_NOTICE([-l is $LIB_QUICHE])
|
|
|
|
CPP_QUICHE=`CURL_EXPORT_PCDIR([$want_quiche_path]) dnl
|
|
$PKGCONFIG --cflags-only-I quiche`
|
|
AC_MSG_NOTICE([-I is $CPP_QUICHE])
|
|
|
|
LD_QUICHE=`CURL_EXPORT_PCDIR([$want_quiche_path])
|
|
$PKGCONFIG --libs-only-L quiche`
|
|
AC_MSG_NOTICE([-L is $LD_QUICHE])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_QUICHE"
|
|
CPPFLAGS="$CPPFLAGS $CPP_QUICHE"
|
|
LIBS="$LIB_QUICHE $LIBS"
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
DIR_QUICHE=`echo $LD_QUICHE | $SED -e 's/^-L//'`
|
|
fi
|
|
AC_CHECK_LIB(quiche, quiche_connect,
|
|
[
|
|
AC_CHECK_HEADERS(quiche.h,
|
|
experimental="$experimental HTTP3"
|
|
AC_MSG_NOTICE([HTTP3 support is experimental])
|
|
curl_h3_msg="enabled (quiche)"
|
|
QUICHE_ENABLED=1
|
|
AC_DEFINE(USE_QUICHE, 1, [if quiche is in use])
|
|
AC_SUBST(USE_QUICHE, [1])
|
|
AC_CHECK_FUNCS([quiche_conn_set_qlog_fd])
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_QUICHE"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_QUICHE to CURL_LIBRARY_PATH]),
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
else
|
|
dnl no quiche pkg-config found, deal with it
|
|
if test X"$want_quiche" != Xdefault; then
|
|
dnl To avoid link errors, we do not allow --with-quiche without
|
|
dnl a pkgconfig file
|
|
AC_MSG_ERROR([--with-quiche was specified but could not find quiche pkg-config file.])
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for Hyper
|
|
dnl **********************************************************************
|
|
|
|
OPT_HYPER="yes"
|
|
|
|
if test "x$disable_http" = "xyes"; then
|
|
# without HTTP, hyper is of no use
|
|
OPT_HYPER="no"
|
|
fi
|
|
|
|
AC_ARG_WITH(hyper,
|
|
AC_HELP_STRING([--with-hyper=PATH],[Enable hyper usage])
|
|
AC_HELP_STRING([--without-hyper],[Disable hyper usage]),
|
|
[OPT_HYPER=$withval])
|
|
case "$OPT_HYPER" in
|
|
no)
|
|
dnl --without-hyper option used
|
|
want_hyper="no"
|
|
;;
|
|
yes)
|
|
dnl --with-hyper option used without path
|
|
want_hyper="default"
|
|
want_hyper_path=""
|
|
;;
|
|
*)
|
|
dnl --with-hyper option used with path
|
|
want_hyper="yes"
|
|
want_hyper_path="$withval"
|
|
;;
|
|
esac
|
|
|
|
if test X"$want_hyper" != Xno; then
|
|
dnl backup the pre-hyper variables
|
|
CLEANLDFLAGS="$LDFLAGS"
|
|
CLEANCPPFLAGS="$CPPFLAGS"
|
|
CLEANLIBS="$LIBS"
|
|
|
|
CURL_CHECK_PKGCONFIG(hyper, $want_hyper_path)
|
|
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
LIB_HYPER=`CURL_EXPORT_PCDIR([$want_hyper_path])
|
|
$PKGCONFIG --libs-only-l hyper`
|
|
CPP_HYPER=`CURL_EXPORT_PCDIR([$want_hyper_path]) dnl
|
|
$PKGCONFIG --cflags-only-I hyper`
|
|
LD_HYPER=`CURL_EXPORT_PCDIR([$want_hyper_path])
|
|
$PKGCONFIG --libs-only-L hyper`
|
|
else
|
|
dnl no hyper pkg-config found
|
|
LIB_HYPER="-lhyper"
|
|
if test X"$want_hyper" != Xdefault; then
|
|
CPP_HYPER=-I"$want_hyper_path/capi/include"
|
|
LD_HYPER="-L$want_hyper_path/target/debug"
|
|
fi
|
|
fi
|
|
if test -n "$LIB_HYPER"; then
|
|
AC_MSG_NOTICE([-l is $LIB_HYPER])
|
|
AC_MSG_NOTICE([-I is $CPP_HYPER])
|
|
AC_MSG_NOTICE([-L is $LD_HYPER])
|
|
|
|
LDFLAGS="$LDFLAGS $LD_HYPER"
|
|
CPPFLAGS="$CPPFLAGS $CPP_HYPER"
|
|
LIBS="$LIB_HYPER $LIBS"
|
|
|
|
if test "x$cross_compiling" != "xyes"; then
|
|
DIR_HYPER=`echo $LD_HYPER | $SED -e 's/^-L//'`
|
|
fi
|
|
|
|
AC_CHECK_LIB(hyper, hyper_io_new,
|
|
[
|
|
AC_CHECK_HEADERS(hyper.h,
|
|
experimental="$experimental Hyper"
|
|
AC_MSG_NOTICE([Hyper support is experimental])
|
|
curl_h1_msg="enabled (Hyper)"
|
|
curl_h2_msg=$curl_h1_msg
|
|
HYPER_ENABLED=1
|
|
AC_DEFINE(USE_HYPER, 1, [if hyper is in use])
|
|
AC_SUBST(USE_HYPER, [1])
|
|
CURL_LIBRARY_PATH="$CURL_LIBRARY_PATH:$DIR_HYPER"
|
|
export CURL_LIBRARY_PATH
|
|
AC_MSG_NOTICE([Added $DIR_HYPER to CURL_LIBRARY_PATH]),
|
|
)
|
|
],
|
|
dnl not found, revert back to clean variables
|
|
LDFLAGS=$CLEANLDFLAGS
|
|
CPPFLAGS=$CLEANCPPFLAGS
|
|
LIBS=$CLEANLIBS
|
|
)
|
|
fi
|
|
fi
|
|
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for zsh completion path
|
|
dnl **********************************************************************
|
|
|
|
OPT_ZSH_FPATH=default
|
|
AC_ARG_WITH(zsh-functions-dir,
|
|
AC_HELP_STRING([--with-zsh-functions-dir=PATH],[Install zsh completions to PATH])
|
|
AC_HELP_STRING([--without-zsh-functions-dir],[Do not install zsh completions]),
|
|
[OPT_ZSH_FPATH=$withval])
|
|
case "$OPT_ZSH_FPATH" in
|
|
no)
|
|
dnl --without-zsh-functions-dir option used
|
|
;;
|
|
default|yes)
|
|
dnl --with-zsh-functions-dir option used without path
|
|
ZSH_FUNCTIONS_DIR="$datarootdir/zsh/site-functions"
|
|
AC_SUBST(ZSH_FUNCTIONS_DIR)
|
|
;;
|
|
*)
|
|
dnl --with-zsh-functions-dir option used with path
|
|
ZSH_FUNCTIONS_DIR="$withval"
|
|
AC_SUBST(ZSH_FUNCTIONS_DIR)
|
|
;;
|
|
esac
|
|
|
|
dnl **********************************************************************
|
|
dnl Check for fish completion path
|
|
dnl **********************************************************************
|
|
|
|
OPT_FISH_FPATH=default
|
|
AC_ARG_WITH(fish-functions-dir,
|
|
AC_HELP_STRING([--with-fish-functions-dir=PATH],[Install fish completions to PATH])
|
|
AC_HELP_STRING([--without-fish-functions-dir],[Do not install fish completions]),
|
|
[OPT_FISH_FPATH=$withval])
|
|
case "$OPT_FISH_FPATH" in
|
|
no)
|
|
dnl --without-fish-functions-dir option used
|
|
;;
|
|
default|yes)
|
|
dnl --with-fish-functions-dir option used without path
|
|
CURL_CHECK_PKGCONFIG(fish)
|
|
if test "$PKGCONFIG" != "no" ; then
|
|
FISH_FUNCTIONS_DIR="$($PKGCONFIG --variable completionsdir fish)"
|
|
else
|
|
FISH_FUNCTIONS_DIR="$datarootdir/fish/vendor_completions.d"
|
|
fi
|
|
AC_SUBST(FISH_FUNCTIONS_DIR)
|
|
;;
|
|
*)
|
|
dnl --with-fish-functions-dir option used with path
|
|
FISH_FUNCTIONS_DIR="$withval"
|
|
AC_SUBST(FISH_FUNCTIONS_DIR)
|
|
;;
|
|
esac
|
|
|
|
dnl **********************************************************************
|
|
dnl Back to "normal" configuring
|
|
dnl **********************************************************************
|
|
|
|
dnl Checks for header files.
|
|
AC_HEADER_STDC
|
|
|
|
CURL_CHECK_HEADER_MALLOC
|
|
CURL_CHECK_HEADER_MEMORY
|
|
|
|
dnl Now check for the very most basic headers. Then we can use these
|
|
dnl ones as default-headers when checking for the rest!
|
|
AC_CHECK_HEADERS(
|
|
sys/types.h \
|
|
sys/time.h \
|
|
sys/select.h \
|
|
sys/socket.h \
|
|
sys/ioctl.h \
|
|
sys/uio.h \
|
|
assert.h \
|
|
unistd.h \
|
|
stdlib.h \
|
|
arpa/inet.h \
|
|
net/if.h \
|
|
netinet/in.h \
|
|
netinet/in6.h \
|
|
sys/un.h \
|
|
linux/tcp.h \
|
|
netinet/tcp.h \
|
|
netdb.h \
|
|
sys/sockio.h \
|
|
sys/stat.h \
|
|
sys/param.h \
|
|
termios.h \
|
|
termio.h \
|
|
sgtty.h \
|
|
fcntl.h \
|
|
alloca.h \
|
|
time.h \
|
|
io.h \
|
|
pwd.h \
|
|
utime.h \
|
|
sys/utime.h \
|
|
sys/poll.h \
|
|
poll.h \
|
|
socket.h \
|
|
sys/resource.h \
|
|
libgen.h \
|
|
locale.h \
|
|
errno.h \
|
|
stdbool.h \
|
|
arpa/tftp.h \
|
|
sys/filio.h \
|
|
sys/wait.h \
|
|
setjmp.h,
|
|
dnl to do if not found
|
|
[],
|
|
dnl to do if found
|
|
[],
|
|
dnl default includes
|
|
[
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
#include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_TIME_H
|
|
#include <sys/time.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_SELECT_H
|
|
#include <sys/select.h>
|
|
#elif defined(HAVE_UNISTD_H)
|
|
#include <unistd.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
#include <sys/socket.h>
|
|
#endif
|
|
#ifdef HAVE_NETINET_IN_H
|
|
#include <netinet/in.h>
|
|
#endif
|
|
#ifdef HAVE_NETINET_IN6_H
|
|
#include <netinet/in6.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_UN_H
|
|
#include <sys/un.h>
|
|
#endif
|
|
]
|
|
)
|
|
|
|
|
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
|
AC_C_CONST
|
|
CURL_CHECK_VARIADIC_MACROS
|
|
AC_TYPE_SIZE_T
|
|
AC_HEADER_TIME
|
|
CURL_CHECK_STRUCT_TIMEVAL
|
|
CURL_VERIFY_RUNTIMELIBS
|
|
|
|
AX_COMPILE_CHECK_SIZEOF(size_t)
|
|
AX_COMPILE_CHECK_SIZEOF(long)
|
|
AX_COMPILE_CHECK_SIZEOF(int)
|
|
AX_COMPILE_CHECK_SIZEOF(short)
|
|
AX_COMPILE_CHECK_SIZEOF(time_t)
|
|
AX_COMPILE_CHECK_SIZEOF(off_t)
|
|
|
|
o=$CPPFLAGS
|
|
CPPFLAGS="-I$srcdir/include $CPPFLAGS"
|
|
AX_COMPILE_CHECK_SIZEOF(curl_off_t, [
|
|
#include <curl/system.h>
|
|
])
|
|
CPPFLAGS=$o
|
|
|
|
AC_CHECK_TYPE(long long,
|
|
[AC_DEFINE(HAVE_LONGLONG, 1,
|
|
[Define to 1 if the compiler supports the 'long long' data type.])]
|
|
longlong="yes"
|
|
)
|
|
|
|
if test "xyes" = "x$longlong"; then
|
|
AC_MSG_CHECKING([if numberLL works])
|
|
AC_COMPILE_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
]],[[
|
|
long long val = 1000LL;
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE(HAVE_LL, 1, [if your compiler supports LL])
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
fi
|
|
|
|
|
|
# check for ssize_t
|
|
AC_CHECK_TYPE(ssize_t, ,
|
|
AC_DEFINE(ssize_t, int, [the signed version of size_t]))
|
|
|
|
# check for bool type
|
|
AC_CHECK_TYPE([bool],[
|
|
AC_DEFINE(HAVE_BOOL_T, 1,
|
|
[Define to 1 if bool is an available type.])
|
|
], ,[
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
#include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_STDBOOL_H
|
|
#include <stdbool.h>
|
|
#endif
|
|
])
|
|
|
|
# check for sa_family_t
|
|
AC_CHECK_TYPE(sa_family_t,
|
|
AC_DEFINE(CURL_SA_FAMILY_T, sa_family_t, [IP address type in sockaddr]),
|
|
[
|
|
# The windows name?
|
|
AC_CHECK_TYPE(ADDRESS_FAMILY,
|
|
AC_DEFINE(CURL_SA_FAMILY_T, ADDRESS_FAMILY, [IP address type in sockaddr]),
|
|
AC_DEFINE(CURL_SA_FAMILY_T, unsigned short, [IP address type in sockaddr]),
|
|
[
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
#include <sys/socket.h>
|
|
#endif
|
|
])
|
|
],
|
|
[
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
#include <sys/socket.h>
|
|
#endif
|
|
])
|
|
|
|
# check for suseconds_t
|
|
AC_CHECK_TYPE([suseconds_t],[
|
|
AC_DEFINE(HAVE_SUSECONDS_T, 1,
|
|
[Define to 1 if suseconds_t is an available type.])
|
|
], ,[
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
#include <sys/types.h>
|
|
#endif
|
|
#ifdef HAVE_SYS_TIME_H
|
|
#include <sys/time.h>
|
|
#endif
|
|
])
|
|
|
|
AC_MSG_CHECKING([if time_t is unsigned])
|
|
CURL_RUN_IFELSE(
|
|
[
|
|
#include <time.h>
|
|
#include <limits.h>
|
|
time_t t = -1;
|
|
return (t > 0);
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
AC_DEFINE(HAVE_TIME_T_UNSIGNED, 1, [Define this if time_t is unsigned])
|
|
],[
|
|
AC_MSG_RESULT([no])
|
|
],[
|
|
dnl cross-compiling, most systems are unsigned
|
|
AC_MSG_RESULT([no])
|
|
])
|
|
|
|
CURL_CONFIGURE_PULL_SYS_POLL
|
|
|
|
TYPE_IN_ADDR_T
|
|
|
|
TYPE_SOCKADDR_STORAGE
|
|
|
|
TYPE_SIG_ATOMIC_T
|
|
|
|
AC_TYPE_SIGNAL
|
|
|
|
CURL_CHECK_FUNC_SELECT
|
|
|
|
CURL_CHECK_FUNC_RECV
|
|
CURL_CHECK_FUNC_SEND
|
|
CURL_CHECK_MSG_NOSIGNAL
|
|
|
|
CURL_CHECK_FUNC_ALARM
|
|
CURL_CHECK_FUNC_BASENAME
|
|
CURL_CHECK_FUNC_CLOSESOCKET
|
|
CURL_CHECK_FUNC_CLOSESOCKET_CAMEL
|
|
CURL_CHECK_FUNC_CONNECT
|
|
CURL_CHECK_FUNC_FCNTL
|
|
CURL_CHECK_FUNC_FREEADDRINFO
|
|
CURL_CHECK_FUNC_FREEIFADDRS
|
|
CURL_CHECK_FUNC_FSETXATTR
|
|
CURL_CHECK_FUNC_FTRUNCATE
|
|
CURL_CHECK_FUNC_GETADDRINFO
|
|
CURL_CHECK_FUNC_GAI_STRERROR
|
|
CURL_CHECK_FUNC_GETHOSTBYADDR
|
|
CURL_CHECK_FUNC_GETHOSTBYADDR_R
|
|
CURL_CHECK_FUNC_GETHOSTBYNAME
|
|
CURL_CHECK_FUNC_GETHOSTBYNAME_R
|
|
CURL_CHECK_FUNC_GETHOSTNAME
|
|
CURL_CHECK_FUNC_GETPEERNAME
|
|
CURL_CHECK_FUNC_GETSOCKNAME
|
|
CURL_CHECK_FUNC_IF_NAMETOINDEX
|
|
CURL_CHECK_FUNC_GETIFADDRS
|
|
CURL_CHECK_FUNC_GETSERVBYPORT_R
|
|
CURL_CHECK_FUNC_GMTIME_R
|
|
CURL_CHECK_FUNC_INET_NTOA_R
|
|
CURL_CHECK_FUNC_INET_NTOP
|
|
CURL_CHECK_FUNC_INET_PTON
|
|
CURL_CHECK_FUNC_IOCTL
|
|
CURL_CHECK_FUNC_IOCTLSOCKET
|
|
CURL_CHECK_FUNC_IOCTLSOCKET_CAMEL
|
|
CURL_CHECK_FUNC_LOCALTIME_R
|
|
CURL_CHECK_FUNC_MEMRCHR
|
|
CURL_CHECK_FUNC_POLL
|
|
CURL_CHECK_FUNC_SETSOCKOPT
|
|
CURL_CHECK_FUNC_SIGACTION
|
|
CURL_CHECK_FUNC_SIGINTERRUPT
|
|
CURL_CHECK_FUNC_SIGNAL
|
|
CURL_CHECK_FUNC_SIGSETJMP
|
|
CURL_CHECK_FUNC_SOCKET
|
|
CURL_CHECK_FUNC_SOCKETPAIR
|
|
CURL_CHECK_FUNC_STRCASECMP
|
|
CURL_CHECK_FUNC_STRCMPI
|
|
CURL_CHECK_FUNC_STRDUP
|
|
CURL_CHECK_FUNC_STRERROR_R
|
|
CURL_CHECK_FUNC_STRICMP
|
|
CURL_CHECK_FUNC_STRNCASECMP
|
|
CURL_CHECK_FUNC_STRNCMPI
|
|
CURL_CHECK_FUNC_STRNICMP
|
|
CURL_CHECK_FUNC_STRSTR
|
|
CURL_CHECK_FUNC_STRTOK_R
|
|
CURL_CHECK_FUNC_STRTOLL
|
|
CURL_CHECK_FUNC_WRITEV
|
|
|
|
case $host in
|
|
*msdosdjgpp)
|
|
ac_cv_func_pipe=no
|
|
skipcheck_pipe=yes
|
|
AC_MSG_NOTICE([skip check for pipe on msdosdjgpp])
|
|
;;
|
|
esac
|
|
|
|
AC_CHECK_DECLS([getpwuid_r], [], [AC_DEFINE(HAVE_DECL_GETPWUID_R_MISSING, 1, "Set if getpwuid_r() declaration is missing")],
|
|
[[#include <pwd.h>
|
|
#include <sys/types.h>]])
|
|
|
|
|
|
AC_CHECK_FUNCS([fnmatch \
|
|
geteuid \
|
|
getpass_r \
|
|
getppid \
|
|
getpwuid \
|
|
getpwuid_r \
|
|
getrlimit \
|
|
gettimeofday \
|
|
if_nametoindex \
|
|
mach_absolute_time \
|
|
pipe \
|
|
setlocale \
|
|
setmode \
|
|
setrlimit \
|
|
usleep \
|
|
utime \
|
|
utimes
|
|
],[
|
|
],[
|
|
func="$ac_func"
|
|
eval skipcheck=\$skipcheck_$func
|
|
if test "x$skipcheck" != "xyes"; then
|
|
AC_MSG_CHECKING([deeper for $func])
|
|
AC_LINK_IFELSE([
|
|
AC_LANG_PROGRAM([[
|
|
]],[[
|
|
$func ();
|
|
]])
|
|
],[
|
|
AC_MSG_RESULT([yes])
|
|
eval "ac_cv_func_$func=yes"
|
|
AC_DEFINE_UNQUOTED(XC_SH_TR_CPP([HAVE_$func]), [1],
|
|
[Define to 1 if you have the $func function.])
|
|
],[
|
|
AC_MSG_RESULT([but still no])
|
|
])
|
|
fi
|
|
])
|
|
|
|
CURL_CHECK_NONBLOCKING_SOCKET
|
|
|
|
dnl ************************************************************
|
|
dnl nroff tool stuff
|
|
dnl
|
|
|
|
AC_PATH_PROG( PERL, perl, ,
|
|
$PATH:/usr/local/bin/perl:/usr/bin/:/usr/local/bin )
|
|
AC_SUBST(PERL)
|
|
|
|
AC_PATH_PROGS( NROFF, gnroff nroff, ,
|
|
$PATH:/usr/bin/:/usr/local/bin )
|
|
AC_SUBST(NROFF)
|
|
|
|
if test -n "$NROFF"; then
|
|
dnl only check for nroff options if an nroff command was found
|
|
|
|
AC_MSG_CHECKING([how to use *nroff to get plain text from man pages])
|
|
MANOPT="-man"
|
|
mancheck=`echo foo | $NROFF $MANOPT 2>/dev/null`
|
|
if test -z "$mancheck"; then
|
|
MANOPT="-mandoc"
|
|
mancheck=`echo foo | $NROFF $MANOPT 2>/dev/null`
|
|
if test -z "$mancheck"; then
|
|
MANOPT=""
|
|
AC_MSG_RESULT([failed])
|
|
AC_MSG_WARN([found no *nroff option to get plaintext from man pages])
|
|
else
|
|
AC_MSG_RESULT([$MANOPT])
|
|
fi
|
|
else
|
|
AC_MSG_RESULT([$MANOPT])
|
|
fi
|
|
AC_SUBST(MANOPT)
|
|
fi
|
|
|
|
if test -z "$MANOPT"
|
|
then
|
|
dnl if no nroff tool was found, or no option that could convert man pages
|
|
dnl was found, then disable the built-in manual stuff
|
|
AC_MSG_WARN([disabling built-in manual])
|
|
USE_MANUAL="no";
|
|
fi
|
|
|
|
dnl *************************************************************************
|
|
dnl If the manual variable still is set, then we go with providing a built-in
|
|
dnl manual
|
|
|
|
if test "$USE_MANUAL" = "1"; then
|
|
AC_DEFINE(USE_MANUAL, 1, [If you want to build curl with the built-in manual])
|
|
curl_manual_msg="enabled"
|
|
fi
|
|
|
|
dnl set variable for use in automakefile(s)
|
|
AM_CONDITIONAL(USE_MANUAL, test x"$USE_MANUAL" = x1)
|
|
|
|
CURL_CHECK_LIB_ARES
|
|
AM_CONDITIONAL(USE_EMBEDDED_ARES, test x$embedded_ares = xyes)
|
|
|
|
if test "x$curl_cv_native_windows" != "xyes" &&
|
|
test "x$enable_shared" = "xyes"; then
|
|
build_libhostname=yes
|
|
else
|
|
build_libhostname=no
|
|
fi
|
|
AM_CONDITIONAL(BUILD_LIBHOSTNAME, test x$build_libhostname = xyes)
|
|
|
|
if test "x$want_ares" != xyes; then
|
|
CURL_CHECK_OPTION_THREADED_RESOLVER
|
|
fi
|
|
|
|
dnl ************************************************************
|
|
dnl disable POSIX threads
|
|
dnl
|
|
AC_MSG_CHECKING([whether to use POSIX threads for threaded resolver])
|
|
AC_ARG_ENABLE(pthreads,
|
|
AC_HELP_STRING([--enable-pthreads],
|
|
[Enable POSIX threads (default for threaded resolver)])
|
|
AC_HELP_STRING([--disable-pthreads],[Disable POSIX threads]),
|
|
[ case "$enableval" in
|
|
no) AC_MSG_RESULT(no)
|
|
want_pthreads=no
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
want_pthreads=yes
|
|
;;
|
|
esac ], [
|
|
AC_MSG_RESULT(auto)
|
|
want_pthreads=auto
|
|
]
|
|
)
|
|
|
|
dnl turn off pthreads if rt is disabled
|
|
if test "$want_pthreads" != "no"; then
|
|
if test "$want_pthreads" = "yes" && test "$dontwant_rt" = "yes"; then
|
|
AC_MSG_ERROR([options --enable-pthreads and --disable-rt are mutually exclusive])
|
|
fi
|
|
if test "$dontwant_rt" != "no"; then
|
|
dnl if --enable-pthreads was explicit then warn it's being ignored
|
|
if test "$want_pthreads" = "yes"; then
|
|
AC_MSG_WARN([--enable-pthreads Ignored since librt is disabled.])
|
|
fi
|
|
want_pthreads=no
|
|
fi
|
|
fi
|
|
|
|
dnl turn off pthreads if no threaded resolver
|
|
if test "$want_pthreads" != "no" && test "$want_thres" != "yes"; then
|
|
want_pthreads=no
|
|
fi
|
|
|
|
dnl detect pthreads
|
|
if test "$want_pthreads" != "no"; then
|
|
AC_CHECK_HEADER(pthread.h,
|
|
[ AC_DEFINE(HAVE_PTHREAD_H, 1, [if you have <pthread.h>])
|
|
save_CFLAGS="$CFLAGS"
|
|
dnl When statically linking against boringssl, -lpthread is added to LIBS.
|
|
dnl Make sure to that this does not pass the check below, we really want
|
|
dnl -pthread in CFLAGS as recommended for GCC. This also ensures that
|
|
dnl lib1541 and lib1565 tests are built with these options. Otherwise
|
|
dnl they fail the build since tests/libtest/Makefile.am clears LIBS.
|
|
save_LIBS="$LIBS"
|
|
|
|
LIBS=
|
|
dnl Check for libc variants without a separate pthread lib like bionic
|
|
AC_CHECK_FUNC(pthread_create, [USE_THREADS_POSIX=1] )
|
|
LIBS="$save_LIBS"
|
|
|
|
dnl on HPUX, life is more complicated...
|
|
case $host in
|
|
*-hp-hpux*)
|
|
dnl it doesn't actually work without -lpthread
|
|
USE_THREADS_POSIX=""
|
|
;;
|
|
*)
|
|
;;
|
|
esac
|
|
|
|
dnl if it wasn't found without lib, search for it in pthread lib
|
|
if test "$USE_THREADS_POSIX" != "1"
|
|
then
|
|
CFLAGS="$CFLAGS -pthread"
|
|
# assign PTHREAD for pkg-config use
|
|
PTHREAD=" -pthread"
|
|
AC_CHECK_LIB(pthread, pthread_create,
|
|
[USE_THREADS_POSIX=1],
|
|
[ CFLAGS="$save_CFLAGS"])
|
|
fi
|
|
|
|
if test "x$USE_THREADS_POSIX" = "x1"
|
|
then
|
|
AC_DEFINE(USE_THREADS_POSIX, 1, [if you want POSIX threaded DNS lookup])
|
|
curl_res_msg="POSIX threaded"
|
|
fi
|
|
])
|
|
fi
|
|
|
|
dnl threaded resolver check
|
|
if test "$want_thres" = "yes" && test "x$USE_THREADS_POSIX" != "x1"; then
|
|
if test "$want_pthreads" = "yes"; then
|
|
AC_MSG_ERROR([--enable-pthreads but pthreads was not found])
|
|
fi
|
|
dnl If native Windows fallback on Win32 threads since no POSIX threads
|
|
if test "$curl_cv_native_windows" = "yes"; then
|
|
USE_THREADS_WIN32=1
|
|
AC_DEFINE(USE_THREADS_WIN32, 1, [if you want Win32 threaded DNS lookup])
|
|
curl_res_msg="Win32 threaded"
|
|
else
|
|
AC_MSG_ERROR([Threaded resolver enabled but no thread library found])
|
|
fi
|
|
fi
|
|
|
|
CURL_CONVERT_INCLUDE_TO_ISYSTEM
|
|
|
|
dnl ************************************************************
|
|
dnl disable verbose text strings
|
|
dnl
|
|
AC_MSG_CHECKING([whether to enable verbose strings])
|
|
AC_ARG_ENABLE(verbose,
|
|
AC_HELP_STRING([--enable-verbose],[Enable verbose strings])
|
|
AC_HELP_STRING([--disable-verbose],[Disable verbose strings]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_VERBOSE_STRINGS, 1, [to disable verbose strings])
|
|
curl_verbose_msg="no"
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl enable SSPI support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to enable SSPI support (Windows native builds only)])
|
|
AC_ARG_ENABLE(sspi,
|
|
AC_HELP_STRING([--enable-sspi],[Enable SSPI])
|
|
AC_HELP_STRING([--disable-sspi],[Disable SSPI]),
|
|
[ case "$enableval" in
|
|
yes)
|
|
if test "$curl_cv_native_windows" = "yes"; then
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(USE_WINDOWS_SSPI, 1, [to enable SSPI support])
|
|
AC_SUBST(USE_WINDOWS_SSPI, [1])
|
|
curl_sspi_msg="enabled"
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
AC_MSG_WARN([--enable-sspi Ignored. Only supported on native Windows builds.])
|
|
fi
|
|
;;
|
|
*)
|
|
if test "x$SCHANNEL_ENABLED" = "x1"; then
|
|
# --with-schannel implies --enable-sspi
|
|
AC_MSG_RESULT(yes)
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
;;
|
|
esac ],
|
|
if test "x$SCHANNEL_ENABLED" = "x1"; then
|
|
# --with-schannel implies --enable-sspi
|
|
AC_MSG_RESULT(yes)
|
|
else
|
|
AC_MSG_RESULT(no)
|
|
fi
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable cryptographic authentication
|
|
dnl
|
|
AC_MSG_CHECKING([whether to enable cryptographic authentication methods])
|
|
AC_ARG_ENABLE(crypto-auth,
|
|
AC_HELP_STRING([--enable-crypto-auth],[Enable cryptographic authentication])
|
|
AC_HELP_STRING([--disable-crypto-auth],[Disable cryptographic authentication]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_CRYPTO_AUTH, 1, [to disable cryptographic authentication])
|
|
CURL_DISABLE_CRYPTO_AUTH=1
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
CURL_CHECK_OPTION_NTLM_WB
|
|
|
|
CURL_CHECK_NTLM_WB
|
|
|
|
dnl ************************************************************
|
|
dnl disable TLS-SRP authentication
|
|
dnl
|
|
AC_MSG_CHECKING([whether to enable TLS-SRP authentication])
|
|
AC_ARG_ENABLE(tls-srp,
|
|
AC_HELP_STRING([--enable-tls-srp],[Enable TLS-SRP authentication])
|
|
AC_HELP_STRING([--disable-tls-srp],[Disable TLS-SRP authentication]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
want_tls_srp=no
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
want_tls_srp=yes
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
want_tls_srp=yes
|
|
)
|
|
|
|
if test "$want_tls_srp" = "yes" && ( test "x$HAVE_GNUTLS_SRP" = "x1" || test "x$HAVE_OPENSSL_SRP" = "x1") ; then
|
|
AC_DEFINE(USE_TLS_SRP, 1, [Use TLS-SRP authentication])
|
|
USE_TLS_SRP=1
|
|
curl_tls_srp_msg="enabled"
|
|
fi
|
|
|
|
dnl ************************************************************
|
|
dnl disable Unix domain sockets support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to enable Unix domain sockets])
|
|
AC_ARG_ENABLE(unix-sockets,
|
|
AC_HELP_STRING([--enable-unix-sockets],[Enable Unix domain sockets])
|
|
AC_HELP_STRING([--disable-unix-sockets],[Disable Unix domain sockets]),
|
|
[ case "$enableval" in
|
|
no) AC_MSG_RESULT(no)
|
|
want_unix_sockets=no
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
want_unix_sockets=yes
|
|
;;
|
|
esac ], [
|
|
AC_MSG_RESULT(auto)
|
|
want_unix_sockets=auto
|
|
]
|
|
)
|
|
if test "x$want_unix_sockets" != "xno"; then
|
|
AC_CHECK_MEMBER([struct sockaddr_un.sun_path], [
|
|
AC_DEFINE(USE_UNIX_SOCKETS, 1, [Use Unix domain sockets])
|
|
AC_SUBST(USE_UNIX_SOCKETS, [1])
|
|
curl_unix_sockets_msg="enabled"
|
|
], [
|
|
if test "x$want_unix_sockets" = "xyes"; then
|
|
AC_MSG_ERROR([--enable-unix-sockets is not available on this platform!])
|
|
fi
|
|
], [
|
|
#include <sys/un.h>
|
|
])
|
|
fi
|
|
|
|
dnl ************************************************************
|
|
dnl disable cookies support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support cookies])
|
|
AC_ARG_ENABLE(cookies,
|
|
AC_HELP_STRING([--enable-cookies],[Enable cookies support])
|
|
AC_HELP_STRING([--disable-cookies],[Disable cookies support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_COOKIES, 1, [to disable cookies support])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable socketpair
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support socketpair])
|
|
AC_ARG_ENABLE(socketpair,
|
|
AC_HELP_STRING([--enable-socketpair],[Enable socketpair support])
|
|
AC_HELP_STRING([--disable-socketpair],[Disable socketpair support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_SOCKETPAIR, 1, [to disable socketpair support])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable HTTP authentication support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support HTTP authentication])
|
|
AC_ARG_ENABLE(http-auth,
|
|
AC_HELP_STRING([--enable-http-auth],[Enable HTTP authentication support])
|
|
AC_HELP_STRING([--disable-http-auth],[Disable HTTP authentication support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_HTTP_AUTH, 1, [disable HTTP authentication])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable DoH support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support DoH])
|
|
AC_ARG_ENABLE(doh,
|
|
AC_HELP_STRING([--enable-doh],[Enable DoH support])
|
|
AC_HELP_STRING([--disable-doh],[Disable DoH support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_DOH, 1, [disable DoH])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable mime API support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support the MIME API])
|
|
AC_ARG_ENABLE(mime,
|
|
AC_HELP_STRING([--enable-mime],[Enable mime API support])
|
|
AC_HELP_STRING([--disable-mime],[Disable mime API support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_MIME, 1, [disable mime API])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable date parsing
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support date parsing])
|
|
AC_ARG_ENABLE(dateparse,
|
|
AC_HELP_STRING([--enable-dateparse],[Enable date parsing])
|
|
AC_HELP_STRING([--disable-dateparse],[Disable date parsing]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_PARSEDATE, 1, [disable date parsing])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable netrc
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support netrc parsing])
|
|
AC_ARG_ENABLE(netrc,
|
|
AC_HELP_STRING([--enable-netrc],[Enable netrc parsing])
|
|
AC_HELP_STRING([--disable-netrc],[Disable netrc parsing]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_NETRC, 1, [disable netrc parsing])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable progress-meter
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support progress-meter])
|
|
AC_ARG_ENABLE(progress-meter,
|
|
AC_HELP_STRING([--enable-progress-meter],[Enable progress-meter])
|
|
AC_HELP_STRING([--disable-progress-meter],[Disable progress-meter]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_PROGRESS_METER, 1, [disable progress-meter])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable shuffle DNS support
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support DNS shuffling])
|
|
AC_ARG_ENABLE(dnsshuffle,
|
|
AC_HELP_STRING([--enable-dnsshuffle],[Enable DNS shuffling])
|
|
AC_HELP_STRING([--disable-dnsshuffle],[Disable DNS shuffling]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_SHUFFLE_DNS, 1, [disable DNS shuffling])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl disable the curl_easy_options API
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support curl_easy_option*])
|
|
AC_ARG_ENABLE(get-easy-option,
|
|
AC_HELP_STRING([--enable-get-easy-options],[Enable curl_easy_options])
|
|
AC_HELP_STRING([--disable-get-easy-options],[Disable curl_easy_options]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_GETOPTIONS, 1, [to disable curl_easy_options])
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(yes)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl switch on/off alt-svc
|
|
dnl
|
|
AC_MSG_CHECKING([whether to support alt-svc])
|
|
AC_ARG_ENABLE(alt-svc,
|
|
AC_HELP_STRING([--enable-alt-svc],[Enable alt-svc support])
|
|
AC_HELP_STRING([--disable-alt-svc],[Disable alt-svc support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(CURL_DISABLE_ALTSVC, 1, [disable alt-svc])
|
|
curl_altsvc_msg="no";
|
|
enable_altsvc="no"
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(no)
|
|
)
|
|
|
|
dnl ************************************************************
|
|
dnl switch on/off hsts
|
|
dnl
|
|
curl_hsts_msg="no (--enable-hsts)";
|
|
AC_MSG_CHECKING([whether to support HSTS])
|
|
AC_ARG_ENABLE(hsts,
|
|
AC_HELP_STRING([--enable-hsts],[Enable HSTS support])
|
|
AC_HELP_STRING([--disable-hsts],[Disable HSTS support]),
|
|
[ case "$enableval" in
|
|
no)
|
|
AC_MSG_RESULT(no)
|
|
;;
|
|
*) AC_MSG_RESULT(yes)
|
|
curl_hsts_msg="enabled";
|
|
enable_hsts="yes"
|
|
;;
|
|
esac ],
|
|
AC_MSG_RESULT(no)
|
|
)
|
|
|
|
if test "$enable_hsts" = "yes"; then
|
|
AC_DEFINE(USE_HSTS, 1, [to enable HSTS])
|
|
experimental="$experimental HSTS"
|
|
fi
|
|
|
|
dnl *************************************************************
|
|
dnl check whether ECH support, if desired, is actually available
|
|
dnl
|
|
if test "x$want_ech" != "xno"; then
|
|
AC_MSG_CHECKING([whether ECH support is available])
|
|
|
|
dnl assume NOT and look for sufficient condition
|
|
ECH_ENABLED=0
|
|
ECH_SUPPORT=''
|
|
|
|
dnl OpenSSL with a chosen ECH function should be enough
|
|
dnl so more exhaustive checking seems unnecessary for now
|
|
if test "x$OPENSSL_ENABLED" = "x1"; then
|
|
AC_CHECK_FUNCS(SSL_get_ech_status,
|
|
ECH_SUPPORT="ECH support available (OpenSSL with SSL_get_ech_status)"
|
|
ECH_ENABLED=1)
|
|
|
|
dnl add 'elif' chain here for additional implementations
|
|
fi
|
|
|
|
dnl now deal with whatever we found
|
|
if test "x$ECH_ENABLED" = "x1"; then
|
|
AC_DEFINE(USE_ECH, 1, [if ECH support is available])
|
|
AC_MSG_RESULT($ECH_SUPPORT)
|
|
experimental="$experimental ECH"
|
|
else
|
|
AC_MSG_ERROR([--enable-ech ignored: No ECH support found])
|
|
fi
|
|
fi
|
|
|
|
dnl ************************************************************
|
|
dnl hiding of library internal symbols
|
|
dnl
|
|
CURL_CONFIGURE_SYMBOL_HIDING
|
|
|
|
dnl
|
|
dnl All the library dependencies put into $LIB apply to libcurl only.
|
|
dnl
|
|
LIBCURL_LIBS="$LIBS$PTHREAD"
|
|
|
|
AC_SUBST(LIBCURL_LIBS)
|
|
AC_SUBST(CURL_NETWORK_LIBS)
|
|
AC_SUBST(CURL_NETWORK_AND_TIME_LIBS)
|
|
|
|
dnl BLANK_AT_MAKETIME may be used in our Makefile.am files to blank
|
|
dnl LIBS variable used in generated makefile at makefile processing
|
|
dnl time. Doing this functionally prevents LIBS from being used for
|
|
dnl all link targets in given makefile.
|
|
BLANK_AT_MAKETIME=
|
|
AC_SUBST(BLANK_AT_MAKETIME)
|
|
|
|
AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes)
|
|
|
|
dnl yes or no
|
|
ENABLE_SHARED="$enable_shared"
|
|
AC_SUBST(ENABLE_SHARED)
|
|
|
|
dnl to let curl-config output the static libraries correctly
|
|
ENABLE_STATIC="$enable_static"
|
|
AC_SUBST(ENABLE_STATIC)
|
|
|
|
dnl merge the pkg-config Libs.private field into Libs when static-only
|
|
if test "x$enable_shared" = "xno"; then
|
|
LIBCURL_NO_SHARED=$LIBCURL_LIBS
|
|
else
|
|
LIBCURL_NO_SHARED=
|
|
fi
|
|
AC_SUBST(LIBCURL_NO_SHARED)
|
|
|
|
dnl
|
|
dnl For keeping supported features and protocols also in pkg-config file
|
|
dnl since it is more cross-compile friendly than curl-config
|
|
dnl
|
|
|
|
if test "x$OPENSSL_ENABLED" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES SSL"
|
|
elif test -n "$SSL_ENABLED"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES SSL"
|
|
fi
|
|
if test "x$IPV6_ENABLED" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES IPv6"
|
|
fi
|
|
if test "x$USE_UNIX_SOCKETS" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES UnixSockets"
|
|
fi
|
|
if test "x$HAVE_LIBZ" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES libz"
|
|
fi
|
|
if test "x$HAVE_BROTLI" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES brotli"
|
|
fi
|
|
if test "x$HAVE_ZSTD" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES zstd"
|
|
fi
|
|
if test "x$USE_ARES" = "x1" -o "x$USE_THREADS_POSIX" = "x1" \
|
|
-o "x$USE_THREADS_WIN32" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES AsynchDNS"
|
|
fi
|
|
if test "x$IDN_ENABLED" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES IDN"
|
|
fi
|
|
if test "x$USE_WINDOWS_SSPI" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES SSPI"
|
|
fi
|
|
|
|
if test "x$HAVE_GSSAPI" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES GSS-API"
|
|
fi
|
|
|
|
if test "x$curl_psl_msg" = "xenabled"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES PSL"
|
|
fi
|
|
|
|
if test "x$curl_gsasl_msg" = "xenabled"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES GSASL"
|
|
fi
|
|
|
|
if test "x$enable_altsvc" = "xyes"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES alt-svc"
|
|
fi
|
|
if test "x$enable_hsts" = "xyes"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES HSTS"
|
|
fi
|
|
|
|
if test "x$CURL_DISABLE_CRYPTO_AUTH" != "x1" -a \
|
|
\( "x$HAVE_GSSAPI" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \); then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES SPNEGO"
|
|
fi
|
|
|
|
if test "x$CURL_DISABLE_CRYPTO_AUTH" != "x1" -a \
|
|
\( "x$HAVE_GSSAPI" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \); then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES Kerberos"
|
|
fi
|
|
|
|
if test "x$CURL_DISABLE_CRYPTO_AUTH" != "x1"; then
|
|
if test "x$OPENSSL_ENABLED" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \
|
|
-o "x$GNUTLS_ENABLED" = "x1" -o "x$MBEDTLS_ENABLED" = "x1" \
|
|
-o "x$NSS_ENABLED" = "x1" -o "x$SECURETRANSPORT_ENABLED" = "x1" \
|
|
-o "x$WOLFSSL_NTLM" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM"
|
|
|
|
if test "x$CURL_DISABLE_HTTP" != "x1" -a \
|
|
"x$NTLM_WB_ENABLED" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM_WB"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if test "x$USE_TLS_SRP" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES TLS-SRP"
|
|
fi
|
|
|
|
if test "x$USE_NGHTTP2" = "x1" -o "x$USE_HYPER" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES HTTP2"
|
|
fi
|
|
|
|
if test "x$USE_NGTCP2" = "x1" -o "x$USE_QUICHE" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES HTTP3"
|
|
fi
|
|
|
|
if test "x$CURL_WITH_MULTI_SSL" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES MultiSSL"
|
|
fi
|
|
|
|
dnl if not explictily turned off, HTTPS-proxy comes with some TLS backends
|
|
if test "x$https_proxy" != "xno"; then
|
|
if test "x$OPENSSL_ENABLED" = "x1" -o "x$GNUTLS_ENABLED" = "x1" \
|
|
-o "x$NSS_ENABLED" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES HTTPS-proxy"
|
|
fi
|
|
fi
|
|
|
|
if test "x$ECH_ENABLED" = "x1"; then
|
|
SUPPORT_FEATURES="$SUPPORT_FEATURES ECH"
|
|
fi
|
|
|
|
dnl replace spaces with newlines
|
|
dnl sort the lines
|
|
dnl replace the newlines back to spaces
|
|
SUPPORT_FEATURES=`echo $SUPPORT_FEATURES | tr ' ' '\012' | sort | tr '\012' ' '`
|
|
AC_SUBST(SUPPORT_FEATURES)
|
|
|
|
dnl For supported protocols in pkg-config file
|
|
if test "x$CURL_DISABLE_HTTP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS HTTP"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS HTTPS"
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_FTP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS FTP"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS FTPS"
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_FILE" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS FILE"
|
|
fi
|
|
if test "x$CURL_DISABLE_TELNET" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS TELNET"
|
|
fi
|
|
if test "x$CURL_DISABLE_LDAP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS LDAP"
|
|
if test "x$CURL_DISABLE_LDAPS" != "x1"; then
|
|
if (test "x$USE_OPENLDAP" = "x1" && test "x$SSL_ENABLED" = "x1") ||
|
|
(test "x$USE_OPENLDAP" != "x1" && test "x$HAVE_LDAP_SSL" = "x1"); then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS LDAPS"
|
|
fi
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_DICT" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS DICT"
|
|
fi
|
|
if test "x$CURL_DISABLE_TFTP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS TFTP"
|
|
fi
|
|
if test "x$CURL_DISABLE_GOPHER" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS GOPHER"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS GOPHERS"
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_MQTT" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS MQTT"
|
|
fi
|
|
if test "x$CURL_DISABLE_POP3" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS POP3"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS POP3S"
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_IMAP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS IMAP"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS IMAPS"
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_SMB" != "x1" \
|
|
-a "x$CURL_DISABLE_CRYPTO_AUTH" != "x1" \
|
|
-a \( "x$OPENSSL_ENABLED" = "x1" \
|
|
-o "x$GNUTLS_ENABLED" = "x1" -o "x$MBEDTLS_ENABLED" = "x1" \
|
|
-o "x$NSS_ENABLED" = "x1" -o "x$SECURETRANSPORT_ENABLED" = "x1" \
|
|
-o "x$WOLFSSL_NTLM" = "x1" \); then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SMB"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SMBS"
|
|
fi
|
|
fi
|
|
if test "x$CURL_DISABLE_SMTP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SMTP"
|
|
if test "x$SSL_ENABLED" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SMTPS"
|
|
fi
|
|
fi
|
|
if test "x$USE_LIBSSH2" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SCP"
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SFTP"
|
|
fi
|
|
if test "x$USE_LIBSSH" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SCP"
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SFTP"
|
|
fi
|
|
if test "x$USE_WOLFSSH" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS SFTP"
|
|
fi
|
|
if test "x$CURL_DISABLE_RTSP" != "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS RTSP"
|
|
fi
|
|
if test "x$USE_LIBRTMP" = "x1"; then
|
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS RTMP"
|
|
fi
|
|
|
|
dnl replace spaces with newlines
|
|
dnl sort the lines
|
|
dnl replace the newlines back to spaces
|
|
SUPPORT_PROTOCOLS=`echo $SUPPORT_PROTOCOLS | tr ' ' '\012' | sort | tr '\012' ' '`
|
|
|
|
AC_SUBST(SUPPORT_PROTOCOLS)
|
|
|
|
dnl squeeze whitespace out of some variables
|
|
|
|
squeeze CFLAGS
|
|
squeeze CPPFLAGS
|
|
squeeze DEFS
|
|
squeeze LDFLAGS
|
|
squeeze LIBS
|
|
|
|
squeeze LIBCURL_LIBS
|
|
squeeze CURL_NETWORK_LIBS
|
|
squeeze CURL_NETWORK_AND_TIME_LIBS
|
|
|
|
squeeze SUPPORT_FEATURES
|
|
squeeze SUPPORT_PROTOCOLS
|
|
|
|
XC_CHECK_BUILD_FLAGS
|
|
|
|
SSL_BACKENDS=${ssl_backends}
|
|
AC_SUBST(SSL_BACKENDS)
|
|
|
|
if test "x$want_curldebug_assumed" = "xyes" &&
|
|
test "x$want_curldebug" = "xyes" && test "x$USE_ARES" = "x1"; then
|
|
ac_configure_args="$ac_configure_args --enable-curldebug"
|
|
fi
|
|
|
|
AC_CONFIG_FILES([Makefile \
|
|
docs/Makefile \
|
|
docs/examples/Makefile \
|
|
docs/libcurl/Makefile \
|
|
docs/libcurl/opts/Makefile \
|
|
docs/cmdline-opts/Makefile \
|
|
include/Makefile \
|
|
include/curl/Makefile \
|
|
src/Makefile \
|
|
lib/Makefile \
|
|
scripts/Makefile \
|
|
lib/libcurl.vers \
|
|
tests/Makefile \
|
|
tests/certs/Makefile \
|
|
tests/certs/scripts/Makefile \
|
|
tests/data/Makefile \
|
|
tests/server/Makefile \
|
|
tests/libtest/Makefile \
|
|
tests/unit/Makefile \
|
|
packages/Makefile \
|
|
packages/vms/Makefile \
|
|
curl-config \
|
|
libcurl.pc
|
|
])
|
|
AC_OUTPUT
|
|
|
|
CURL_GENERATE_CONFIGUREHELP_PM
|
|
|
|
XC_AMEND_DISTCLEAN([lib src tests/unit tests/server tests/libtest docs/examples])
|
|
|
|
AC_MSG_NOTICE([Configured to build curl/libcurl:
|
|
|
|
Host setup: ${host}
|
|
Install prefix: ${prefix}
|
|
Compiler: ${CC}
|
|
CFLAGS: ${CFLAGS}
|
|
CPPFLAGS: ${CPPFLAGS}
|
|
LDFLAGS: ${LDFLAGS}
|
|
LIBS: ${LIBS}
|
|
|
|
curl version: ${CURLVERSION}
|
|
SSL: ${curl_ssl_msg}
|
|
SSH: ${curl_ssh_msg}
|
|
zlib: ${curl_zlib_msg}
|
|
brotli: ${curl_brotli_msg}
|
|
zstd: ${curl_zstd_msg}
|
|
GSS-API: ${curl_gss_msg}
|
|
GSASL: ${curl_gsasl_msg}
|
|
TLS-SRP: ${curl_tls_srp_msg}
|
|
resolver: ${curl_res_msg}
|
|
IPv6: ${curl_ipv6_msg}
|
|
Unix sockets: ${curl_unix_sockets_msg}
|
|
IDN: ${curl_idn_msg}
|
|
Build libcurl: Shared=${enable_shared}, Static=${enable_static}
|
|
Built-in manual: ${curl_manual_msg}
|
|
--libcurl option: ${curl_libcurl_msg}
|
|
Verbose errors: ${curl_verbose_msg}
|
|
Code coverage: ${curl_coverage_msg}
|
|
SSPI: ${curl_sspi_msg}
|
|
ca cert bundle: ${ca}${ca_warning}
|
|
ca cert path: ${capath}${capath_warning}
|
|
ca fallback: ${with_ca_fallback}
|
|
LDAP: ${curl_ldap_msg}
|
|
LDAPS: ${curl_ldaps_msg}
|
|
RTSP: ${curl_rtsp_msg}
|
|
RTMP: ${curl_rtmp_msg}
|
|
Metalink: ${curl_mtlnk_msg}
|
|
PSL: ${curl_psl_msg}
|
|
Alt-svc: ${curl_altsvc_msg}
|
|
HTTP1: ${curl_h1_msg}
|
|
HTTP2: ${curl_h2_msg}
|
|
HTTP3: ${curl_h3_msg}
|
|
ECH: ${curl_ech_msg}
|
|
Protocols: ${SUPPORT_PROTOCOLS}
|
|
Features: ${SUPPORT_FEATURES}
|
|
])
|
|
if test -n "$experimental"; then
|
|
cat >&2 << _EOF
|
|
WARNING: $experimental enabled but marked EXPERIMENTAL. Use with caution!
|
|
_EOF
|
|
fi
|