From 71d4e776bfe5c30bb017235b49d69a371dc37aca Mon Sep 17 00:00:00 2001 From: tmadlener Date: Fri, 19 Apr 2024 09:45:12 +0200 Subject: [PATCH] Make sure things fail at compile time for wrong inputs --- test/utils/test_covmatrix_utils.cpp | 3 +++ utils/include/edm4hep/utils/cov_matrix_utils.h | 17 ++++++++++------- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/test/utils/test_covmatrix_utils.cpp b/test/utils/test_covmatrix_utils.cpp index 4c32bf259..fb6c29e02 100644 --- a/test/utils/test_covmatrix_utils.cpp +++ b/test/utils/test_covmatrix_utils.cpp @@ -14,7 +14,10 @@ TEST_CASE("CovarianceMatrix indexing", "[cov_matrix_utils]") { STATIC_REQUIRE(get_cov_dim(21) == 6); STATIC_REQUIRE(get_cov_dim(1) == 1); +#if !__cpp_consteval + // This will fail to compile if we have consteval REQUIRE_THROWS_AS(get_cov_dim(14), std::invalid_argument); +#endif // clang-format off // For better interpretability of the tests below, these are the indices of a diff --git a/utils/include/edm4hep/utils/cov_matrix_utils.h b/utils/include/edm4hep/utils/cov_matrix_utils.h index d1f5898a6..45c70dd16 100644 --- a/utils/include/edm4hep/utils/cov_matrix_utils.h +++ b/utils/include/edm4hep/utils/cov_matrix_utils.h @@ -1,10 +1,7 @@ #ifndef EDM4HEP_UTILS_COVMATRIXUTILS_H #define EDM4HEP_UTILS_COVMATRIXUTILS_H -#include #include -#include -#include #include #include @@ -44,13 +41,19 @@ namespace utils { * * **NOTE: to avoid having to do a square root operation and in order to keep * this constexpr this is currently only implemented for storage sizes up to - * 21 (corresponding to covariance matrix dimensions of 6 x 6)** + * 21 (corresponding to covariance matrix dimensions of 6 x 6)**. This + * function is intended to be called in constexpr or immediate contexts in + * order to fail at compilation already for invalid values of N. * * @param N the size of the 1D storage * * @returns the dimension of the covariance matrix */ - inline constexpr std::size_t get_cov_dim(std::size_t N) { +#if cpp_consteval + consteval std::size_t get_cov_dim(std::size_t N) { +#else + constexpr std::size_t get_cov_dim(std::size_t N) { +#endif switch (N) { case 21: return 6; @@ -91,7 +94,7 @@ namespace utils { const auto i = detail::to_index(dimI); const auto j = detail::to_index(dimJ); - const auto dim = get_cov_dim(N); + constexpr auto dim = get_cov_dim(N); if (i < 0 || j < 0 || i >= dim || j >= dim) { // TODO: error handling } @@ -104,7 +107,7 @@ namespace utils { auto i = detail::to_index(dimI); auto j = detail::to_index(dimJ); - const auto dim = get_cov_dim(N); + constexpr auto dim = get_cov_dim(N); if (i < 0 || j < 0 || i >= dim || j >= dim) { // TODO: error handling }