15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier
95a83710eSEric Fiselier // <set>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // class set
125a83710eSEric Fiselier
135a83710eSEric Fiselier // iterator begin();
145a83710eSEric Fiselier // const_iterator begin() const;
155a83710eSEric Fiselier // iterator end();
165a83710eSEric Fiselier // const_iterator end() const;
175a83710eSEric Fiselier //
185a83710eSEric Fiselier // reverse_iterator rbegin();
195a83710eSEric Fiselier // const_reverse_iterator rbegin() const;
205a83710eSEric Fiselier // reverse_iterator rend();
215a83710eSEric Fiselier // const_reverse_iterator rend() const;
225a83710eSEric Fiselier //
235a83710eSEric Fiselier // const_iterator cbegin() const;
245a83710eSEric Fiselier // const_iterator cend() const;
255a83710eSEric Fiselier // const_reverse_iterator crbegin() const;
265a83710eSEric Fiselier // const_reverse_iterator crend() const;
275a83710eSEric Fiselier
285a83710eSEric Fiselier #include <set>
295a83710eSEric Fiselier #include <cassert>
30a11d322fSStephan T. Lavavej #include <cstddef>
315a83710eSEric Fiselier
320f901c7eSStephan T. Lavavej #include "test_macros.h"
335a83710eSEric Fiselier #include "min_allocator.h"
345a83710eSEric Fiselier
main(int,char **)352df59c50SJF Bastien int main(int, char**)
365a83710eSEric Fiselier {
375a83710eSEric Fiselier {
385a83710eSEric Fiselier typedef int V;
395a83710eSEric Fiselier V ar[] =
405a83710eSEric Fiselier {
415a83710eSEric Fiselier 1,
425a83710eSEric Fiselier 1,
435a83710eSEric Fiselier 1,
445a83710eSEric Fiselier 2,
455a83710eSEric Fiselier 2,
465a83710eSEric Fiselier 2,
475a83710eSEric Fiselier 3,
485a83710eSEric Fiselier 3,
495a83710eSEric Fiselier 3,
505a83710eSEric Fiselier 4,
515a83710eSEric Fiselier 4,
525a83710eSEric Fiselier 4,
535a83710eSEric Fiselier 5,
545a83710eSEric Fiselier 5,
555a83710eSEric Fiselier 5,
565a83710eSEric Fiselier 6,
575a83710eSEric Fiselier 6,
585a83710eSEric Fiselier 6,
595a83710eSEric Fiselier 7,
605a83710eSEric Fiselier 7,
615a83710eSEric Fiselier 7,
625a83710eSEric Fiselier 8,
635a83710eSEric Fiselier 8,
645a83710eSEric Fiselier 8
655a83710eSEric Fiselier };
665a83710eSEric Fiselier std::set<int> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
67fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
68fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
695a83710eSEric Fiselier std::set<int>::iterator i;
705a83710eSEric Fiselier i = m.begin();
715a83710eSEric Fiselier std::set<int>::const_iterator k = i;
725a83710eSEric Fiselier assert(i == k);
73*a7b9af78SCasey Carter for (int j = 1; j <= static_cast<int>(m.size()); ++j, ++i)
745a83710eSEric Fiselier assert(*i == j);
756a929492SRuslan Arutyunyan assert(i == m.end());
76*a7b9af78SCasey Carter for (int j = static_cast<int>(m.size()); j >= 1; --j) {
776a929492SRuslan Arutyunyan --i;
786a929492SRuslan Arutyunyan assert(*i == j);
796a929492SRuslan Arutyunyan }
806a929492SRuslan Arutyunyan assert(i == m.begin());
815a83710eSEric Fiselier }
825a83710eSEric Fiselier {
835a83710eSEric Fiselier typedef int V;
845a83710eSEric Fiselier V ar[] =
855a83710eSEric Fiselier {
865a83710eSEric Fiselier 1,
875a83710eSEric Fiselier 1,
885a83710eSEric Fiselier 1,
895a83710eSEric Fiselier 2,
905a83710eSEric Fiselier 2,
915a83710eSEric Fiselier 2,
925a83710eSEric Fiselier 3,
935a83710eSEric Fiselier 3,
945a83710eSEric Fiselier 3,
955a83710eSEric Fiselier 4,
965a83710eSEric Fiselier 4,
975a83710eSEric Fiselier 4,
985a83710eSEric Fiselier 5,
995a83710eSEric Fiselier 5,
1005a83710eSEric Fiselier 5,
1015a83710eSEric Fiselier 6,
1025a83710eSEric Fiselier 6,
1035a83710eSEric Fiselier 6,
1045a83710eSEric Fiselier 7,
1055a83710eSEric Fiselier 7,
1065a83710eSEric Fiselier 7,
1075a83710eSEric Fiselier 8,
1085a83710eSEric Fiselier 8,
1095a83710eSEric Fiselier 8
1105a83710eSEric Fiselier };
1115a83710eSEric Fiselier const std::set<int> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
112fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
113fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.cbegin(), m.cend())) == m.size());
114fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
115fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.crbegin(), m.crend())) == m.size());
1165a83710eSEric Fiselier std::set<int>::const_iterator i;
1175a83710eSEric Fiselier i = m.begin();
118*a7b9af78SCasey Carter for (int j = 1; j <= static_cast<int>(m.size()); ++j, ++i)
1195a83710eSEric Fiselier assert(*i == j);
1206a929492SRuslan Arutyunyan assert(i == m.end());
121*a7b9af78SCasey Carter for (int j = static_cast<int>(m.size()); j >= 1; --j) {
1226a929492SRuslan Arutyunyan --i;
1236a929492SRuslan Arutyunyan assert(*i == j);
1246a929492SRuslan Arutyunyan }
1256a929492SRuslan Arutyunyan assert(i == m.begin());
1265a83710eSEric Fiselier }
127f2f2a639SEric Fiselier #if TEST_STD_VER >= 11
1285a83710eSEric Fiselier {
1295a83710eSEric Fiselier typedef int V;
1305a83710eSEric Fiselier V ar[] =
1315a83710eSEric Fiselier {
1325a83710eSEric Fiselier 1,
1335a83710eSEric Fiselier 1,
1345a83710eSEric Fiselier 1,
1355a83710eSEric Fiselier 2,
1365a83710eSEric Fiselier 2,
1375a83710eSEric Fiselier 2,
1385a83710eSEric Fiselier 3,
1395a83710eSEric Fiselier 3,
1405a83710eSEric Fiselier 3,
1415a83710eSEric Fiselier 4,
1425a83710eSEric Fiselier 4,
1435a83710eSEric Fiselier 4,
1445a83710eSEric Fiselier 5,
1455a83710eSEric Fiselier 5,
1465a83710eSEric Fiselier 5,
1475a83710eSEric Fiselier 6,
1485a83710eSEric Fiselier 6,
1495a83710eSEric Fiselier 6,
1505a83710eSEric Fiselier 7,
1515a83710eSEric Fiselier 7,
1525a83710eSEric Fiselier 7,
1535a83710eSEric Fiselier 8,
1545a83710eSEric Fiselier 8,
1555a83710eSEric Fiselier 8
1565a83710eSEric Fiselier };
1575a83710eSEric Fiselier std::set<int, std::less<int>, min_allocator<int>> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
158fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
159fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
1605a83710eSEric Fiselier std::set<int, std::less<int>, min_allocator<int>>::iterator i;
1615a83710eSEric Fiselier i = m.begin();
1625a83710eSEric Fiselier std::set<int, std::less<int>, min_allocator<int>>::const_iterator k = i;
1635a83710eSEric Fiselier assert(i == k);
164*a7b9af78SCasey Carter for (int j = 1; j <= static_cast<int>(m.size()); ++j, ++i)
1655a83710eSEric Fiselier assert(*i == j);
1666a929492SRuslan Arutyunyan assert(i == m.end());
167*a7b9af78SCasey Carter for (int j = static_cast<int>(m.size()); j >= 1; --j) {
1686a929492SRuslan Arutyunyan --i;
1696a929492SRuslan Arutyunyan assert(*i == j);
1706a929492SRuslan Arutyunyan }
1716a929492SRuslan Arutyunyan assert(i == m.begin());
1725a83710eSEric Fiselier }
1735a83710eSEric Fiselier {
1745a83710eSEric Fiselier typedef int V;
1755a83710eSEric Fiselier V ar[] =
1765a83710eSEric Fiselier {
1775a83710eSEric Fiselier 1,
1785a83710eSEric Fiselier 1,
1795a83710eSEric Fiselier 1,
1805a83710eSEric Fiselier 2,
1815a83710eSEric Fiselier 2,
1825a83710eSEric Fiselier 2,
1835a83710eSEric Fiselier 3,
1845a83710eSEric Fiselier 3,
1855a83710eSEric Fiselier 3,
1865a83710eSEric Fiselier 4,
1875a83710eSEric Fiselier 4,
1885a83710eSEric Fiselier 4,
1895a83710eSEric Fiselier 5,
1905a83710eSEric Fiselier 5,
1915a83710eSEric Fiselier 5,
1925a83710eSEric Fiselier 6,
1935a83710eSEric Fiselier 6,
1945a83710eSEric Fiselier 6,
1955a83710eSEric Fiselier 7,
1965a83710eSEric Fiselier 7,
1975a83710eSEric Fiselier 7,
1985a83710eSEric Fiselier 8,
1995a83710eSEric Fiselier 8,
2005a83710eSEric Fiselier 8
2015a83710eSEric Fiselier };
2025a83710eSEric Fiselier const std::set<int, std::less<int>, min_allocator<int>> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
203fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
204fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.cbegin(), m.cend())) == m.size());
205fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
206fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.crbegin(), m.crend())) == m.size());
2075a83710eSEric Fiselier std::set<int, std::less<int>, min_allocator<int>>::const_iterator i;
2085a83710eSEric Fiselier i = m.begin();
209*a7b9af78SCasey Carter for (int j = 1; j <= static_cast<int>(m.size()); ++j, ++i)
2105a83710eSEric Fiselier assert(*i == j);
2116a929492SRuslan Arutyunyan assert(i == m.end());
212*a7b9af78SCasey Carter for (int j = static_cast<int>(m.size()); j >= 1; --j) {
2136a929492SRuslan Arutyunyan --i;
2146a929492SRuslan Arutyunyan assert(*i == j);
2156a929492SRuslan Arutyunyan }
2166a929492SRuslan Arutyunyan assert(i == m.begin());
2175a83710eSEric Fiselier }
2185a83710eSEric Fiselier #endif
2190f901c7eSStephan T. Lavavej #if TEST_STD_VER > 11
2205a83710eSEric Fiselier { // N3644 testing
2215a83710eSEric Fiselier typedef std::set<int> C;
2225a83710eSEric Fiselier C::iterator ii1{}, ii2{};
2235a83710eSEric Fiselier C::iterator ii4 = ii1;
2245a83710eSEric Fiselier C::const_iterator cii{};
2255a83710eSEric Fiselier assert ( ii1 == ii2 );
2265a83710eSEric Fiselier assert ( ii1 == ii4 );
2275a83710eSEric Fiselier
2285a83710eSEric Fiselier assert (!(ii1 != ii2 ));
2295a83710eSEric Fiselier
2305a83710eSEric Fiselier assert ( (ii1 == cii ));
2315a83710eSEric Fiselier assert ( (cii == ii1 ));
2325a83710eSEric Fiselier assert (!(ii1 != cii ));
2335a83710eSEric Fiselier assert (!(cii != ii1 ));
2345a83710eSEric Fiselier }
2355a83710eSEric Fiselier #endif
2362df59c50SJF Bastien
2372df59c50SJF Bastien return 0;
2385a83710eSEric Fiselier }
239