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 // <map>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // class map
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 <map>
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 std::pair<const int, double> V;
395a83710eSEric Fiselier V ar[] =
405a83710eSEric Fiselier {
415a83710eSEric Fiselier V(1, 1),
425a83710eSEric Fiselier V(1, 1.5),
435a83710eSEric Fiselier V(1, 2),
445a83710eSEric Fiselier V(2, 1),
455a83710eSEric Fiselier V(2, 1.5),
465a83710eSEric Fiselier V(2, 2),
475a83710eSEric Fiselier V(3, 1),
485a83710eSEric Fiselier V(3, 1.5),
495a83710eSEric Fiselier V(3, 2),
505a83710eSEric Fiselier V(4, 1),
515a83710eSEric Fiselier V(4, 1.5),
525a83710eSEric Fiselier V(4, 2),
535a83710eSEric Fiselier V(5, 1),
545a83710eSEric Fiselier V(5, 1.5),
555a83710eSEric Fiselier V(5, 2),
565a83710eSEric Fiselier V(6, 1),
575a83710eSEric Fiselier V(6, 1.5),
585a83710eSEric Fiselier V(6, 2),
595a83710eSEric Fiselier V(7, 1),
605a83710eSEric Fiselier V(7, 1.5),
615a83710eSEric Fiselier V(7, 2),
625a83710eSEric Fiselier V(8, 1),
635a83710eSEric Fiselier V(8, 1.5),
645a83710eSEric Fiselier V(8, 2)
655a83710eSEric Fiselier };
665a83710eSEric Fiselier std::map<int, double> 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::map<int, double>::iterator i;
705a83710eSEric Fiselier i = m.begin();
715a83710eSEric Fiselier std::map<int, double>::const_iterator k = i;
725a83710eSEric Fiselier assert(i == k);
73a11d322fSStephan T. Lavavej for (int j = 1; static_cast<std::size_t>(j) <= m.size(); ++j, ++i)
745a83710eSEric Fiselier {
755a83710eSEric Fiselier assert(i->first == j);
765a83710eSEric Fiselier assert(i->second == 1);
775a83710eSEric Fiselier i->second = 2.5;
785a83710eSEric Fiselier assert(i->second == 2.5);
795a83710eSEric Fiselier }
80*6a929492SRuslan Arutyunyan assert(i == m.end());
81*6a929492SRuslan Arutyunyan for (int j = m.size(); j >= 1; --j)
82*6a929492SRuslan Arutyunyan {
83*6a929492SRuslan Arutyunyan --i;
84*6a929492SRuslan Arutyunyan assert(i->first == j);
85*6a929492SRuslan Arutyunyan assert(i->second == 2.5);
86*6a929492SRuslan Arutyunyan i->second = 1;
87*6a929492SRuslan Arutyunyan assert(i->second == 1);
88*6a929492SRuslan Arutyunyan }
89*6a929492SRuslan Arutyunyan assert(i == m.begin());
905a83710eSEric Fiselier }
915a83710eSEric Fiselier {
925a83710eSEric Fiselier typedef std::pair<const int, double> V;
935a83710eSEric Fiselier V ar[] =
945a83710eSEric Fiselier {
955a83710eSEric Fiselier V(1, 1),
965a83710eSEric Fiselier V(1, 1.5),
975a83710eSEric Fiselier V(1, 2),
985a83710eSEric Fiselier V(2, 1),
995a83710eSEric Fiselier V(2, 1.5),
1005a83710eSEric Fiselier V(2, 2),
1015a83710eSEric Fiselier V(3, 1),
1025a83710eSEric Fiselier V(3, 1.5),
1035a83710eSEric Fiselier V(3, 2),
1045a83710eSEric Fiselier V(4, 1),
1055a83710eSEric Fiselier V(4, 1.5),
1065a83710eSEric Fiselier V(4, 2),
1075a83710eSEric Fiselier V(5, 1),
1085a83710eSEric Fiselier V(5, 1.5),
1095a83710eSEric Fiselier V(5, 2),
1105a83710eSEric Fiselier V(6, 1),
1115a83710eSEric Fiselier V(6, 1.5),
1125a83710eSEric Fiselier V(6, 2),
1135a83710eSEric Fiselier V(7, 1),
1145a83710eSEric Fiselier V(7, 1.5),
1155a83710eSEric Fiselier V(7, 2),
1165a83710eSEric Fiselier V(8, 1),
1175a83710eSEric Fiselier V(8, 1.5),
1185a83710eSEric Fiselier V(8, 2)
1195a83710eSEric Fiselier };
1205a83710eSEric Fiselier const std::map<int, double> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
121fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
122fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.cbegin(), m.cend())) == m.size());
123fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
124fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.crbegin(), m.crend())) == m.size());
1255a83710eSEric Fiselier std::map<int, double>::const_iterator i;
1265a83710eSEric Fiselier i = m.begin();
127a11d322fSStephan T. Lavavej for (int j = 1; static_cast<std::size_t>(j) <= m.size(); ++j, ++i)
1285a83710eSEric Fiselier {
1295a83710eSEric Fiselier assert(i->first == j);
1305a83710eSEric Fiselier assert(i->second == 1);
1315a83710eSEric Fiselier }
132*6a929492SRuslan Arutyunyan assert(i == m.end());
133*6a929492SRuslan Arutyunyan for (int j = m.size(); j >= 1; --j)
134*6a929492SRuslan Arutyunyan {
135*6a929492SRuslan Arutyunyan --i;
136*6a929492SRuslan Arutyunyan assert(i->first == j);
137*6a929492SRuslan Arutyunyan assert(i->second == 1);
138*6a929492SRuslan Arutyunyan }
139*6a929492SRuslan Arutyunyan assert(i == m.begin());
1405a83710eSEric Fiselier }
141f2f2a639SEric Fiselier #if TEST_STD_VER >= 11
1425a83710eSEric Fiselier {
1435a83710eSEric Fiselier typedef std::pair<const int, double> V;
1445a83710eSEric Fiselier V ar[] =
1455a83710eSEric Fiselier {
1465a83710eSEric Fiselier V(1, 1),
1475a83710eSEric Fiselier V(1, 1.5),
1485a83710eSEric Fiselier V(1, 2),
1495a83710eSEric Fiselier V(2, 1),
1505a83710eSEric Fiselier V(2, 1.5),
1515a83710eSEric Fiselier V(2, 2),
1525a83710eSEric Fiselier V(3, 1),
1535a83710eSEric Fiselier V(3, 1.5),
1545a83710eSEric Fiselier V(3, 2),
1555a83710eSEric Fiselier V(4, 1),
1565a83710eSEric Fiselier V(4, 1.5),
1575a83710eSEric Fiselier V(4, 2),
1585a83710eSEric Fiselier V(5, 1),
1595a83710eSEric Fiselier V(5, 1.5),
1605a83710eSEric Fiselier V(5, 2),
1615a83710eSEric Fiselier V(6, 1),
1625a83710eSEric Fiselier V(6, 1.5),
1635a83710eSEric Fiselier V(6, 2),
1645a83710eSEric Fiselier V(7, 1),
1655a83710eSEric Fiselier V(7, 1.5),
1665a83710eSEric Fiselier V(7, 2),
1675a83710eSEric Fiselier V(8, 1),
1685a83710eSEric Fiselier V(8, 1.5),
1695a83710eSEric Fiselier V(8, 2)
1705a83710eSEric Fiselier };
1715a83710eSEric Fiselier std::map<int, double, std::less<int>, min_allocator<V>> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
172fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
173fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
1745a83710eSEric Fiselier std::map<int, double, std::less<int>, min_allocator<V>>::iterator i;
1755a83710eSEric Fiselier i = m.begin();
1765a83710eSEric Fiselier std::map<int, double, std::less<int>, min_allocator<V>>::const_iterator k = i;
1775a83710eSEric Fiselier assert(i == k);
178a11d322fSStephan T. Lavavej for (int j = 1; static_cast<std::size_t>(j) <= m.size(); ++j, ++i)
1795a83710eSEric Fiselier {
1805a83710eSEric Fiselier assert(i->first == j);
1815a83710eSEric Fiselier assert(i->second == 1);
1825a83710eSEric Fiselier i->second = 2.5;
1835a83710eSEric Fiselier assert(i->second == 2.5);
1845a83710eSEric Fiselier }
185*6a929492SRuslan Arutyunyan assert(i == m.end());
186*6a929492SRuslan Arutyunyan for (int j = m.size(); j >= 1; --j)
187*6a929492SRuslan Arutyunyan {
188*6a929492SRuslan Arutyunyan --i;
189*6a929492SRuslan Arutyunyan assert(i->first == j);
190*6a929492SRuslan Arutyunyan assert(i->second == 2.5);
191*6a929492SRuslan Arutyunyan i->second = 1;
192*6a929492SRuslan Arutyunyan assert(i->second == 1);
193*6a929492SRuslan Arutyunyan }
194*6a929492SRuslan Arutyunyan assert(i == m.begin());
1955a83710eSEric Fiselier }
1965a83710eSEric Fiselier {
1975a83710eSEric Fiselier typedef std::pair<const int, double> V;
1985a83710eSEric Fiselier V ar[] =
1995a83710eSEric Fiselier {
2005a83710eSEric Fiselier V(1, 1),
2015a83710eSEric Fiselier V(1, 1.5),
2025a83710eSEric Fiselier V(1, 2),
2035a83710eSEric Fiselier V(2, 1),
2045a83710eSEric Fiselier V(2, 1.5),
2055a83710eSEric Fiselier V(2, 2),
2065a83710eSEric Fiselier V(3, 1),
2075a83710eSEric Fiselier V(3, 1.5),
2085a83710eSEric Fiselier V(3, 2),
2095a83710eSEric Fiselier V(4, 1),
2105a83710eSEric Fiselier V(4, 1.5),
2115a83710eSEric Fiselier V(4, 2),
2125a83710eSEric Fiselier V(5, 1),
2135a83710eSEric Fiselier V(5, 1.5),
2145a83710eSEric Fiselier V(5, 2),
2155a83710eSEric Fiselier V(6, 1),
2165a83710eSEric Fiselier V(6, 1.5),
2175a83710eSEric Fiselier V(6, 2),
2185a83710eSEric Fiselier V(7, 1),
2195a83710eSEric Fiselier V(7, 1.5),
2205a83710eSEric Fiselier V(7, 2),
2215a83710eSEric Fiselier V(8, 1),
2225a83710eSEric Fiselier V(8, 1.5),
2235a83710eSEric Fiselier V(8, 2)
2245a83710eSEric Fiselier };
2255a83710eSEric Fiselier const std::map<int, double, std::less<int>, min_allocator<V>> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
226fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
227fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.cbegin(), m.cend())) == m.size());
228fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
229fbfb2ab6SStephan T. Lavavej assert(static_cast<std::size_t>(std::distance(m.crbegin(), m.crend())) == m.size());
2305a83710eSEric Fiselier std::map<int, double, std::less<int>, min_allocator<V>>::const_iterator i;
2315a83710eSEric Fiselier i = m.begin();
232a11d322fSStephan T. Lavavej for (int j = 1; static_cast<std::size_t>(j) <= m.size(); ++j, ++i)
2335a83710eSEric Fiselier {
2345a83710eSEric Fiselier assert(i->first == j);
2355a83710eSEric Fiselier assert(i->second == 1);
2365a83710eSEric Fiselier }
237*6a929492SRuslan Arutyunyan assert(i == m.end());
238*6a929492SRuslan Arutyunyan for (int j = m.size(); j >= 1; --j)
239*6a929492SRuslan Arutyunyan {
240*6a929492SRuslan Arutyunyan --i;
241*6a929492SRuslan Arutyunyan assert(i->first == j);
242*6a929492SRuslan Arutyunyan assert(i->second == 1);
243*6a929492SRuslan Arutyunyan }
244*6a929492SRuslan Arutyunyan assert(i == m.begin());
2455a83710eSEric Fiselier }
2465a83710eSEric Fiselier #endif
2470f901c7eSStephan T. Lavavej #if TEST_STD_VER > 11
2485a83710eSEric Fiselier { // N3644 testing
2495a83710eSEric Fiselier typedef std::map<int, double> C;
2505a83710eSEric Fiselier C::iterator ii1{}, ii2{};
2515a83710eSEric Fiselier C::iterator ii4 = ii1;
2525a83710eSEric Fiselier C::const_iterator cii{};
2535a83710eSEric Fiselier assert ( ii1 == ii2 );
2545a83710eSEric Fiselier assert ( ii1 == ii4 );
2555a83710eSEric Fiselier
2565a83710eSEric Fiselier assert (!(ii1 != ii2 ));
2575a83710eSEric Fiselier
2585a83710eSEric Fiselier assert ( (ii1 == cii ));
2595a83710eSEric Fiselier assert ( (cii == ii1 ));
2605a83710eSEric Fiselier assert (!(ii1 != cii ));
2615a83710eSEric Fiselier assert (!(cii != ii1 ));
2625a83710eSEric Fiselier }
2635a83710eSEric Fiselier #endif
2642df59c50SJF Bastien
2652df59c50SJF Bastien return 0;
2665a83710eSEric Fiselier }
267