aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3/testsuite
diff options
context:
space:
mode:
authorPatrick Palka <ppalka@redhat.com>2022-09-01 09:54:57 -0400
committerPatrick Palka <ppalka@redhat.com>2022-09-01 09:54:57 -0400
commit0cb8d96157a95b7619ef1ccf28051181415fe989 (patch)
treeee9f441e60d67d9da0764beea30fee5f28d29907 /libstdc++-v3/testsuite
parent47e15513c9e581ef04ad25fb0d561a45d345edd1 (diff)
downloadgcc-0cb8d96157a95b7619ef1ccf28051181415fe989.zip
gcc-0cb8d96157a95b7619ef1ccf28051181415fe989.tar.gz
gcc-0cb8d96157a95b7619ef1ccf28051181415fe989.tar.bz2
libstdc++: Implement ranges::adjacent_transform_view from P2321R2
libstdc++-v3/ChangeLog: * include/std/ranges (__detail::__unarize): Define. (adjacent_view::_Iterator): Befriend adjacent_transform_view. (adjacent_transform_view): Define. (adjacent_transform_view::_Iterator): Define. (adjacent_transform_view::_Sentinel): Define. (views::__detail::__can_adjacent_transform_view): Define. (views::_AdjacentTransform): Define. (views::adjacent_transform): Define. (views::pairwise_transform): Define. * testsuite/std/ranges/adaptors/adjacent_transform/1.cc: New test.
Diffstat (limited to 'libstdc++-v3/testsuite')
-rw-r--r--libstdc++-v3/testsuite/std/ranges/adaptors/adjacent_transform/1.cc106
1 files changed, 106 insertions, 0 deletions
diff --git a/libstdc++-v3/testsuite/std/ranges/adaptors/adjacent_transform/1.cc b/libstdc++-v3/testsuite/std/ranges/adaptors/adjacent_transform/1.cc
new file mode 100644
index 0000000..07f20b7
--- /dev/null
+++ b/libstdc++-v3/testsuite/std/ranges/adaptors/adjacent_transform/1.cc
@@ -0,0 +1,106 @@
+// { dg-options "-std=gnu++23" }
+// { dg-do run { target c++23 } }
+
+#include <ranges>
+#include <algorithm>
+#include <utility>
+#include <testsuite_hooks.h>
+#include <testsuite_iterators.h>
+
+namespace ranges = std::ranges;
+namespace views = std::views;
+
+constexpr bool
+test01()
+{
+ auto v1 = std::array{1, 2, 3} | views::adjacent_transform<1>(std::identity{});
+ VERIFY( ranges::equal(v1, (int[]){1, 2, 3}) );
+ const auto i0 = v1.begin(), i1 = v1.begin() + 1;
+ VERIFY( i0 + 1 - 1 == i0 );
+ VERIFY( i0 < i1 );
+ VERIFY( i1 < v1.end() );
+ VERIFY( i1 - i0 == 1 );
+ VERIFY( i0 - i1 == -1 );
+ VERIFY( v1.end() - i1 == 2 );
+ VERIFY( i1 - v1.end() == -2 );
+ ranges::iter_swap(i0, i1);
+ VERIFY( ranges::equal(std::move(v1), (int[]){2, 1, 3}) );
+
+ auto v2 = std::array{1, -1, 2, -2} | views::pairwise_transform(std::multiplies{});
+ auto i2 = v2.begin();
+ i2 += 1;
+ i2 -= -2;
+ VERIFY( i2 == v2.end() );
+ VERIFY( ranges::size(v2) == 3 );
+ VERIFY( ranges::size(std::as_const(v2)) == 3 );
+ VERIFY( ranges::equal(v2, (int[]){-1, -2, -4}) );
+
+ int y[] = {1, 2, 3, 4, 5, 6};
+ auto v3 = y | views::adjacent_transform<3>([](auto... xs) { return ranges::max({xs...}); });
+ VERIFY( ranges::size(v3) == 4 );
+ VERIFY( ranges::equal(v3, (int[]){3, 4, 5, 6}) );
+
+ const auto v6 = y | views::adjacent_transform<6>([](auto...) { return 0; });
+ VERIFY( ranges::equal(v6, (int[]){0}) );
+
+ const auto v7 = y | views::adjacent_transform<7>([](auto...) { return 0; });
+ VERIFY( ranges::empty(v7) );
+
+ const auto v0 = y | views::adjacent_transform<0>([] { return 0; });
+ VERIFY( ranges::empty(v0) );
+
+ return true;
+}
+
+constexpr bool
+test02()
+{
+ using __gnu_test::test_input_range;
+ using __gnu_test::test_forward_range;
+ using __gnu_test::test_random_access_range;
+
+ using ty1 = ranges::adjacent_transform_view<views::all_t<test_forward_range<int>>,
+ std::plus<>, 2>;
+ static_assert(ranges::forward_range<ty1>);
+ static_assert(!ranges::bidirectional_range<ty1>);
+ static_assert(!ranges::sized_range<ty1>);
+
+ using ty2 = ranges::adjacent_transform_view<views::all_t<test_random_access_range<int>>,
+ decltype([](int, int, int) { return 0;}), 3>;
+ static_assert(ranges::random_access_range<ty2>);
+ static_assert(ranges::sized_range<ty2>);
+
+ return true;
+}
+
+constexpr bool
+test03()
+{
+ auto v = views::iota(0, 4)
+ | views::filter([](auto) { return true; })
+ | views::pairwise_transform(std::plus{});
+ using ty = decltype(v);
+ static_assert(ranges::forward_range<ty>);
+ static_assert(ranges::common_range<ty>);
+ static_assert(!ranges::sized_range<ty>);
+ VERIFY( v.begin() == v.begin() );
+ VERIFY( v.begin() != v.end() );
+ VERIFY( ranges::next(v.begin(), 3) == v.end() );
+ auto it = v.begin();
+ ++it;
+ it++;
+ VERIFY( ranges::next(it) == v.end() );
+ it--;
+ --it;
+ VERIFY( it == v.begin() );
+
+ return true;
+}
+
+int
+main()
+{
+ static_assert(test01());
+ static_assert(test02());
+ static_assert(test03());
+}