From 0577b4d9deccd6444da59abf5060e54a4a07344d Mon Sep 17 00:00:00 2001 From: Kittywhiskers Van Gogh <63189531+kwvg@users.noreply.github.com> Date: Fri, 1 Nov 2024 16:02:27 +0000 Subject: [PATCH] refactor: make namespace `ranges` mostly an alias of `std::ranges` --- src/util/ranges.h | 38 +++++++++----------------------------- 1 file changed, 9 insertions(+), 29 deletions(-) diff --git a/src/util/ranges.h b/src/util/ranges.h index dca6866eea31d..aec61de960a10 100644 --- a/src/util/ranges.h +++ b/src/util/ranges.h @@ -5,40 +5,20 @@ #ifndef BITCOIN_UTIL_RANGES_H #define BITCOIN_UTIL_RANGES_H -#include +#include #include -//#if __cplusplus > 201703L // C++20 compiler -//namespace ranges = std::ranges; -//#else - -#define MK_RANGE(FUN) \ -template \ -inline auto FUN(const X& ds, const Z& fn) { \ - return std::FUN(cbegin(ds), cend(ds), fn); \ -} \ -template \ -inline auto FUN(X& ds, const Z& fn) { \ - return std::FUN(begin(ds), end(ds), fn); \ -} - - namespace ranges { - MK_RANGE(all_of) - MK_RANGE(any_of) - MK_RANGE(count_if) - MK_RANGE(find_if) +using namespace std::ranges; - template - constexpr inline auto find_if_opt(const X& ds, const Z& fn) { - const auto it = ranges::find_if(ds, fn); - if (it != end(ds)) { - return std::make_optional(*it); - } - return std::optional>{}; +template +constexpr inline auto find_if_opt(const X& ds, const Z& fn) { + const auto it = std::ranges::find_if(ds, fn); + if (it != std::end(ds)) { + return std::make_optional(*it); } - + return std::optional>{}; +} } -//#endif // C++20 compiler #endif // BITCOIN_UTIL_RANGES_H