X-Git-Url: http://sjero.net/git/?p=wget;a=blobdiff_plain;f=configure.ac;h=88d498ecc3996f879ac093fc10199fb577e3f9ea;hp=fa3d5b977b9c0afaa115e968cd651b5377b76175;hb=1eb1e76e9ac6f1692f33570f61ff43740f3b44d1;hpb=f9c765d8e635728753572db7af242a8c167980d7 diff --git a/configure.ac b/configure.ac index fa3d5b97..88d498ec 100644 --- a/configure.ac +++ b/configure.ac @@ -1,6 +1,6 @@ dnl Template file for GNU Autoconf -dnl Copyright (C) 1995, 1996, 1997, 2001, 2007, 2008, 2009, 2010 Free -dnl Software Foundation, Inc. +dnl Copyright (C) 1995, 1996, 1997, 2001, 2007, 2008, 2009, 2010, 2011 +dnl Free Software Foundation, Inc. dnl This program is free software; you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by @@ -165,11 +165,11 @@ dnl Check sizes of integer types. These are used to find n-bit dnl integral types on older systems that fail to provide intN_t and dnl uintN_t typedefs. dnl -AC_CHECK_SIZEOF(short) -AC_CHECK_SIZEOF(int) -AC_CHECK_SIZEOF(long) -AC_CHECK_SIZEOF(long long) -AC_CHECK_SIZEOF(void *) +AC_CHECK_SIZEOF([short]) +AC_CHECK_SIZEOF([int]) +AC_CHECK_SIZEOF([long]) +AC_CHECK_SIZEOF([long long]) +AC_CHECK_SIZEOF([void *]) dnl dnl Checks for non-universal or system-specific types. @@ -223,30 +223,20 @@ WGET_NSL_SOCKET dnl Deal with specific hosts case $host_os in *mingw32* ) - AC_SUBST(W32LIBS, '-lws2_32') + LIBS+=' -lws2_32' AC_LIBOBJ([mswindows]) ;; esac + dnl dnl Checks for libraries. dnl -AS_IF([test x"$with_ssl" = xgnutls], [ - dnl Now actually check for -lssl - AC_LIB_HAVE_LINKFLAGS([gnutls], [], [ -#include - ], [gnutls_global_init()]) - if test x"$LIBGNUTLS" != x - then - AC_MSG_NOTICE([compiling in support for SSL via GnuTLS]) - AC_LIBOBJ([gnutls]) - else - AC_MSG_ERROR([--with-ssl=gnutls was given, but GNUTLS is not available.]) - fi -], [ - # --with-ssl is not gnutls: check if it's no - AS_IF([test x"$with_ssl" != xno], [ +AS_IF([test x"$with_ssl" = xopenssl], [ + dnl some versions of openssl use zlib compression + AC_CHECK_LIB(z, compress) + dnl As of this writing (OpenSSL 0.9.6), the libcrypto shared library dnl doesn't record its dependency on libdl, so we need to make sure dnl -ldl ends up in LIBS on systems that have it. Most OSes use @@ -255,26 +245,61 @@ AS_IF([test x"$with_ssl" = xgnutls], [ AC_CHECK_LIB(dl, shl_load) ]) + case $host_os in + *mingw32* ) + dnl prefer link to openssl dlls if possible. if not then fallback on static libs. if not then error + + AC_CHECK_LIB(eay32, EVP_MD_CTX_init) + if test x"$ac_cv_lib_eay32_EVP_MD_CTX_init" != xno + then + AC_CHECK_LIB(ssl32, SSL_connect,, + AC_MSG_ERROR([openssl not found: shared lib eay32 found but ssl32 not found])) + AC_MSG_NOTICE([Enabling support for SSL via OpenSSL (shared)]) + else + + LIBS+=' -lgdi32' + + dnl fallback and test static libs + AC_CHECK_LIB(crypto, EVP_MD_CTX_init,,,) + if test x"$ac_cv_lib_crypto_EVP_MD_CTX_init" != xno + then + AC_CHECK_LIB(ssl, SSL_connect,, AC_MSG_ERROR([openssl not found])) + AC_MSG_NOTICE([Enabling support for SSL via OpenSSL]) + else + AC_MSG_ERROR([openssl not found: shared (eay32/ssl32) or static (crypto/ssl) libs needed]) + fi + fi + + dnl add zdll lib as dep for above tests? + ;; + *) + + AC_CHECK_LIB(crypto, EVP_MD_CTX_init) + AC_CHECK_LIB(ssl, ERR_func_error_string,, + AC_MSG_ERROR([openssl development libraries not found])) + AC_MSG_NOTICE([Enabling support for SSL via OpenSSL (static)]) + ;; + esac + AC_LIBOBJ([openssl]) +], [ + # --with-ssl is not gnutls: check if it's no + AS_IF([test x"$with_ssl" != xno], [ dnl Now actually check for -lssl - AC_LIB_HAVE_LINKFLAGS([ssl], [crypto], [ - #include - #include - #include - #include - #include - #include - #include - ], [SSL_library_init ()]) - if test x"$LIBSSL" != x - then - AC_MSG_NOTICE([compiling in support for SSL via OpenSSL]) - AC_LIBOBJ([openssl]) - elif test x"$with_ssl" != x + + AC_CHECK_LIB(z, compress) + AC_CHECK_LIB(gpg-error, gpg_err_init) + AC_CHECK_LIB(gcrypt, gcry_control) + AC_CHECK_LIB(gnutls, main) + + if test x"$ac_cv_lib_gnutls_main" != xno then - AC_MSG_ERROR([--with-ssl was given, but SSL is not available.]) + AC_MSG_NOTICE([compiling in support for SSL via GnuTLS]) + AC_LIBOBJ([gnutls]) + else + AC_MSG_ERROR([--with-ssl was given, but GNUTLS is not available.]) fi ]) # endif: --with-ssl == no? -]) # endif: --with-ssl == gnutls? +]) # endif: --with-ssl == openssl? dnl Enable NTLM if requested and if SSL is available. @@ -478,6 +503,6 @@ dnl Create output dnl AC_CONFIG_FILES([Makefile src/Makefile doc/Makefile util/Makefile po/Makefile.in tests/Makefile tests/WgetTest.pm - lib/Makefile windows/Makefile]) + lib/Makefile]) AC_CONFIG_HEADERS([src/config.h]) AC_OUTPUT