From b483a1eb5ab985f6e00ff820e63031bcad006190 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Tue, 16 Feb 2021 13:23:13 +0100 Subject: [PATCH] changes acording review comments update to current PackageProject version 1.5.0 too --- CMakeLists.txt | 13 ++++--------- standalone/source/main.cpp | 5 ----- test/CMakeLists.txt | 18 +++++++----------- test/source/greeter.cpp | 5 ----- 4 files changed, 11 insertions(+), 30 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 21b7733..93af7a6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -27,12 +27,9 @@ include(cmake/CPM.cmake) CPMAddPackage( NAME PackageProject.cmake GITHUB_REPOSITORY TheLartians/PackageProject.cmake - VERSION 1.4.1 + VERSION 1.5.0 ) -# Note: If fmt is not imported, this is needed to prevent: CMake Error: install(EXPORT -# "GreeterTargets" ...) includes target "Greeter" which requires target "fmt" that is not in any -# export set. see too https://gitlab.kitware.com/cmake/cmake/-/issues/15415 CPMAddPackage( NAME fmt GIT_TAG 7.1.3 @@ -53,14 +50,12 @@ file(GLOB_RECURSE sources CONFIGURE_DEPENDS "${CMAKE_CURRENT_SOURCE_DIR}/source/ # target: add_library(Greeter INTERFACE) add_library(Greeter ${headers} ${sources}) -# EITHER: set_target_properties(Greeter PROPERTIES CXX_STANDARD 17) # OR: -target_compile_features(Greeter PUBLIC cxx_std_17) +set_target_properties(Greeter PROPERTIES CXX_STANDARD 17) # being a cross-platform target, we enforce standards conformance on MSVC target_compile_options(Greeter PUBLIC "$<$:/permissive>") -# Link dependencies EITHER: target_link_libraries(Greeter PRIVATE -# $) # OR: +# Link dependencies target_link_libraries(Greeter PUBLIC fmt::fmt) target_include_directories( @@ -84,6 +79,6 @@ packageProject( INCLUDE_DESTINATION include/${PROJECT_NAME}-${PROJECT_VERSION} VERSION_HEADER "${VERSION_HEADER_LOCATION}" COMPATIBILITY ExactVersion - # TBD COMPATIBILITY SameMajorVersion + COMPATIBILITY SameMajorVersion DEPENDENCIES "fmt 7.1.3" ) diff --git a/standalone/source/main.cpp b/standalone/source/main.cpp index 6874460..55588bb 100644 --- a/standalone/source/main.cpp +++ b/standalone/source/main.cpp @@ -8,8 +8,6 @@ // NOLINTNEXTLINE(modernize-use-trailing-return-type) int main(int argc, char** argv) { - // prevent warning: initialization of 'languages' with static storage duration may throw an - // exception that cannot be caught [cert-err58-cpp] const std::unordered_map languages{ {"en", greeter::LanguageCode::EN}, {"de", greeter::LanguageCode::DE}, @@ -17,8 +15,6 @@ int main(int argc, char** argv) { {"fr", greeter::LanguageCode::FR}, }; - // prevent warning: do not use pointer arithmetic - // [cppcoreguidelines-pro-bounds-pointer-arithmetic] cxxopts::Options options(*argv, "A program to welcome the world!"); std::string language; @@ -40,7 +36,6 @@ int main(int argc, char** argv) { return 0; } - // prevent warning: do not use 'else' after 'return' [readability-else-after-return] if (result["version"].as()) { std::cout << "Greeter, version " << GREETER_VERSION << std::endl; return 0; diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 76def2c..571feb2 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -1,6 +1,10 @@ cmake_minimum_required(VERSION 3.14 FATAL_ERROR) -project(GreeterTests LANGUAGES CXX) +project( + GreeterTests + VERSION 1.0 + LANGUAGES CXX +) # ---- Options ---- @@ -22,7 +26,7 @@ CPMAddPackage( ) if(TEST_INSTALLED_VERSION) - find_package(Greeter ${PROJECT_VERSION} REQUIRED) + find_package(Greeter ${PROJECT_VERSION} EXACT REQUIRED) else() CPMAddPackage(NAME Greeter SOURCE_DIR ${CMAKE_CURRENT_LIST_DIR}/..) endif() @@ -40,7 +44,6 @@ CPMAddPackage( file(GLOB sources CONFIGURE_DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/source/*.cpp) add_executable(GreeterTests ${sources}) target_link_libraries(GreeterTests doctest::doctest Greeter::Greeter) - set_target_properties(GreeterTests PROPERTIES CXX_STANDARD 17) # enable compiler warnings @@ -57,14 +60,7 @@ endif() enable_testing() -# Note: doctest and similar testing frameworks can automatically configure CMake tests For other -# testing frameworks add the tests target instead: -if(DEFINED doctest_SOURCE_DIR) - include(${doctest_SOURCE_DIR}/scripts/cmake/doctest.cmake) - doctest_discover_tests(GreeterTests) -else() - add_test(greeterTests GreeterTests) -endif() +add_test(NAME greeterTests COMMAND GreeterTests) # ---- code coverage ---- diff --git a/test/source/greeter.cpp b/test/source/greeter.cpp index 10a1242..2ff31ba 100644 --- a/test/source/greeter.cpp +++ b/test/source/greeter.cpp @@ -16,11 +16,6 @@ TEST_CASE("Greeter") { } TEST_CASE("Greeter version") { -#if (__cpp_lib_starts_ends_with) - static_assert(std::string_view(GREETER_VERSION).starts_with("1.0")); // TBD C++20 only - CHECK(std::string(GREETER_VERSION).starts_with("1.0")); // SameMajorVersion -#else static_assert(std::string_view(GREETER_VERSION) == std::string_view("1.0")); CHECK(std::string(GREETER_VERSION) == std::string("1.0")); -#endif }