aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CMakeLists.txt27
-rw-r--r--lib/CMakeLists.txt18
-rw-r--r--src/CMakeLists.txt10
-rw-r--r--tests/CMakeLists.txt2
-rw-r--r--tests/libtest/CMakeLists.txt76
-rw-r--r--tests/server/CMakeLists.txt43
6 files changed, 149 insertions, 27 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 71442e47e..c87127be8 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -750,8 +750,33 @@ IF(MSVC)
ADD_DEFINITIONS(-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE)
ENDIF(MSVC)
+# Sets up the dependencies (zlib, OpenSSL, etc.) of a cURL subproject according to options.
+# TODO This is far to be complete!
+FUNCTION(SETUP_CURL_DEPENDENCIES TARGET_NAME)
+ IF(CURL_ZLIB AND ZLIB_FOUND)
+ INCLUDE_DIRECTORIES(${ZLIB_INCLUDE_DIR})
+ ENDIF()
+ IF(CURL_ZLIB AND ZLIB_FOUND)
+ TARGET_LINK_LIBRARIES(${TARGET_NAME} ${ZLIB_LIBRARIES})
+ #ADD_DEFINITIONS( -DHAVE_ZLIB_H -DHAVE_ZLIB -DHAVE_LIBZ )
+ ENDIF()
+
+ IF(CMAKE_USE_OPENSSL AND OPENSSL_FOUND)
+ INCLUDE_DIRECTORIES(${OPENSSL_INCLUDE_DIR})
+ ENDIF()
+ IF(CURL_SSL AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE)
+ TARGET_LINK_LIBRARIES(${TARGET_NAME} ${OPENSSL_LIBRARIES})
+ #ADD_DEFINITIONS( -DUSE_SSLEAY )
+ ENDIF()
+ENDFUNCTION()
+
ADD_SUBDIRECTORY(lib)
-ADD_SUBDIRECTORY(src)
+IF(BUILD_CURL_EXE)
+ ADD_SUBDIRECTORY(src)
+ENDIF()
+IF(BUILD_CURL_TESTS)
+ ADD_SUBDIRECTORY(tests)
+ENDIF()
# This needs to be run very last so other parts of the scripts can take advantage of this.
IF(NOT CURL_CONFIG_HAS_BEEN_RUN_BEFORE)
diff --git a/lib/CMakeLists.txt b/lib/CMakeLists.txt
index b938000c0..7e55c7d79 100644
--- a/lib/CMakeLists.txt
+++ b/lib/CMakeLists.txt
@@ -110,14 +110,6 @@ IF(CURL_MALLOC_DEBUG)
)
ENDIF(CURL_MALLOC_DEBUG)
-IF(CMAKE_USE_OPENSSL AND OPENSSL_FOUND)
- INCLUDE_DIRECTORIES(${OPENSSL_INCLUDE_DIR})
-ENDIF()
-
-IF(CURL_ZLIB AND ZLIB_FOUND)
- INCLUDE_DIRECTORIES(${ZLIB_INCLUDE_DIR})
-ENDIF()
-
IF(HAVE_FEATURES_H)
SET_SOURCE_FILES_PROPERTIES(
cookie.c
@@ -220,15 +212,7 @@ ADD_DEFINITIONS(
-DBUILDING_LIBCURL
)
-IF(CURL_ZLIB AND ZLIB_FOUND)
- TARGET_LINK_LIBRARIES(${LIB_NAME} ${ZLIB_LIBRARIES})
- #ADD_DEFINITIONS( -DHAVE_ZLIB_H -DHAVE_ZLIB -DHAVE_LIBZ )
-ENDIF()
-
-# IF(CURL_SSL AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE)
- # TARGET_LINK_LIBRARIES(${LIB_NAME} ${OPENSSL_LIBRARIES})
- # ADD_DEFINITIONS( -DUSE_SSLEAY )
-# ENDIF()
+SETUP_CURL_DEPENDENCIES(${LIB_NAME})
# Remove the "lib" prefix since the library is already named "libcurl".
SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES PREFIX "")
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 168abf422..e0e7a7855 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -47,15 +47,7 @@ INCLUDE_DIRECTORIES(
# Setup dependencies
-
-IF(CURL_ZLIB AND ZLIB_FOUND)
- TARGET_LINK_LIBRARIES(${EXE_NAME} ${ZLIB_LIBRARIES})
- #ADD_DEFINITIONS( -DHAVE_ZLIB_H -DHAVE_ZLIB -DHAVE_LIBZ )
-ENDIF()
-# IF(CURL_SSL AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE)
- # TARGET_LINK_LIBRARIES(${EXE_NAME} ${OPENSSL_LIBRARIES})
- # ADD_DEFINITIONS( -DUSE_SSLEAY )
-# ENDIF()
+SETUP_CURL_DEPENDENCIES(${EXE_NAME})
TARGET_LINK_LIBRARIES( ${EXE_NAME} libcurl )
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
new file mode 100644
index 000000000..147ef1fdd
--- /dev/null
+++ b/tests/CMakeLists.txt
@@ -0,0 +1,2 @@
+ADD_SUBDIRECTORY(libtest)
+ADD_SUBDIRECTORY(server)
diff --git a/tests/libtest/CMakeLists.txt b/tests/libtest/CMakeLists.txt
new file mode 100644
index 000000000..b0bf77187
--- /dev/null
+++ b/tests/libtest/CMakeLists.txt
@@ -0,0 +1,76 @@
+
+MACRO(SETUP_TEST TEST_NAME) # ARGN are the files in the test
+ ADD_EXECUTABLE( ${TEST_NAME} ${ARGN} )
+ STRING(TOUPPER TEST_NAME UPPER_TEST_NAME)
+
+ INCLUDE_DIRECTORIES(
+ ${CURL_SOURCE_DIR}/lib # To be able to reach "setup_once.h"
+ ${CURL_BINARY_DIR}/lib # To be able to reach "config.h"
+ ${CURL_BINARY_DIR}/include # To be able to reach "curl/curlbuild.h"
+ )
+
+ SETUP_CURL_DEPENDENCIES(${TEST_NAME})
+ TARGET_LINK_LIBRARIES( ${TEST_NAME} libcurl )
+
+ ADD_DEFINITIONS( "-D${UPPER_TEST_NAME}" )
+
+ # Add the postfix to the executable since it is not added automatically as for modules and shared libraries
+ SET_TARGET_PROPERTIES(${TEST_NAME} PROPERTIES DEBUG_POSTFIX "${CMAKE_DEBUG_POSTFIX}")
+
+ IF(MSVC)
+ IF(NOT BUILD_RELEASE_DEBUG_DIRS)
+ # Ugly workaround to remove the "/debug" or "/release" in each output
+ SET_TARGET_PROPERTIES(${TEST_NAME} PROPERTIES PREFIX "../")
+ ENDIF()
+ ENDIF()
+
+ENDMACRO()
+
+
+
+# files used only in some libcurl test programs
+SET(TESTUTIL testutil.c testutil.h)
+
+# these files are used in every single test program below
+SET(SUPPORTFILES first.c test.h)
+
+# These are all libcurl test programs
+SET(noinst_PROGRAMS
+ lib500 lib501 lib502 lib503 lib504 lib505 lib506
+ lib507 lib508 lib510 lib511 lib512 lib513 lib514 lib515 lib516
+ lib517 lib518 lib519 lib520 lib521 lib523 lib524 lib525 lib526 #lib527
+ #lib529
+ lib530
+ #lib532
+ lib533 lib536 lib537 lib540 lib541 lib542 lib543
+ lib544
+ #lib545
+ lib547
+ #lib548
+ lib549 lib552 lib553 lib554 lib555 lib556
+ lib539 lib557 lib558
+ #lib559
+ lib560
+)
+
+SET(noinst_PROGRAMS_USE_TESTUTIL
+ lib502 lib503 lib504
+ lib507
+ lib525 lib526 #lib527
+ #lib529
+ lib530
+ #lib532
+ lib533 lib536
+ lib555
+)
+
+
+FOREACH(TEST_NAME ${noinst_PROGRAMS})
+ SET(SOURCE "${TEST_NAME}.c" ${SUPPORTFILES})
+ LIST(FIND noinst_PROGRAMS_USE_TESTUTIL ${TEST_NAME} USES_TESTUTIL)
+ IF(NOT ${USES_TESTUTIL} EQUAL -1)
+ LIST(APPEND SOURCE ${TESTUTIL}) # Need TestUtil
+ ENDIF()
+ SETUP_TEST(${TEST_NAME} ${SOURCE})
+ENDFOREACH()
+
diff --git a/tests/server/CMakeLists.txt b/tests/server/CMakeLists.txt
new file mode 100644
index 000000000..b0369b846
--- /dev/null
+++ b/tests/server/CMakeLists.txt
@@ -0,0 +1,43 @@
+
+MACRO(SETUP_EXECUTABLE TEST_NAME) # ARGN are the files in the test
+ ADD_EXECUTABLE( ${TEST_NAME} ${ARGN} )
+ STRING(TOUPPER TEST_NAME UPPER_TEST_NAME)
+
+ INCLUDE_DIRECTORIES(
+ ${CURL_SOURCE_DIR}/lib # To be able to reach "setup_once.h"
+ ${CURL_BINARY_DIR}/lib # To be able to reach "config.h"
+ ${CURL_BINARY_DIR}/include # To be able to reach "curl/curlbuild.h"
+ )
+
+ SETUP_CURL_DEPENDENCIES(${TEST_NAME})
+ TARGET_LINK_LIBRARIES( ${TEST_NAME} libcurl )
+
+ ADD_DEFINITIONS( "-D${UPPER_TEST_NAME}" )
+
+ # Add the postfix to the executable since it is not added automatically as for modules and shared libraries
+ SET_TARGET_PROPERTIES(${TEST_NAME} PROPERTIES DEBUG_POSTFIX "${CMAKE_DEBUG_POSTFIX}")
+
+ IF(MSVC)
+ IF(NOT BUILD_RELEASE_DEBUG_DIRS)
+ # Ugly workaround to remove the "/debug" or "/release" in each output
+ SET_TARGET_PROPERTIES(${TEST_NAME} PROPERTIES PREFIX "../")
+ ENDIF()
+ ENDIF()
+
+ENDMACRO()
+
+
+
+SET(useful
+ getpart.c getpart.h
+ ${CURL_SOURCE_DIR}/lib/strequal.c
+ ${CURL_SOURCE_DIR}/lib/base64.c ${CURL_SOURCE_DIR}/lib/mprintf.c
+ ${CURL_SOURCE_DIR}/lib/memdebug.c ${CURL_SOURCE_DIR}/lib/timeval.c
+)
+
+SETUP_EXECUTABLE(sws sws.c util.c util.h ${useful})
+SETUP_EXECUTABLE(resolve resolve.c util.c util.h ${useful})
+SETUP_EXECUTABLE(sockfilt sockfilt.c util.c util.h ${useful} ${CURL_SOURCE_DIR}/lib/inet_pton.c)
+SETUP_EXECUTABLE(getpart testpart.c ${useful})
+SETUP_EXECUTABLE(tftpd tftpd.c util.c util.h ${useful} tftp.h)
+