aboutsummaryrefslogtreecommitdiff
path: root/CMakeLists.txt
diff options
context:
space:
mode:
authorXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-10-15 22:37:11 +0200
committerXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-10-25 13:45:12 +0200
commitb2be8b4658deea570b2a1890b6b45a7b2e95b615 (patch)
tree3e15b4277bc1a97c9c5f3ed9c0031f6c1a3d26e2 /CMakeLists.txt
parentfc3db3927747fc98fb1378f46f232ef932b773e0 (diff)
downloadslcl-b2be8b4658deea570b2a1890b6b45a7b2e95b615.tar.gz
CMake: Find system libweb or dynstr if available
So far, slcl's build system would always build libweb and dynstr. However, this is discouraged by distribution packagers.
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r--CMakeLists.txt12
1 files changed, 11 insertions, 1 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 391b093..03df184 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -12,7 +12,17 @@ add_executable(${PROJECT_NAME}
)
target_compile_options(${PROJECT_NAME} PRIVATE -Wall)
target_compile_definitions(${PROJECT_NAME} PRIVATE _FILE_OFFSET_BITS=64)
-add_subdirectory(libweb)
+set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_LIST_DIR}/cmake)
+find_package(web 0.1.0)
+
+if(WEB_FOUND)
+ find_package(dynstr 0.1.0)
+else()
+ message(STATUS "Using in-tree libweb")
+ add_subdirectory(libweb)
+ #dynstr is already provided by libweb.
+endif()
+
find_package(cJSON 1.0 REQUIRED)
find_package(OpenSSL 2.0 REQUIRED)
target_link_libraries(${PROJECT_NAME} PRIVATE web dynstr cjson OpenSSL::SSL)