comparison libstdc++-v3/testsuite/std/ranges/subrange/lwg3433.cc @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
comparison
equal deleted inserted replaced
145:1830386684a0 152:2b5abeee2509
1 // Copyright (C) 2020 Free Software Foundation, Inc.
2 //
3 // This file is part of the GNU ISO C++ Library. This library is free
4 // software; you can redistribute it and/or modify it under the
5 // terms of the GNU General Public License as published by the
6 // Free Software Foundation; either version 3, or (at your option)
7 // any later version.
8
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13
14 // You should have received a copy of the GNU General Public License along
15 // with this library; see the file COPYING3. If not see
16 // <http://www.gnu.org/licenses/>.
17
18 // { dg-options "-std=gnu++2a" }
19 // { dg-do run { target c++2a } }
20
21 #include <algorithm>
22 #include <ranges>
23 #include <testsuite_iterators.h>
24 #include <testsuite_hooks.h>
25
26 using __gnu_test::bidirectional_iterator_wrapper;
27 using __gnu_test::forward_iterator_wrapper;
28 using __gnu_test::test_range;
29 using __gnu_test::test_sized_range;
30 using __gnu_test::test_sized_range_sized_sent;
31
32 namespace ranges = std::ranges;
33
34 template<typename Container>
35 void
36 test01()
37 {
38 int x[] = {1,2,3,4,5};
39 Container r{x};
40 ranges::subrange sr = r;
41 constexpr bool sized_range_p = ranges::sized_range<decltype(sr)>;
42 constexpr bool bidirectional_p = ranges::bidirectional_range<decltype(sr)>;
43 VERIFY( ranges::equal(sr, (int[]){1,2,3,4,5}) );
44 if constexpr (sized_range_p)
45 VERIFY( sr.size() == 5 );
46
47 sr = sr.next();
48 VERIFY( ranges::equal(sr, (int[]){2,3,4,5}) );
49 if constexpr (sized_range_p)
50 VERIFY( sr.size() == 4 );
51
52 sr = std::move(sr).next(2);
53 VERIFY( ranges::equal(sr, (int[]){4,5}) );
54 if constexpr (sized_range_p)
55 VERIFY( sr.size() == 2 );
56
57 if constexpr (bidirectional_p)
58 {
59 sr = sr.prev(2);
60 VERIFY( ranges::equal(sr, (int[]){2,3,4,5}) );
61 if constexpr (sized_range_p)
62 VERIFY( sr.size() == 4 );
63
64 sr = sr.prev();
65 VERIFY( ranges::equal(sr, (int[]){1,2,3,4,5}) );
66 if constexpr (sized_range_p)
67 VERIFY( sr.size() == 5 );
68 }
69 else
70 sr = r;
71
72 sr.advance(1);
73 VERIFY( ranges::equal(sr, (int[]){2,3,4,5}) );
74 if constexpr (sized_range_p)
75 VERIFY( sr.size() == 4 );
76
77 if constexpr (bidirectional_p)
78 {
79 sr.advance(-1);
80 VERIFY( ranges::equal(sr, (int[]){1,2,3,4,5}) );
81 if constexpr (sized_range_p)
82 VERIFY( sr.size() == 5 );
83 }
84 }
85
86 int
87 main()
88 {
89 test01<test_sized_range_sized_sent<int, bidirectional_iterator_wrapper>>();
90 test01<test_sized_range<int, bidirectional_iterator_wrapper>>();
91 test01<test_range<int, bidirectional_iterator_wrapper>>();
92
93 test01<test_sized_range_sized_sent<int, forward_iterator_wrapper>>();
94 test01<test_sized_range<int, forward_iterator_wrapper>>();
95 test01<test_range<int, forward_iterator_wrapper>>();
96 }