From 83c9a98942a4961512fd475ea1336e2f562e4e85 Mon Sep 17 00:00:00 2001 From: Steve Downey Date: Sun, 10 Nov 2024 14:57:48 -0500 Subject: [PATCH 01/13] Add verify to build presets Add the verify headers target to the build presets for each compiler. --- CMakePresets.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakePresets.json b/CMakePresets.json index 42d3d6c..11abeb1 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -158,7 +158,7 @@ { "name": "clang-16", "inherits": "common", - "configurePreset": "clang-16" + "configurePreset": "clang-16", "targets": [ "all_verify_interface_header_sets", "all" From c429662d2ec9acb537f78c2fd7236cbed61bab3b Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Wed, 20 Nov 2024 08:15:06 +0100 Subject: [PATCH 02/13] Export cmake config package --- CMakeLists.txt | 39 ++++++++++++++--------- examples/CMakeLists.txt | 30 ++++++++++------- include/beman/optional26/CMakeLists.txt | 4 +-- src/beman/optional26/tests/CMakeLists.txt | 7 ++-- 4 files changed, 50 insertions(+), 30 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 5b4897d..88af46a 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -2,15 +2,18 @@ # # SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception -cmake_minimum_required(VERSION 3.27) +cmake_minimum_required(VERSION 3.27...3.31) project(beman_optional26 VERSION 0.0.0 LANGUAGES CXX) # Includes -include(CTest) -include(FetchContent) +include(CPack) +include(GNUInstallDirs) +include(CMakePackageConfigHelpers) -set(TARGETS_EXPORT_NAME ${CMAKE_PROJECT_NAME}Targets) +set(TARGET_PACKAGE_NAME ${PROJECT_NAME}) +set(TARGETS_EXPORT_NAME ${TARGET_PACKAGE_NAME}-targets) +set(INSTALL_CONFIGDIR ${CMAKE_INSTALL_LIBDIR}/cmake/${TARGET_PACKAGE_NAME}) option( OPTIONAL26_ENABLE_TESTING @@ -20,6 +23,8 @@ option( # Build the tests if enabled via the option OPTIONAL26_ENABLE_TESTING if(OPTIONAL26_ENABLE_TESTING) + include(FetchContent) + # Fetch GoogleTest FetchContent_Declare( googletest @@ -29,12 +34,15 @@ if(OPTIONAL26_ENABLE_TESTING) e39786088138f2749d64e9e90e0f9902daa77c40 # release-1.15.0 ) FetchContent_MakeAvailable(googletest) + + enable_testing() endif() set(CMAKE_VERIFY_INTERFACE_HEADER_SETS ON) # Create the library target and named header set for beman_optional26 add_library(beman_optional26 INTERFACE) +add_library(Beman::Optional26::beman_optional26 ALIAS beman_optional26) target_sources( beman_optional26 PUBLIC FILE_SET beman_optional26_headers TYPE HEADERS BASE_DIRS include @@ -59,23 +67,24 @@ add_subdirectory(include/beman/optional26) add_subdirectory(examples) -include(CMakePackageConfigHelpers) +# install +write_basic_package_version_file( + ${CMAKE_CURRENT_BINARY_DIR}/${TARGET_PACKAGE_NAME}-config-version.cmake + VERSION ${PROJECT_VERSION} + COMPATIBILITY AnyNewerVersion +) -# This will be used to replace @PACKAGE_cmakeModulesDir@ -set(cmakeModulesDir cmake/beman) configure_package_config_file( cmake/Config.cmake.in - BemanOptional26Config.cmake - INSTALL_DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/beman/optional26/ - PATH_VARS cmakeModulesDir - NO_SET_AND_CHECK_MACRO - NO_CHECK_REQUIRED_COMPONENTS_MACRO + ${CMAKE_CURRENT_BINARY_DIR}/${TARGET_PACKAGE_NAME}-config.cmake + INSTALL_DESTINATION ${INSTALL_CONFIGDIR} ) install( - FILES ${CMAKE_CURRENT_BINARY_DIR}/BemanOptional26Config.cmake - DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/beman/optional26/ - COMPONENT beman_optional26_development + FILES + ${CMAKE_CURRENT_BINARY_DIR}/${TARGET_PACKAGE_NAME}-config.cmake + ${CMAKE_CURRENT_BINARY_DIR}/${TARGET_PACKAGE_NAME}-config-version.cmake + DESTINATION ${INSTALL_CONFIGDIR} ) # Coverage diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt index b94bbab..8a2af8d 100644 --- a/examples/CMakeLists.txt +++ b/examples/CMakeLists.txt @@ -3,9 +3,15 @@ # SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception # cmake-format: on -set(BEMAN_OPTIONAL26_LIBRARY "beman_optional26") +cmake_minimum_required(VERSION 3.27...3.31) -include(GNUInstallDirs) +project(beman_optional26_example VERSION 0.0.0 LANGUAGES CXX) + +set(BEMAN_OPTIONAL26_LIBRARY "Beman::Optional26::beman_optional26") + +if(PROJECT_IS_TOP_LEVEL) + find_package(beman_optional26 0.0.0 EXACT REQUIRED) +endif() # List of all buildable examples. set(EXAMPLES @@ -27,13 +33,15 @@ foreach(example ${EXAMPLES}) # Link example with the library. target_link_libraries(${example} "${BEMAN_OPTIONAL26_LIBRARY}") - # Install . - install( - TARGETS - ${example} - COMPONENT - beman_optional26_examples - DESTINATION - ${CMAKE_INSTALL_BINDIR} - ) + if(NOT PROJECT_IS_TOP_LEVEL) + # Install . + install( + TARGETS + ${example} + COMPONENT + beman_optional26_examples + DESTINATION + ${CMAKE_INSTALL_BINDIR} + ) + endif() endforeach() diff --git a/include/beman/optional26/CMakeLists.txt b/include/beman/optional26/CMakeLists.txt index e43fc93..e4c2028 100644 --- a/include/beman/optional26/CMakeLists.txt +++ b/include/beman/optional26/CMakeLists.txt @@ -33,9 +33,9 @@ install( install( EXPORT beman_optional26_export - DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/beman/optional26/ + DESTINATION ${INSTALL_CONFIGDIR} NAMESPACE Beman::Optional26:: - FILE beman_optional26.cmake + FILE beman_optional26-config-targets.cmake EXPORT_LINK_INTERFACE_LIBRARIES COMPONENT beman_optional26_development ) diff --git a/src/beman/optional26/tests/CMakeLists.txt b/src/beman/optional26/tests/CMakeLists.txt index 5a2c1ad..f7e2142 100644 --- a/src/beman/optional26/tests/CMakeLists.txt +++ b/src/beman/optional26/tests/CMakeLists.txt @@ -29,7 +29,7 @@ target_sources( target_link_libraries( beman_optional26_test - PRIVATE beman_optional26 GTest::gtest GTest::gtest_main + PRIVATE Beman::Optional26::beman_optional26 GTest::gtest GTest::gtest_main ) # Issue #32: Re-enable ASAN run CI/clang-19. @@ -41,7 +41,10 @@ gtest_add_tests(TARGET beman_optional26_test "" AUTO) add_library(constructor_fails test_constructor_fail.cpp) -target_link_libraries(constructor_fails PRIVATE beman_optional26) +target_link_libraries( + constructor_fails + PRIVATE Beman::Optional26::beman_optional26 +) set_target_properties( constructor_fails From 73fde6b26ee3f109e0134efb160487fafb831a19 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Wed, 20 Nov 2024 08:28:51 +0100 Subject: [PATCH 03/13] Add find-package-test --- src/beman/optional26/tests/CMakeLists.txt | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/src/beman/optional26/tests/CMakeLists.txt b/src/beman/optional26/tests/CMakeLists.txt index f7e2142..2996dda 100644 --- a/src/beman/optional26/tests/CMakeLists.txt +++ b/src/beman/optional26/tests/CMakeLists.txt @@ -62,3 +62,21 @@ set_tests_properties(constructor_fails PROPERTIES WILL_FAIL true) # Alternatively -- check for a particular regex to pass # set_tests_properties(constructor_fails PROPERTIES PASS_REGULAR_EXPRESSION # "Assert true") + +# test if the targets are findable from the build directory +if(CMAKE_BUILD_TYPE STREQUAL Debug) + add_test( + NAME find-package-test + COMMAND + ${CMAKE_CTEST_COMMAND} + # --verbose + --output-on-failure -C $ --build-and-test + "${PROJECT_SOURCE_DIR}" + "${CMAKE_CURRENT_BINARY_DIR}/find-package-test" --build-generator + ${CMAKE_GENERATOR} --build-makeprogram ${CMAKE_MAKE_PROGRAM} + --build-options "-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}" + "-DCMAKE_CXX_STANDARD=${CMAKE_CXX_STANDARD}" + "-DCMAKE_BUILD_TYPE=$" + "-DCMAKE_PREFIX_PATH=${CMAKE_PREFIX_PATH}" + ) +endif() From e530c3f1c787ecadbbc5d9577997e9eeb6fdd0f8 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Fri, 6 Dec 2024 22:10:04 +0100 Subject: [PATCH 04/13] Restructure cmake preset --- CMakePresets.json | 62 +++++++++++++++++------------------------------ 1 file changed, 22 insertions(+), 40 deletions(-) diff --git a/CMakePresets.json b/CMakePresets.json index 11abeb1..b34ac00 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -2,7 +2,7 @@ "version": 6, "cmakeMinimumRequired": { "major": 3, - "minor": 29, + "minor": 27, "patch": 2 }, "configurePresets": [ @@ -14,7 +14,16 @@ "binaryDir": "${sourceDir}/.build/${presetName}", "installDir": "${sourceDir}/.install/${presetName}", "cacheVariables": { - "CMAKE_CONFIGURATION_TYPES": "RelWithDebInfo;Debug;Tsan;Asan" + "CMAKE_PREFIX_PATH": { + "type": "path", + "value": "${sourceDir}/.install/${presetName}" + }, + "CMAKE_CONFIGURATION_TYPES": "RelWithDebInfo;Debug;Tsan;Asan", + "CMAKE_CXX_EXTENSIONS": false, + "CMAKE_CXX_STANDARD": "20", + "CMAKE_CXX_STANDARD_REQUIRED": true, + "CMAKE_EXPORT_COMPILE_COMMANDS": true, + "CMAKE_SKIP_TEST_ALL_DEPENDENCY": false } }, { @@ -85,38 +94,27 @@ { "name": "common", "hidden": true, - "configuration": "Asan", + "configuration": "Debug", "targets": [ "all_verify_interface_header_sets", - "all" + "all", + "install" ] }, { "name": "system", "inherits": "common", - "configurePreset": "system", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "system" }, { "name": "gcc-14", "inherits": "common", - "configurePreset": "gcc-14", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "gcc-14" }, { "name": "gcc-13", "inherits": "common", - "configurePreset": "gcc-13", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "gcc-13" }, { "name": "gcc-12", @@ -131,45 +129,29 @@ { "name": "clang-19", "inherits": "common", - "configurePreset": "clang-19", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "clang-19" }, { "name": "clang-18", "inherits": "common", - "configurePreset": "clang-18", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "clang-18" }, { "name": "clang-17", "inherits": "common", - "configurePreset": "clang-17", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "clang-17" }, { "name": "clang-16", "inherits": "common", - "configurePreset": "clang-16", - "targets": [ - "all_verify_interface_header_sets", - "all" - ] + "configurePreset": "clang-16" } ], "testPresets": [ { "name": "common", "hidden": true, - "configuration": "Asan", + "configuration": "Debug", "output": { "outputOnFailure": true }, From aa946398b7b8f058b85763b8ceaa8a1dca689612 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Fri, 6 Dec 2024 22:20:02 +0100 Subject: [PATCH 05/13] Trigger find-packge-test --- CMakePresets.json | 1 + 1 file changed, 1 insertion(+) diff --git a/CMakePresets.json b/CMakePresets.json index b34ac00..e2acd60 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -18,6 +18,7 @@ "type": "path", "value": "${sourceDir}/.install/${presetName}" }, + "CMAKE_BUILD_TYPE": "Debug", "CMAKE_CONFIGURATION_TYPES": "RelWithDebInfo;Debug;Tsan;Asan", "CMAKE_CXX_EXTENSIONS": false, "CMAKE_CXX_STANDARD": "20", From 72f43703d20933aa9f7ea6624056fb63876b64fd Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Fri, 6 Dec 2024 22:41:14 +0100 Subject: [PATCH 06/13] Test to find installed package on CI too --- .github/workflows/ci.yml | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index bafdbe8..8f43b22 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -83,7 +83,7 @@ jobs: echo ${{ matrix.config.cmake_args }} echo ${{ matrix.config.toolchain }} rm -rf .build - cmake ${{ matrix.config.cmake_args }} -DCMAKE_INSTALL_PREFIX=.install -DCMAKE_TOOLCHAIN_FILE="etc/${{ matrix.config.toolchain }}-toolchain.cmake" -B .build -S . + cmake ${{ matrix.config.cmake_args }} -DCMAKE_INSTALL_PREFIX=.install -DCMAKE_PREFIX_PATH=.install -DCMAKE_TOOLCHAIN_FILE="etc/${{ matrix.config.toolchain }}-toolchain.cmake" -B .build -S . - name: CMake ASAN Build run: | set -x @@ -106,4 +106,8 @@ jobs: - name: Install run: | set -x - cmake --install .build --config RelWithDebInfo --component beman_optional26_development --verbose + cmake --install .build --config RelWithDebInfo --verbose + - name: CMake Debug Test + run: | + set -x + cmake --build .build --config Debug --target test -- -k 0 From b29852da831875658bb5b0d72a45c8cd5b39d8e1 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Fri, 6 Dec 2024 22:48:09 +0100 Subject: [PATCH 07/13] Add missing Debug build type for CI --- .github/workflows/ci.yml | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 8f43b22..98907f0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -13,14 +13,14 @@ jobs: fail-fast: false matrix: config: - - {name: "Ubuntu Clang 20", os: ubuntu-24.04, toolchain: "clang-20", clang_version: 20, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} + - {name: "Ubuntu Clang 20", os: ubuntu-24.04, toolchain: "clang-20", clang_version: 20, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" "} # Note: clang-19 + Asan setup causes errors on some platforms. Temporary skip some checks via .asan_options. - - {name: "Ubuntu Clang 19", os: ubuntu-24.04, toolchain: "clang-19", clang_version: 19, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" ", asan_options: "new_delete_type_mismatch=0"} - - {name: "Ubuntu Clang 18", os: ubuntu-24.04, toolchain: "clang-18", clang_version: 18, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - - {name: "Ubuntu Clang 17", os: ubuntu-24.04, toolchain: "clang-17", clang_version: 17, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - - {name: "Ubuntu GCC 14", os: ubuntu-24.04, toolchain: "gcc-14", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - - {name: "Ubuntu GCC 13", os: ubuntu-24.04, toolchain: "gcc-13", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - - {name: "Ubuntu GCC 12", os: ubuntu-24.04, toolchain: "gcc-12", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} + - {name: "Ubuntu Clang 19", os: ubuntu-24.04, toolchain: "clang-19", clang_version: 19, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" ", asan_options: "new_delete_type_mismatch=0"} + - {name: "Ubuntu Clang 18", os: ubuntu-24.04, toolchain: "clang-18", clang_version: 18, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" "} + - {name: "Ubuntu Clang 17", os: ubuntu-24.04, toolchain: "clang-17", clang_version: 17, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" "} + - {name: "Ubuntu GCC 14", os: ubuntu-24.04, toolchain: "gcc-14", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" "} + - {name: "Ubuntu GCC 13", os: ubuntu-24.04, toolchain: "gcc-13", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" "} + - {name: "Ubuntu GCC 12", os: ubuntu-24.04, toolchain: "gcc-12", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Debug;Asan\" "} steps: - uses: actions/checkout@v3 with: From b70856b860098f36464c54c76d5c1775d3ecec40 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Fri, 6 Dec 2024 22:54:48 +0100 Subject: [PATCH 08/13] Setup that test depends on all --- CMakeLists.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index 88af46a..f789940 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -2,6 +2,8 @@ # # SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +set(CMAKE_SKIP_TEST_ALL_DEPENDENCY FALSE) + cmake_minimum_required(VERSION 3.27...3.31) project(beman_optional26 VERSION 0.0.0 LANGUAGES CXX) From 405286db3d50ecf44ed9b8b3bf225a0c3d72eb72 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Sat, 7 Dec 2024 05:09:44 +0100 Subject: [PATCH 09/13] Use cmake workflow preset on CI Update README Bump minimum cmake version --- .github/workflows/ci.yml | 4 ++-- CMakeLists.txt | 5 +++-- CMakePresets.json | 2 +- README.md | 6 +++++- examples/CMakeLists.txt | 6 +++--- 5 files changed, 14 insertions(+), 9 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 98907f0..bb38e87 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -107,7 +107,7 @@ jobs: run: | set -x cmake --install .build --config RelWithDebInfo --verbose - - name: CMake Debug Test + - name: CMake Debug Workflow run: | set -x - cmake --build .build --config Debug --target test -- -k 0 + cmake --workflow --preset clang-19 diff --git a/CMakeLists.txt b/CMakeLists.txt index f789940..e0e1214 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -4,9 +4,9 @@ set(CMAKE_SKIP_TEST_ALL_DEPENDENCY FALSE) -cmake_minimum_required(VERSION 3.27...3.31) +cmake_minimum_required(VERSION 3.29...3.31) -project(beman_optional26 VERSION 0.0.0 LANGUAGES CXX) +project(beman_optional26 VERSION 0.0.1 LANGUAGES CXX) # Includes include(CPack) @@ -98,4 +98,5 @@ add_custom_target( COMMENT "Running gcovr to process coverage results" COMMAND mkdir -p coverage COMMAND gcovr --config gcovr.cfg . + DEPENDS test ) diff --git a/CMakePresets.json b/CMakePresets.json index e2acd60..7e176ad 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -2,7 +2,7 @@ "version": 6, "cmakeMinimumRequired": { "major": 3, - "minor": 27, + "minor": 29, "patch": 2 }, "configurePresets": [ diff --git a/README.md b/README.md index 0919c27..0ac6776 100644 --- a/README.md +++ b/README.md @@ -141,7 +141,7 @@ apt-get install -y cmake make ninja-build # Example of toolchains: apt-get install \ - g++-14 gcc-14 gcc-13 g++-14 \ + g++-14 gcc-14 gcc-13 g++-13 \ clang-18 clang++-18 clang-17 clang++-17 ``` @@ -162,8 +162,12 @@ Available workflow presets: "system" "gcc-14" "gcc-13" + "gcc-12" + "clang-20" + "clang-19" "clang-18" "clang-17" + "clang-16" # Run examples: $ cmake --workflow --preset gcc-14 diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt index 8a2af8d..a2d10a4 100644 --- a/examples/CMakeLists.txt +++ b/examples/CMakeLists.txt @@ -3,14 +3,14 @@ # SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception # cmake-format: on -cmake_minimum_required(VERSION 3.27...3.31) +cmake_minimum_required(VERSION 3.29...3.31) -project(beman_optional26_example VERSION 0.0.0 LANGUAGES CXX) +project(beman_optional26_example VERSION 0.0.1 LANGUAGES CXX) set(BEMAN_OPTIONAL26_LIBRARY "Beman::Optional26::beman_optional26") if(PROJECT_IS_TOP_LEVEL) - find_package(beman_optional26 0.0.0 EXACT REQUIRED) + find_package(beman_optional26 0.0.1 EXACT REQUIRED) endif() # List of all buildable examples. From 37b29912010860e1e0bb2114f07f1a4fd2815a48 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Sat, 7 Dec 2024 05:42:39 +0100 Subject: [PATCH 10/13] Use right toolchain for preset name --- .github/workflows/ci.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index bb38e87..49ce4da 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -64,6 +64,7 @@ jobs: [[ ${CLANG_VERSION} = 17 ]] && sudo apt-get install libc++-dev libc++1 libc++abi-dev libc++abi1 find /usr/lib/x86_64-linux-gnu/ -name libc++.so* || true clang++-${CLANG_VERSION} --version + type clang++-${CLANG_VERSION} - name: Install GCC if: startsWith(matrix.config.name, 'Ubuntu GCC') run: | @@ -77,6 +78,7 @@ jobs: sudo apt-get install g++-${GCC_VERSION} gcc-${GCC_VERSION} find /usr/lib/x86_64-linux-gnu/ -name libstdc++.so* g++-${GCC_VERSION} --version + type g++-${GCC_VERSION} - name: CMake Configure run: | set -x @@ -110,4 +112,4 @@ jobs: - name: CMake Debug Workflow run: | set -x - cmake --workflow --preset clang-19 + cmake --workflow --preset ${{ matrix.config.toolchain }} From c0f2538717c36ec84958d0875606b5a45d9200b6 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Sat, 7 Dec 2024 06:28:24 +0100 Subject: [PATCH 11/13] It seems clang-17 builds only with -std=c++20 ? --- etc/clang-flags.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/etc/clang-flags.cmake b/etc/clang-flags.cmake index 5b23bf7..2f651cf 100644 --- a/etc/clang-flags.cmake +++ b/etc/clang-flags.cmake @@ -1,6 +1,6 @@ include_guard(GLOBAL) -set(CMAKE_CXX_STANDARD 23) +set(CMAKE_CXX_STANDARD 20) set(CMAKE_CXX_FLAGS "-stdlib=libc++ -Wall -Wextra " From fb64c34cdb990d00109e06c1c8c81d0986c7fdac Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Tue, 10 Dec 2024 22:21:09 +0100 Subject: [PATCH 12/13] Fix merge problems --- .github/workflows/ci.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 4bf0fd1..58e104e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -19,8 +19,8 @@ jobs: - {name: "Ubuntu Clang 18", os: ubuntu-24.04, toolchain: "clang-18", clang_version: 18, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - {name: "Ubuntu Clang 17", os: ubuntu-24.04, toolchain: "clang-17", clang_version: 17, installed_clang_version: 17, cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - {name: "Ubuntu GCC 14", os: ubuntu-24.04, toolchain: "gcc-14", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan;Gcov\" ", coverage: true} - - {name: "Ubuntu GCC 13", os: ubuntu-24.04, toolchain: "gcc-13", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} - - {name: "Ubuntu GCC 12", os: ubuntu-24.04, toolchain: "gcc-12", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} + - {name: "Ubuntu GCC 13", os: ubuntu-24.04, toolchain: "gcc-13", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} + - {name: "Ubuntu GCC 12", os: ubuntu-24.04, toolchain: "gcc-12", cmake_args: "-G \"Ninja Multi-Config\" -DCMAKE_CONFIGURATION_TYPES=\"RelWithDebInfo;Asan\" "} steps: - uses: actions/checkout@v3 with: @@ -78,6 +78,7 @@ jobs: sudo apt-get install g++-${GCC_VERSION} gcc-${GCC_VERSION} find /usr/lib/x86_64-linux-gnu/ -name libstdc++.so* g++-${GCC_VERSION} --version + type g++-${GCC_VERSION} - name: Install Gcovr if: matrix.config.coverage run: | @@ -135,8 +136,7 @@ jobs: with: file: ${{runner.workspace}}/optional26/.build/coverage.json github-token: ${{ secrets.GITHUB_TOKEN }} - cmake --install .build --config RelWithDebInfo --verbose - name: CMake Debug Workflow run: | set -x - cmake --workflow --preset ${{ matrix.config.toolchain }} \ No newline at end of file + cmake --workflow --preset ${{ matrix.config.toolchain }} From 0505f9cf254a6e4e22ada6265a0887550cb11810 Mon Sep 17 00:00:00 2001 From: ClausKlein Date: Thu, 12 Dec 2024 07:41:27 +0100 Subject: [PATCH 13/13] Validate and format json files too --- .clang-format | 3 +++ .pre-commit-config.yaml | 4 +++- CMakePresets.json | 2 +- 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/.clang-format b/.clang-format index 01d5fac..43e7cbc 100644 --- a/.clang-format +++ b/.clang-format @@ -1,4 +1,7 @@ --- +Language: Json +IndentWidth: 2 +--- Language: Cpp AccessModifierOffset: -2 AlignAfterOpenBracket: Align diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 72a4a83..1329d45 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -6,7 +6,9 @@ repos: hooks: - id: trailing-whitespace - id: end-of-file-fixer + - id: check-json - id: check-yaml + exclude: ^\.clang-format$ - id: check-added-large-files # Clang-format for C++ @@ -16,7 +18,7 @@ repos: rev: v18.1.8 hooks: - id: clang-format - types_or: [c++, c] + types_or: [c++, c, json] # CMake linting and formatting - repo: https://github.com/BlankSpruce/gersemi diff --git a/CMakePresets.json b/CMakePresets.json index 0a2b376..7e176ad 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -145,7 +145,7 @@ { "name": "clang-16", "inherits": "common", - "configurePreset": "clang-16", + "configurePreset": "clang-16" } ], "testPresets": [