diff options
Diffstat (limited to 'libcxx/test/std/containers/views/span.iterators/rend.pass.cpp')
| -rw-r--r-- | libcxx/test/std/containers/views/span.iterators/rend.pass.cpp | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/libcxx/test/std/containers/views/span.iterators/rend.pass.cpp b/libcxx/test/std/containers/views/span.iterators/rend.pass.cpp new file mode 100644 index 00000000000..abcead445e1 --- /dev/null +++ b/libcxx/test/std/containers/views/span.iterators/rend.pass.cpp @@ -0,0 +1,118 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// UNSUPPORTED: c++98, c++03, c++11, c++14, c++17 + +// <span> + +// constexpr reverse_iterator rend() const noexcept; +// constexpr const_reverse_iterator crend() const noexcept; + +#include <span> +#include <cassert> +#include <string> + +#include "test_macros.h" + +template <class Span> +constexpr bool testConstexprSpan(Span s) +{ + bool ret = true; + typename Span::reverse_iterator e = s. rend(); + typename Span::const_reverse_iterator ce = s.crend(); + if (s.empty()) + { + ret = ret && ( e == s.rbegin()); + ret = ret && (ce == s.crbegin()); + } + else + { + ret = ret && ( e != s.rbegin()); + ret = ret && (ce != s.crbegin()); + } + + ret = ret && (( e - s.rbegin()) == s.size()); + ret = ret && ((ce - s.crbegin()) == s.size()); + + ret = ret && (e == ce); + return ret; +} + +template <class Span> +void testRuntimeSpan(Span s) +{ + typename Span::reverse_iterator e = s. rend(); + typename Span::const_reverse_iterator ce = s.crend(); + if (s.empty()) + { + assert( e == s.rbegin()); + assert(ce == s.crbegin()); + } + else + { + assert( e != s.rbegin()); + assert(ce != s.crbegin()); + } + + assert(( e - s.rbegin()) == s.size()); + assert((ce - s.crbegin()) == s.size()); + + assert(e == ce); +} + + +struct A{}; +bool operator==(A, A) {return true;} + +constexpr int iArr1[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; + int iArr2[] = {10, 11, 12, 13, 14, 15, 16, 17, 18, 19}; + + +int main() +{ + static_assert(testConstexprSpan(std::span<int>()), ""); + static_assert(testConstexprSpan(std::span<long>()), ""); + static_assert(testConstexprSpan(std::span<double>()), ""); + static_assert(testConstexprSpan(std::span<A>()), ""); + static_assert(testConstexprSpan(std::span<std::string>()), ""); + + static_assert(testConstexprSpan(std::span<int, 0>()), ""); + static_assert(testConstexprSpan(std::span<long, 0>()), ""); + static_assert(testConstexprSpan(std::span<double, 0>()), ""); + static_assert(testConstexprSpan(std::span<A, 0>()), ""); + static_assert(testConstexprSpan(std::span<std::string, 0>()), ""); + + static_assert(testConstexprSpan(std::span<const int>(iArr1, 1)), ""); + static_assert(testConstexprSpan(std::span<const int>(iArr1, 2)), ""); + static_assert(testConstexprSpan(std::span<const int>(iArr1, 3)), ""); + static_assert(testConstexprSpan(std::span<const int>(iArr1, 4)), ""); + static_assert(testConstexprSpan(std::span<const int>(iArr1, 5)), ""); + + + testRuntimeSpan(std::span<int> ()); + testRuntimeSpan(std::span<long> ()); + testRuntimeSpan(std::span<double> ()); + testRuntimeSpan(std::span<A> ()); + testRuntimeSpan(std::span<std::string>()); + + testRuntimeSpan(std::span<int, 0> ()); + testRuntimeSpan(std::span<long, 0> ()); + testRuntimeSpan(std::span<double, 0> ()); + testRuntimeSpan(std::span<A, 0> ()); + testRuntimeSpan(std::span<std::string, 0>()); + + testRuntimeSpan(std::span<int>(iArr2, 1)); + testRuntimeSpan(std::span<int>(iArr2, 2)); + testRuntimeSpan(std::span<int>(iArr2, 3)); + testRuntimeSpan(std::span<int>(iArr2, 4)); + testRuntimeSpan(std::span<int>(iArr2, 5)); + + std::string s; + testRuntimeSpan(std::span<std::string>(&s, (std::ptrdiff_t) 0)); + testRuntimeSpan(std::span<std::string>(&s, 1)); +} |

