From: Aaron Bishop Date: Thu, 2 Aug 2018 14:35:39 +0000 (-0400) Subject: Modernize cmake X-Git-Tag: v2.11.0-rc1~204^2~3^2~5^2 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3866386b6d7c60572d13de5e3ce6b984fa044a9c;p=icinga2 Modernize cmake * Able to use as subfolder * Able to install (and import again in cmake) * Able to disable tests * Able to disable samples --- diff --git a/CMakeLists.txt b/CMakeLists.txt index 667d2881d..8cac0a1f5 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,13 +1,42 @@ -cmake_minimum_required (VERSION 2.8.0) -project (utf8cpp) -include_directories ("${PROJECT_SOURCE_DIR}/source") +cmake_minimum_required (VERSION 3.0.2) +project (utf8cpp VERSION 2.3.5 LANGUAGES CXX) -add_executable(smoke ${PROJECT_SOURCE_DIR}/test_drivers/smoke_test/test.cpp) -add_executable(negative ${PROJECT_SOURCE_DIR}/test_drivers/negative/negative.cpp) -add_executable(utf8reader ${PROJECT_SOURCE_DIR}/test_drivers/utf8reader/utf8reader.cpp) +option(UTF8_TESTS "Enable tests for UTF8-CPP" On) +option(UTF8_SAMPLES "Enable building samples for UTF8-CPP" On) -add_executable(docsample ${PROJECT_SOURCE_DIR}/samples/docsample.cpp) +add_library(utf8cpp INTERFACE) +target_include_directories(utf8cpp INTERFACE + "$" + $ +) +add_library(utf8::cpp ALIAS utf8cpp) -enable_testing() -add_test(smoke_test smoke) -add_test(negative_test negative ${PROJECT_SOURCE_DIR}/test_data/negative/utf8_invalid.txt) +if(WIN32 AND NOT CYGWIN) + set(DEF_INSTALL_CMAKE_DIR CMake) +else() + set(DEF_INSTALL_CMAKE_DIR ${CMAKE_INSTALL_LIBDIR}/cmake/utf8cpp) +endif() + +install(DIRECTORY source/ DESTINATION include/utf8cpp) +install(TARGETS utf8cpp EXPORT utf8cppConfig) +install(EXPORT utf8cppConfig DESTINATION ${DEF_INSTALL_CMAKE_DIR}) + +if(UTF8_SAMPLES) + add_executable(utf8reader ${PROJECT_SOURCE_DIR}/test_drivers/utf8reader/utf8reader.cpp) + add_executable(docsample ${PROJECT_SOURCE_DIR}/samples/docsample.cpp) + + target_link_libraries(utf8reader PRIVATE utf8::cpp) + target_link_libraries(docsample PRIVATE utf8::cpp) +endif() + +if(UTF8_TESTS) + add_executable(smoke ${PROJECT_SOURCE_DIR}/test_drivers/smoke_test/test.cpp) + add_executable(negative ${PROJECT_SOURCE_DIR}/test_drivers/negative/negative.cpp) + + target_link_libraries(smoke PRIVATE utf8::cpp) + target_link_libraries(negative PRIVATE utf8::cpp) + + enable_testing() + add_test(smoke_test smoke) + add_test(negative_test negative ${PROJECT_SOURCE_DIR}/test_data/negative/utf8_invalid.txt) +endif()