mirror of
https://github.com/TheLartians/ModernCppStarter.git
synced 2025-08-31 22:21:13 +02:00
changes acording review comments
update to current PackageProject version 1.5.0 too
This commit is contained in:
parent
f76aa76a81
commit
b483a1eb5a
4 changed files with 11 additions and 30 deletions
|
@ -27,12 +27,9 @@ include(cmake/CPM.cmake)
|
||||||
CPMAddPackage(
|
CPMAddPackage(
|
||||||
NAME PackageProject.cmake
|
NAME PackageProject.cmake
|
||||||
GITHUB_REPOSITORY TheLartians/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(
|
CPMAddPackage(
|
||||||
NAME fmt
|
NAME fmt
|
||||||
GIT_TAG 7.1.3
|
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)
|
# target: add_library(Greeter INTERFACE)
|
||||||
add_library(Greeter ${headers} ${sources})
|
add_library(Greeter ${headers} ${sources})
|
||||||
|
|
||||||
# EITHER: set_target_properties(Greeter PROPERTIES CXX_STANDARD 17) # OR:
|
set_target_properties(Greeter PROPERTIES CXX_STANDARD 17)
|
||||||
target_compile_features(Greeter PUBLIC cxx_std_17)
|
|
||||||
|
|
||||||
# being a cross-platform target, we enforce standards conformance on MSVC
|
# being a cross-platform target, we enforce standards conformance on MSVC
|
||||||
target_compile_options(Greeter PUBLIC "$<$<COMPILE_LANG_AND_ID:CXX,MSVC>:/permissive>")
|
target_compile_options(Greeter PUBLIC "$<$<COMPILE_LANG_AND_ID:CXX,MSVC>:/permissive>")
|
||||||
|
|
||||||
# Link dependencies EITHER: target_link_libraries(Greeter PRIVATE
|
# Link dependencies
|
||||||
# $<BUILD_INTERFACE:fmt::fmt-header-only>) # OR:
|
|
||||||
target_link_libraries(Greeter PUBLIC fmt::fmt)
|
target_link_libraries(Greeter PUBLIC fmt::fmt)
|
||||||
|
|
||||||
target_include_directories(
|
target_include_directories(
|
||||||
|
@ -84,6 +79,6 @@ packageProject(
|
||||||
INCLUDE_DESTINATION include/${PROJECT_NAME}-${PROJECT_VERSION}
|
INCLUDE_DESTINATION include/${PROJECT_NAME}-${PROJECT_VERSION}
|
||||||
VERSION_HEADER "${VERSION_HEADER_LOCATION}"
|
VERSION_HEADER "${VERSION_HEADER_LOCATION}"
|
||||||
COMPATIBILITY ExactVersion
|
COMPATIBILITY ExactVersion
|
||||||
# TBD COMPATIBILITY SameMajorVersion
|
COMPATIBILITY SameMajorVersion
|
||||||
DEPENDENCIES "fmt 7.1.3"
|
DEPENDENCIES "fmt 7.1.3"
|
||||||
)
|
)
|
||||||
|
|
|
@ -8,8 +8,6 @@
|
||||||
|
|
||||||
// NOLINTNEXTLINE(modernize-use-trailing-return-type)
|
// NOLINTNEXTLINE(modernize-use-trailing-return-type)
|
||||||
int main(int argc, char** argv) {
|
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<std::string, greeter::LanguageCode> languages{
|
const std::unordered_map<std::string, greeter::LanguageCode> languages{
|
||||||
{"en", greeter::LanguageCode::EN},
|
{"en", greeter::LanguageCode::EN},
|
||||||
{"de", greeter::LanguageCode::DE},
|
{"de", greeter::LanguageCode::DE},
|
||||||
|
@ -17,8 +15,6 @@ int main(int argc, char** argv) {
|
||||||
{"fr", greeter::LanguageCode::FR},
|
{"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!");
|
cxxopts::Options options(*argv, "A program to welcome the world!");
|
||||||
|
|
||||||
std::string language;
|
std::string language;
|
||||||
|
@ -40,7 +36,6 @@ int main(int argc, char** argv) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// prevent warning: do not use 'else' after 'return' [readability-else-after-return]
|
|
||||||
if (result["version"].as<bool>()) {
|
if (result["version"].as<bool>()) {
|
||||||
std::cout << "Greeter, version " << GREETER_VERSION << std::endl;
|
std::cout << "Greeter, version " << GREETER_VERSION << std::endl;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
cmake_minimum_required(VERSION 3.14 FATAL_ERROR)
|
cmake_minimum_required(VERSION 3.14 FATAL_ERROR)
|
||||||
|
|
||||||
project(GreeterTests LANGUAGES CXX)
|
project(
|
||||||
|
GreeterTests
|
||||||
|
VERSION 1.0
|
||||||
|
LANGUAGES CXX
|
||||||
|
)
|
||||||
|
|
||||||
# ---- Options ----
|
# ---- Options ----
|
||||||
|
|
||||||
|
@ -22,7 +26,7 @@ CPMAddPackage(
|
||||||
)
|
)
|
||||||
|
|
||||||
if(TEST_INSTALLED_VERSION)
|
if(TEST_INSTALLED_VERSION)
|
||||||
find_package(Greeter ${PROJECT_VERSION} REQUIRED)
|
find_package(Greeter ${PROJECT_VERSION} EXACT REQUIRED)
|
||||||
else()
|
else()
|
||||||
CPMAddPackage(NAME Greeter SOURCE_DIR ${CMAKE_CURRENT_LIST_DIR}/..)
|
CPMAddPackage(NAME Greeter SOURCE_DIR ${CMAKE_CURRENT_LIST_DIR}/..)
|
||||||
endif()
|
endif()
|
||||||
|
@ -40,7 +44,6 @@ CPMAddPackage(
|
||||||
file(GLOB sources CONFIGURE_DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/source/*.cpp)
|
file(GLOB sources CONFIGURE_DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/source/*.cpp)
|
||||||
add_executable(GreeterTests ${sources})
|
add_executable(GreeterTests ${sources})
|
||||||
target_link_libraries(GreeterTests doctest::doctest Greeter::Greeter)
|
target_link_libraries(GreeterTests doctest::doctest Greeter::Greeter)
|
||||||
|
|
||||||
set_target_properties(GreeterTests PROPERTIES CXX_STANDARD 17)
|
set_target_properties(GreeterTests PROPERTIES CXX_STANDARD 17)
|
||||||
|
|
||||||
# enable compiler warnings
|
# enable compiler warnings
|
||||||
|
@ -57,14 +60,7 @@ endif()
|
||||||
|
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
|
||||||
# Note: doctest and similar testing frameworks can automatically configure CMake tests For other
|
add_test(NAME greeterTests COMMAND GreeterTests)
|
||||||
# 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()
|
|
||||||
|
|
||||||
# ---- code coverage ----
|
# ---- code coverage ----
|
||||||
|
|
||||||
|
|
|
@ -16,11 +16,6 @@ TEST_CASE("Greeter") {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("Greeter version") {
|
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"));
|
static_assert(std::string_view(GREETER_VERSION) == std::string_view("1.0"));
|
||||||
CHECK(std::string(GREETER_VERSION) == std::string("1.0"));
|
CHECK(std::string(GREETER_VERSION) == std::string("1.0"));
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue