configure: add --with-sha1={libmd,libcrypto} option
Signed-off-by: Julien Cristau <jcristau@debian.org> Reviewed-by: Rémi Cardona <remi@gentoo.org>
This commit is contained in:
		
							parent
							
								
									5551609494
								
							
						
					
					
						commit
						d2a6a39543
					
				
							
								
								
									
										50
									
								
								configure.ac
								
								
								
								
							
							
						
						
									
										50
									
								
								configure.ac
								
								
								
								
							|  | @ -1280,25 +1280,45 @@ MIEXT_SHADOW_INC='-I$(top_srcdir)/miext/shadow' | ||||||
| MIEXT_SHADOW_LIB='$(top_builddir)/miext/shadow/libshadow.la' | MIEXT_SHADOW_LIB='$(top_builddir)/miext/shadow/libshadow.la' | ||||||
| CORE_INCS='-I$(top_srcdir)/include -I$(top_builddir)/include' | CORE_INCS='-I$(top_srcdir)/include -I$(top_builddir)/include' | ||||||
| 
 | 
 | ||||||
| # OpenSSL used for SHA1 hashing in render/glyph.c, but we don't need all of | # SHA1 hashing | ||||||
| # the OpenSSL libraries, just libcrypto | AC_ARG_WITH([sha1], | ||||||
| # Some systems have matching functionality in the smaller/simpler libmd |             [AS_HELP_STRING([--with-sha1=libmd|libcrypto], | ||||||
| # Builders who want to force a choice can set SHA1_LIBS and SHA1_CFLAGS |                             [choose SHA1 implementation])]) | ||||||
| if test "x$SHA1_LIB" = "x" ; then | AC_CHECK_LIB([md], [SHA1Init], [HAVE_LIBMD=yes]) | ||||||
|   AC_CHECK_LIB([md], [SHA1Init], [SHA1_LIBS="-lmd" | if test "x$with_sha1" = x && test "x$HAVE_LIBMD" = xyes; then | ||||||
|  | 	with_sha1=libmd | ||||||
|  | fi | ||||||
|  | if test "x$with_sha1" = xlibmd && test "x$HAVE_LIBMD" != xyes; then | ||||||
|  | 	AC_MSG_ERROR([libmd requested but not found]) | ||||||
|  | fi | ||||||
|  | if test "x$with_sha1" = xlibmd; then | ||||||
| 	AC_DEFINE([HAVE_SHA1_IN_LIBMD], [1], | 	AC_DEFINE([HAVE_SHA1_IN_LIBMD], [1], | ||||||
|             [Use libmd SHA1 functions instead of OpenSSL libcrypto])]) | 	          [Use libmd SHA1 functions]) | ||||||
|  | 	SHA1_LIBS=-lmd | ||||||
| fi | fi | ||||||
| 
 | # We don't need all of the OpenSSL libraries, just libcrypto | ||||||
| if test "x$SHA1_LIB" = "x" ; then | AC_CHECK_LIB([crypto], [SHA1_Init], [HAVE_LIBCRYPTO=yes]) | ||||||
|   PKG_CHECK_EXISTS([openssl], [HAVE_OPENSSL_PKC=yes], | PKG_CHECK_MODULES([OPENSSL], [openssl], [HAVE_OPENSSL_PKC=yes], | ||||||
|                   [HAVE_OPENSSL_PKC=no]) |                   [HAVE_OPENSSL_PKC=no]) | ||||||
|   if test "x$HAVE_OPENSSL_PKC" = xyes; then | if test "x$HAVE_LIBCRYPTO" = xyes || test "x$HAVE_OPENSSL_PKC" = xyes; then | ||||||
|     PKG_CHECK_MODULES([SHA1], [openssl]) | 	if test "x$with_sha1" = x; then | ||||||
|   else | 		with_sha1=libcrypto | ||||||
|     AC_CHECK_LIB([crypto], [SHA1_Init], [SHA1_LIBS="-lcrypto"], |  | ||||||
|                  [AC_MSG_ERROR([OpenSSL must be installed in order to build the X server.])]) |  | ||||||
| 	fi | 	fi | ||||||
|  | else | ||||||
|  | 	if test "x$with_sha1" = xlibcrypto; then | ||||||
|  | 		AC_MSG_ERROR([OpenSSL libcrypto requested but not found]) | ||||||
|  | 	fi | ||||||
|  | fi | ||||||
|  | if test "x$with_sha1" = xlibcrypto; then | ||||||
|  | 	if test "x$HAVE_LIBCRYPTO" = xyes; then | ||||||
|  | 		SHA1_LIBS=-lcrypto | ||||||
|  | 	else | ||||||
|  | 		SHA1_LIBS="$OPENSSL_LIBS" | ||||||
|  | 		SHA1_CFLAGS="$OPENSSL_CFLAGS" | ||||||
|  | 	fi | ||||||
|  | fi | ||||||
|  | if test "x$with_sha1" = x; then | ||||||
|  | 	AC_MSG_ERROR([No suitable SHA1 implementation found]) | ||||||
| fi | fi | ||||||
| AC_SUBST(SHA1_LIBS) | AC_SUBST(SHA1_LIBS) | ||||||
| AC_SUBST(SHA1_CFLAGS) | AC_SUBST(SHA1_CFLAGS) | ||||||
|  |  | ||||||
|  | @ -160,7 +160,7 @@ | ||||||
| /* Define to 1 if you have the <rpcsvc/dbm.h> header file. */ | /* Define to 1 if you have the <rpcsvc/dbm.h> header file. */ | ||||||
| #undef HAVE_RPCSVC_DBM_H | #undef HAVE_RPCSVC_DBM_H | ||||||
| 
 | 
 | ||||||
| /* Define to use libmd SHA1 functions instead of OpenSSL libcrypto */ | /* Define to use libmd SHA1 functions */ | ||||||
| #undef HAVE_SHA1_IN_LIBMD | #undef HAVE_SHA1_IN_LIBMD | ||||||
| 
 | 
 | ||||||
| /* Define to 1 if you have the `shmctl64' function. */ | /* Define to 1 if you have the `shmctl64' function. */ | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue