Fixed IPv4/v6 support checks
[umurmur.git] / CMakeLists.txt
index f0b38512fdfbd4c0a3e743fecaf51a94c2095db1..7ff95a019e777695b7bd49f50a8d33234cdc593f 100644 (file)
@@ -5,19 +5,32 @@ project(umurmurd C)
 set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_SOURCE_DIR}/cmake/Modules/")
 set(CMAKE_INSTALL_RPATH_USE_LINK_PATH true)
 
+option(USE_POLARSSL_TESTCERT "Link to the PolarSSL test certificate and key." OFF)
+option(USE_POLARSSL_HAVEGE "Use the PolarSSL HAVEGE random generator key." OFF)
+
+if(USE_POLARSSL_TESTCERT OR USE_POLARSSL_HAVEGE)
+  if(SSL MATCHES "openssl" OR SSL MATCHES "gnutls")
+    message(FATAL_ERROR "Selecting USE_POLARSSL_TESTCERT or USE_POLARSSL_HAVEGE implies SSL=polarssl")
+  endif(SSL MATCHES "openssl" OR SSL MATCHES "gnutls")
+endif(USE_POLARSSL_TESTCERT OR USE_POLARSSL_HAVEGE)
+
 find_package(Libconfig REQUIRED)
 find_package(ProtobufC REQUIRED)
 include(CheckFunctionExists)
 include(CheckLibraryExists)
 
-if(SSL MATCHES "openssl")
+if("${SSL}" STREQUAL "")
+  set(SSL "polarssl")
+endif("${SSL}" STREQUAL "")
+
+if("${SSL}" STREQUAL "openssl")
   find_package(OpenSSL REQUIRED)
   if(OPENSSL_FOUND)
     set(SSLIMP_LIBRARIES ${OPENSSL_LIBRARIES})
     set(SSLIMP_INCLUDE_DIR ${OPENSSL_INCLUDE_DIR})
     set(SSLIMP_LIBRARY_DIR ${OPENSSL_LIB_DIR})
   endif(OPENSSL_FOUND)
-else(SSL MATCHES "openssl")
+elseif("${SSL}" STREQUAL "polarssl")
   find_package(PolarSSL REQUIRED)
   if(POLARSSL_FOUND)
     set(USE_POLARSSL ON)
@@ -25,20 +38,27 @@ else(SSL MATCHES "openssl")
     set(SSLIMP_INCLUDE_DIR ${POLARSSL_INCLUDE_DIR})
     set(SSLIMP_LIBRARY_DIR ${POLARSSL_LIB_DIR})
   endif(POLARSSL_FOUND)
-endif(SSL MATCHES "openssl")
+elseif("${SSL}" STREQUAL "gnutls")
+  find_package(GnuTLS REQUIRED)
+  if(GNUTLS_FOUND)
+    set(SSLIMP_LIBRARIES ${GNUTLS_LIBRARIES})
+    set(SSLIMP_INCLUDE_DIR ${GNUTLS_INCLUDE_DIR})
+    set(SSLIMP_LIBRARY_DIR ${GNUTLS_LIB_DIR})
+  endif(GNUTLS_FOUND)
+endif("${SSL}" STREQUAL "openssl")
 
-check_function_exists(clock_gettime HAVE_CLOCK_GETTIME)
+check_library_exists(rt clock_gettime "time.h" HAVE_CLOCK_GETTIME_RT)
 
-if(NOT HAVE_CLOCK_GETTIME)
-  check_library_exists(rt clock_gettime "time.h" HAVE_CLOCK_GETTIME_RT)
-  if(NOT HAVE_CLOCK_GETTIME_RT)
+if(NOT HAVE_CLOCK_GETTIME_RT)
+  check_function_exists(clock_gettime HAVE_CLOCK_GETTIME)
+  if(NOT HAVE_CLOCK_GETTIME)
     check_library_exists(c clock_get_time "mach/time.h" HAVE_CLOCK_GET_TIME)
     if(NOT HAVE_CLOCK_GET_TIME)
       message(FATAL_ERROR "Didn't find clock_gettime() or clock_get_time!")
     endif()
-  else()
-    set(LIBRT rt)
   endif()
+else()
+  set(LIBRT rt)
 endif()
 
 set(SOURCE "")