mirror of
				https://github.com/TheLartians/ModernCppStarter.git
				synced 2025-10-31 02:01:33 +01:00 
			
		
		
		
	Merge branch 'master' into develop
This commit is contained in:
		
						commit
						9d1c7413f0
					
				
					 7 changed files with 27 additions and 38 deletions
				
			
		|  | @ -29,17 +29,13 @@ include(cmake/CPM.cmake) | ||||||
| CPMUsePackageLock(package-lock.cmake) | CPMUsePackageLock(package-lock.cmake) | ||||||
| 
 | 
 | ||||||
| # PackageProject.cmake will be used to make our target installable | # PackageProject.cmake will be used to make our target installable | ||||||
| CPMAddPackage( | CPMAddPackage("gh:TheLartians/PackageProject.cmake@1.4.1") | ||||||
|   NAME PackageProject.cmake |  | ||||||
|   GITHUB_REPOSITORY TheLartians/PackageProject.cmake |  | ||||||
|   VERSION 1.5.0 |  | ||||||
| ) |  | ||||||
| 
 | 
 | ||||||
| CPMAddPackage( | CPMAddPackage( | ||||||
|   NAME fmt |   NAME fmt | ||||||
|   GIT_TAG 7.1.3 |   GIT_TAG 7.1.3 | ||||||
|   GITHUB_REPOSITORY fmtlib/fmt # to get an installable target |   GITHUB_REPOSITORY fmtlib/fmt | ||||||
|   OPTIONS "FMT_INSTALL YES" |   OPTIONS "FMT_INSTALL YES" # create an installable target | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| # ---- Add source files ---- | # ---- Add source files ---- | ||||||
|  | @ -52,19 +48,18 @@ file(GLOB_RECURSE sources CONFIGURE_DEPENDS source/*.cpp) | ||||||
| # ---- Create library ---- | # ---- Create library ---- | ||||||
| 
 | 
 | ||||||
| # Note: for header-only libraries change all PUBLIC flags to INTERFACE and create an interface | # Note: for header-only libraries change all PUBLIC flags to INTERFACE and create an interface | ||||||
| # target! EITHER: add_library(Greeter INTERFACE) OR: | # target: add_library(Greeter INTERFACE) | ||||||
| add_library(Greeter ${headers} ${sources}) | add_library(Greeter ${headers} ${sources}) | ||||||
| set_target_properties(Greeter PROPERTIES CXX_STANDARD ${CMAKE_CXX_STANDARD}) | set_target_properties(Greeter PROPERTIES CXX_STANDARD ${CMAKE_CXX_STANDARD}) | ||||||
| 
 | 
 | ||||||
| # for SameMajorVersion upgrade stategie | # for SameMajorVersion upgrade stategie | ||||||
| set_target_properties(Greeter PROPERTIES SOVERSION 1 VERSION ${PROJECT_VERSION}) | set_target_properties(Greeter PROPERTIES SOVERSION 1 VERSION ${PROJECT_VERSION}) | ||||||
| 
 | 
 | ||||||
| # 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: | # Link dependencies | ||||||
| target_link_libraries(Greeter PRIVATE $<BUILD_INTERFACE:fmt::fmt-header-only>) | target_link_libraries(Greeter PUBLIC fmt::fmt) | ||||||
| # OR: target_link_libraries(Greeter PUBLIC fmt::fmt) |  | ||||||
| 
 | 
 | ||||||
| set(INCLUDE_INSTALL_DIR include/${PROJECT_NAME}-${PROJECT_VERSION}) | set(INCLUDE_INSTALL_DIR include/${PROJECT_NAME}-${PROJECT_VERSION}) | ||||||
| target_include_directories( | target_include_directories( | ||||||
|  | @ -96,5 +91,5 @@ packageProject( | ||||||
|   INCLUDE_DESTINATION ${INCLUDE_INSTALL_DIR} |   INCLUDE_DESTINATION ${INCLUDE_INSTALL_DIR} | ||||||
|   VERSION_HEADER "${VERSION_HEADER_LOCATION}" |   VERSION_HEADER "${VERSION_HEADER_LOCATION}" | ||||||
|   COMPATIBILITY SameMajorVersion |   COMPATIBILITY SameMajorVersion | ||||||
|   # Note: not needed DEPENDENCIES "fmt 7.1.3" |   DEPENDENCIES "fmt 7.1.3" | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | @ -34,7 +34,10 @@ This template is the result of learnings from many previous projects and should | ||||||
| 
 | 
 | ||||||
| ### Adjust the template to your needs | ### Adjust the template to your needs | ||||||
| 
 | 
 | ||||||
| - Use this repo [as a template](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/creating-a-repository-from-a-template) and replace all occurrences of "Greeter" in the relevant CMakeLists.txt with the name of your project | - Use this repo [as a template](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/creating-a-repository-from-a-template). | ||||||
|  | - Replace all occurrences of "Greeter" in the relevant CMakeLists.txt with the name of your project | ||||||
|  |   - Capitalization matters here: `Greeter` means the name of the project, while `greeter` is used in file names. | ||||||
|  |   - Remember to rename the `include/greeter` directory to use your project's lowercase name and update all relevant `#include`s accordingly. | ||||||
| - Replace the source files with your own | - Replace the source files with your own | ||||||
| - For header-only libraries: see the comments in [CMakeLists.txt](CMakeLists.txt) | - For header-only libraries: see the comments in [CMakeLists.txt](CMakeLists.txt) | ||||||
| - Add [your project's codecov token](https://docs.codecov.io/docs/quick-start) to your project's github secrets under `CODECOV_TOKEN` | - Add [your project's codecov token](https://docs.codecov.io/docs/quick-start) to your project's github secrets under `CODECOV_TOKEN` | ||||||
|  |  | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| set(CPM_DOWNLOAD_VERSION 0.30.0) | set(CPM_DOWNLOAD_VERSION 0.31.0) | ||||||
| 
 | 
 | ||||||
| if(CPM_SOURCE_CACHE) | if(CPM_SOURCE_CACHE) | ||||||
|   # Expand relative path. This is important if the provided path contains a tilde (~) |   # Expand relative path. This is important if the provided path contains a tilde (~) | ||||||
|  |  | ||||||
|  | @ -11,12 +11,7 @@ include(../cmake/tools.cmake) | ||||||
| include(../cmake/CPM.cmake) | include(../cmake/CPM.cmake) | ||||||
| CPMUsePackageLock(package-lock.cmake) | CPMUsePackageLock(package-lock.cmake) | ||||||
| 
 | 
 | ||||||
| CPMAddPackage( | CPMAddPackage("gh:jarro2783/cxxopts@2.2.0") | ||||||
|   NAME cxxopts |  | ||||||
|   GITHUB_REPOSITORY jarro2783/cxxopts |  | ||||||
|   VERSION 2.2.0 |  | ||||||
|   OPTIONS "CXXOPTS_BUILD_EXAMPLES Off" "CXXOPTS_BUILD_TESTS Off" |  | ||||||
| ) |  | ||||||
| 
 | 
 | ||||||
| CPMAddPackage(NAME Greeter SOURCE_DIR ${CMAKE_CURRENT_LIST_DIR}/..) | CPMAddPackage(NAME Greeter SOURCE_DIR ${CMAKE_CURRENT_LIST_DIR}/..) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -20,11 +20,7 @@ include(../cmake/tools.cmake) | ||||||
| include(../cmake/CPM.cmake) | include(../cmake/CPM.cmake) | ||||||
| CPMUsePackageLock(package-lock.cmake) | CPMUsePackageLock(package-lock.cmake) | ||||||
| 
 | 
 | ||||||
| CPMAddPackage( | CPMAddPackage("gh:onqtam/doctest#2.4.5") | ||||||
|   NAME doctest |  | ||||||
|   GITHUB_REPOSITORY onqtam/doctest |  | ||||||
|   GIT_TAG 2.4.5 |  | ||||||
| ) |  | ||||||
| 
 | 
 | ||||||
| if(TEST_INSTALLED_VERSION) | if(TEST_INSTALLED_VERSION) | ||||||
|   find_package(Greeter ${PROJECT_VERSION} REQUIRED) |   find_package(Greeter ${PROJECT_VERSION} REQUIRED) | ||||||
|  | @ -45,12 +41,13 @@ CPMAddPackage( | ||||||
| file(GLOB sources CONFIGURE_DEPENDS source/*.cpp) | file(GLOB sources CONFIGURE_DEPENDS 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 ${CMAKE_CXX_STANDARD}) | 
 | ||||||
|  | set_target_properties(GreeterTests PROPERTIES CXX_STANDARD 17) | ||||||
| 
 | 
 | ||||||
| # enable compiler warnings | # enable compiler warnings | ||||||
| if(NOT TEST_INSTALLED_VERSION) | if(NOT TEST_INSTALLED_VERSION) | ||||||
|   if(CMAKE_CXX_COMPILER_ID MATCHES "(Apple)?[Cc]lang" OR CMAKE_CXX_COMPILER_ID MATCHES "GNU") |   if(CMAKE_CXX_COMPILER_ID MATCHES "Clang" OR CMAKE_CXX_COMPILER_ID MATCHES "GNU") | ||||||
|     target_compile_options(Greeter PUBLIC -Wall -Wextra -Werror) |     target_compile_options(Greeter PUBLIC -Wall -Wpedantic -Wextra -Werror) | ||||||
|   elseif(MSVC) |   elseif(MSVC) | ||||||
|     target_compile_options(Greeter PUBLIC /W4 /WX) |     target_compile_options(Greeter PUBLIC /W4 /WX) | ||||||
|     target_compile_definitions(GreeterTests PUBLIC DOCTEST_CONFIG_USE_STD_HEADERS) |     target_compile_definitions(GreeterTests PUBLIC DOCTEST_CONFIG_USE_STD_HEADERS) | ||||||
|  | @ -61,7 +58,11 @@ endif() | ||||||
| 
 | 
 | ||||||
| enable_testing() | enable_testing() | ||||||
| 
 | 
 | ||||||
| add_test(NAME greeterTests COMMAND GreeterTests -s false) | # Note: doctest and similar testing frameworks can automatically configure CMake tests. For other | ||||||
|  | # testing frameworks add the tests target instead: add_test(NAME greeterTests COMMAND GreeterTests) | ||||||
|  | 
 | ||||||
|  | include(${doctest_SOURCE_DIR}/scripts/cmake/doctest.cmake) | ||||||
|  | doctest_discover_tests(GreeterTests) | ||||||
| 
 | 
 | ||||||
| # ---- code coverage ---- | # ---- code coverage ---- | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -14,11 +14,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) == std::string_view("1.0")); | ||||||
|   static_assert(std::string_view(GREETER_VERSION).starts_with("1"));  // TBD C++20 only
 |   CHECK(std::string(GREETER_VERSION) == std::string("1.0")); | ||||||
|   CHECK(std::string(GREETER_VERSION).starts_with("1"));               // SameMajorVersion
 |  | ||||||
| #else |  | ||||||
|   static_assert(std::string_view(GREETER_VERSION) == std::string_view("1.0.1")); |  | ||||||
|   CHECK(std::string(GREETER_VERSION) == std::string("1.0.1")); |  | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue