From 3544d9c12fcb66ff8d4dd947137a769eb99f26c2 Mon Sep 17 00:00:00 2001 From: Johannes Stoelp Date: Tue, 19 Mar 2024 21:51:30 +0100 Subject: ring: add pre cpp17 take() fn --- ring.h | 11 +++++++++-- test/ring.cc | 4 ++-- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/ring.h b/ring.h index 3658ec4..43c3fca 100644 --- a/ring.h +++ b/ring.h @@ -99,12 +99,19 @@ class ring { #if __cplusplus >= 201703L constexpr std::optional take() { if (!is_empty()) { - const std::optional kRet = std::move(vals[m_rc & kMASK]); + std::optional ret = std::move(vals[m_rc & kMASK]); pop(); - return kRet; + return ret; } return std::nullopt; } +#else + constexpr T take() { + assert(!is_empty()); + T ret = std::move(vals[m_rc & kMASK]); + pop(); + return ret; + } #endif // -- INTERNAL --------------------------------------------------------------- diff --git a/test/ring.cc b/test/ring.cc index a42efaa..657fdfa 100644 --- a/test/ring.cc +++ b/test/ring.cc @@ -56,14 +56,14 @@ int main() { assert(!r.is_empty()); assert(r.is_full()); -#if __cplusplus >= 201703L auto v = r.take(); +#if __cplusplus >= 201703L assert(v.has_value()); +#endif assert(r.size() == 7); assert(!r.is_empty()); assert(!r.is_full()); -#endif assert(m::cnt == 8); } -- cgit v1.2.3