1
0
mirror of https://github.com/rkd77/elinks.git synced 2024-12-04 14:46:47 -05:00

configure: More extensible choice of SSL library

In 0.13.GIT, the configure script sets disable_gnutls=yes if it
decides to use nss_compat_ossl.  In recent elinks-0.12, the script
logs "explicitly disabled" if $disable_gnutls is set.  Thus, merging
those together could have caused an incorrect claim to be logged.

Rearrange the logic to make it easier to extend to multiple libraries.
Code that deals with one library no longer needs to worry about each
alternative library separately.  Instead just test and set the one
shared chosen_ssl_library variable.

While at it, get rid of openssl_withval, which merely mirrored the
with_openssl variable provided by Autoconf.
This commit is contained in:
Kalle Olavi Niemitalo 2009-05-23 01:57:23 +03:00 committed by Kalle Olavi Niemitalo
parent a7fe06be06
commit 3d4919507a

View File

@ -1001,35 +1001,40 @@ AC_SUBST(CONFIG_SCRIPTING)
# For wiping SSL hooks.. # For wiping SSL hooks..
#ifdef CONFIG_SSL #ifdef CONFIG_SSL
disable_openssl="" chosen_ssl_library=""
disable_gnutls=""
enable_gnutls=""
AC_ARG_WITH(gnutls, [[ --without-gnutls disable GNUTLS SSL support]]) AC_ARG_WITH(gnutls, [[ --without-gnutls disable GNUTLS SSL support]])
AC_ARG_WITH(gnutls, [[ --with-gnutls enable GNUTLS SSL support]], AC_ARG_WITH(gnutls, [[ --with-gnutls enable GNUTLS SSL support]],
[case "$with_gnutls" in [case "$with_gnutls" in
"no") disable_gnutls=yes;; "no") : ;;
"yes") enable_gnutls=yes; disable_openssl=yes;; "yes") chosen_ssl_library="GNUTLS" ;;
*) AC_MSG_WARN([[Support for --with-gnutls=DIR has been removed. *) chosen_ssl_library="GNUTLS"
You may have to set the PKG_CONFIG_PATH environment variable instead.]]);; AC_MSG_WARN([[Support for --with-gnutls=DIR has been removed.
You may have to set the PKG_CONFIG_PATH environment variable instead.]]) ;;
esac]) esac])
AC_ARG_WITH(openssl, [ --without-openssl disable OpenSSL support], AC_ARG_WITH(openssl, [[ --without-openssl disable OpenSSL support]])
[if test "$with_openssl" = no; then disable_openssl=yes; fi]) AC_ARG_WITH(openssl, [[ --with-openssl[=DIR] enable OpenSSL support (default)]],
AC_ARG_WITH(openssl, [[ --with-openssl[=DIR] enable OpenSSL support (default)]]) [case "$with_openssl" in
openssl_withval="$withval" "no") : ;;
*) chosen_ssl_library="OpenSSL" ;;
esac])
# ---- OpenSSL # ---- OpenSSL
AC_MSG_CHECKING([for OpenSSL]) AC_MSG_CHECKING([for OpenSSL])
EL_SAVE_FLAGS EL_SAVE_FLAGS
cf_result="no"
if test "$disable_openssl" = yes; then if test "$with_openssl" = no; then
cf_result="not used" cf_result="explicitly disabled"
elif test -n "$chosen_ssl_library" && test "$chosen_ssl_library" != "OpenSSL"; then
cf_result="not used, because $chosen_ssl_library was chosen"
else else
for ssldir in "$openssl_withval" "" /usr /usr/local/openssl \ cf_result=no
for ssldir in "$with_openssl" "" /usr /usr/local/openssl \
/usr/lib/openssl /usr/local/ssl \ /usr/lib/openssl /usr/local/ssl \
/usr/local/www /usr/lib/ssl /usr/local \ /usr/local/www /usr/lib/ssl /usr/local \
/usr/pkg /opt /opt/openssl; do /usr/pkg /opt /opt/openssl; do
@ -1055,12 +1060,13 @@ else
done done
if test "$cf_result" != yes; then if test "$cf_result" != yes; then
if test -n "$openssl_withval" && test "x$openssl_withval" != xno; then if test "${with_openssl-no}" != "no"; then
AC_MSG_ERROR([OpenSSL not found]) AC_MSG_ERROR([OpenSSL not found])
fi fi
EL_RESTORE_FLAGS EL_RESTORE_FLAGS
else else
EL_CONFIG(CONFIG_OPENSSL, [OpenSSL]) EL_CONFIG(CONFIG_OPENSSL, [OpenSSL])
chosen_ssl_library="OpenSSL"
CFLAGS="$CFLAGS_X" CFLAGS="$CFLAGS_X"
AC_SUBST(OPENSSL_CFLAGS) AC_SUBST(OPENSSL_CFLAGS)
@ -1069,16 +1075,21 @@ fi
AC_MSG_RESULT($cf_result) AC_MSG_RESULT($cf_result)
CONFIG_GNUTLS_OPENSSL_COMPAT=no
# ---- GNU TLS # ---- GNU TLS
if test "$cf_result" = yes; then
AC_MSG_CHECKING([[for GNUTLS]])
AC_MSG_RESULT([[not used, because OpenSSL was chosen]])
elif test -n "$disable_gnutls"; then # GnuTLS 2.2.0 changed libgnutls-openssl from GPLv2+
# to GPLv3+. Don't link that with the GPLv2 ELinks.
# ELinks will use its internal MD5 code instead.
CONFIG_GNUTLS_OPENSSL_COMPAT=no
if test "$with_gnutls" = no; then
AC_MSG_CHECKING([[for GNUTLS]]) AC_MSG_CHECKING([[for GNUTLS]])
AC_MSG_RESULT([[explicitly disabled]]) AC_MSG_RESULT([[explicitly disabled]])
elif test -n "$chosen_ssl_library" && test "$chosen_ssl_library" != "GNUTLS"; then
AC_MSG_CHECKING([[for GNUTLS]])
AC_MSG_RESULT([[not used, because $chosen_ssl_library was chosen]])
else else
cf_result=no cf_result=no
AC_MSG_CHECKING([[for GNUTLS (1.2 or later) in pkg-config]]) AC_MSG_CHECKING([[for GNUTLS (1.2 or later) in pkg-config]])
@ -1107,14 +1118,11 @@ else
if test "$cf_result" = yes; then if test "$cf_result" = yes; then
EL_CONFIG(CONFIG_GNUTLS, [GNUTLS]) EL_CONFIG(CONFIG_GNUTLS, [GNUTLS])
chosen_ssl_library="GNUTLS"
LIBS="$GNUTLS_LIBS $LIBS" LIBS="$GNUTLS_LIBS $LIBS"
AC_SUBST(GNUTLS_CFLAGS) AC_SUBST(GNUTLS_CFLAGS)
# GnuTLS 2.2.0 changed libgnutls-openssl from GPLv2+
# to GPLv3+. Don't link that with the GPLv2 ELinks.
# ELinks will use its internal MD5 code instead.
CONFIG_GNUTLS_OPENSSL_COMPAT=no
elif test "${with_gnutls-no}" != "no"; then elif test "${with_gnutls-no}" != "no"; then
AC_MSG_ERROR([[GNUTLS (1.2 or later) not found. ELinks no longer supports GNUTLS 1.1.]]) AC_MSG_ERROR([[GNUTLS (1.2 or later) not found. ELinks no longer supports GNUTLS 1.1.]])
fi fi