mirror of
https://github.com/curl/curl.git
synced 2026-04-14 22:51:53 +03:00
cmake: omit linking duplicate/unnecessary libs to tests & examples
Before this patch we explicitly linked the full list of libcurl dependency libs to tests and examples via `CURL_LIBS`. This was redundant, because test and example code do not directly use these dependency libs and for indirect use they are implicitly passed via libcurl as needed. After this patch, tests and examples only link explicitly to system libs (e.g. socket). Also bringing it closer to how `./configure` does this. Borrow the variable name `CURL_NETWORK_AND_TIME_LIBS` from `./configure`. However, its content is not exactly the same. With cmake it also holds `pthread`, but doesn't hold AmiSSL. Closes #17696
This commit is contained in:
parent
8e1d817cb3
commit
58b9c6134b
5 changed files with 14 additions and 11 deletions
|
|
@ -362,6 +362,7 @@ endif()
|
|||
option(CURL_USE_PKGCONFIG "Enable pkg-config to detect dependencies" ${_curl_use_pkgconfig_default})
|
||||
|
||||
# Initialize variables collecting dependency libs, paths, pkg-config names.
|
||||
set(CURL_NETWORK_AND_TIME_LIBS "")
|
||||
set(CURL_LIBS "")
|
||||
set(CURL_LIBDIRS "")
|
||||
set(LIBCURL_PC_REQUIRES_PRIVATE "")
|
||||
|
|
@ -544,9 +545,9 @@ endif()
|
|||
|
||||
# If we are on Haiku, make sure that the network library is brought in.
|
||||
if(CMAKE_SYSTEM_NAME STREQUAL "Haiku")
|
||||
list(APPEND CURL_LIBS "network")
|
||||
list(APPEND CURL_NETWORK_AND_TIME_LIBS "network")
|
||||
elseif(AMIGA)
|
||||
list(APPEND CURL_LIBS "net" "m" "atomic")
|
||||
list(APPEND CURL_NETWORK_AND_TIME_LIBS "net" "m" "atomic")
|
||||
list(APPEND CMAKE_REQUIRED_LIBRARIES "net" "m" "atomic")
|
||||
endif()
|
||||
|
||||
|
|
@ -591,7 +592,7 @@ if(ENABLE_THREADED_RESOLVER)
|
|||
find_package(Threads REQUIRED)
|
||||
set(USE_THREADS_POSIX ${CMAKE_USE_PTHREADS_INIT})
|
||||
set(HAVE_PTHREAD_H ${CMAKE_USE_PTHREADS_INIT})
|
||||
list(APPEND CURL_LIBS ${CMAKE_THREAD_LIBS_INIT})
|
||||
list(APPEND CURL_NETWORK_AND_TIME_LIBS ${CMAKE_THREAD_LIBS_INIT})
|
||||
endif()
|
||||
endif()
|
||||
|
||||
|
|
@ -614,7 +615,7 @@ elseif(DOS)
|
|||
if(WATT_ROOT)
|
||||
set(USE_WATT32 ON)
|
||||
# FIXME upstream: must specify the full path to avoid CMake converting "watt" to "watt.lib"
|
||||
list(APPEND CURL_LIBS "${WATT_ROOT}/lib/libwatt.a")
|
||||
list(APPEND CURL_NETWORK_AND_TIME_LIBS "${WATT_ROOT}/lib/libwatt.a")
|
||||
include_directories(SYSTEM "${WATT_ROOT}/inc")
|
||||
list(APPEND CMAKE_REQUIRED_INCLUDES "${WATT_ROOT}/inc")
|
||||
else()
|
||||
|
|
@ -634,7 +635,7 @@ elseif(AMIGA)
|
|||
elseif(NOT APPLE)
|
||||
check_library_exists("socket" "connect" "" HAVE_LIBSOCKET)
|
||||
if(HAVE_LIBSOCKET)
|
||||
set(CURL_LIBS "socket" ${CURL_LIBS})
|
||||
set(CURL_NETWORK_AND_TIME_LIBS "socket" ${CURL_NETWORK_AND_TIME_LIBS})
|
||||
endif()
|
||||
endif()
|
||||
|
||||
|
|
@ -1944,9 +1945,9 @@ include(CMake/OtherTests.cmake)
|
|||
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS "HAVE_CONFIG_H")
|
||||
|
||||
if(WIN32)
|
||||
list(APPEND CURL_LIBS "${_win32_winsock}")
|
||||
list(APPEND CURL_NETWORK_AND_TIME_LIBS "${_win32_winsock}")
|
||||
if(NOT WINCE AND NOT WINDOWS_STORE)
|
||||
list(APPEND CURL_LIBS "iphlpapi")
|
||||
list(APPEND CURL_NETWORK_AND_TIME_LIBS "iphlpapi")
|
||||
endif()
|
||||
if(NOT WINCE)
|
||||
list(APPEND CURL_LIBS "bcrypt")
|
||||
|
|
@ -1973,6 +1974,8 @@ if(WIN32)
|
|||
endif()
|
||||
endif()
|
||||
|
||||
list(APPEND CURL_LIBS ${CURL_NETWORK_AND_TIME_LIBS})
|
||||
|
||||
if(CMAKE_C_COMPILER_ID STREQUAL "MSVC") # MSVC but exclude clang-cl
|
||||
set_property(DIRECTORY APPEND PROPERTY COMPILE_OPTIONS "-MP") # Parallel compilation
|
||||
endif()
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue