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 multimap
125a83710eSEric Fiselier
135a83710eSEric Fiselier // void swap(multimap& m);
145a83710eSEric Fiselier
155a83710eSEric Fiselier #include <map>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier
18*7fc6a556SMarshall Clow #include "test_macros.h"
195a83710eSEric Fiselier #include "min_allocator.h"
205a83710eSEric Fiselier
main(int,char **)212df59c50SJF Bastien int main(int, char**)
225a83710eSEric Fiselier {
235a83710eSEric Fiselier typedef std::pair<const int, double> V;
245a83710eSEric Fiselier {
255a83710eSEric Fiselier typedef std::multimap<int, double> M;
265a83710eSEric Fiselier {
278f55e629SEric Fiselier M m1;
288f55e629SEric Fiselier M m2;
295a83710eSEric Fiselier M m1_save = m1;
305a83710eSEric Fiselier M m2_save = m2;
315a83710eSEric Fiselier m1.swap(m2);
325a83710eSEric Fiselier assert(m1 == m2_save);
335a83710eSEric Fiselier assert(m2 == m1_save);
345a83710eSEric Fiselier }
355a83710eSEric Fiselier {
365a83710eSEric Fiselier V ar2[] =
375a83710eSEric Fiselier {
385a83710eSEric Fiselier V(5, 5),
395a83710eSEric Fiselier V(6, 6),
405a83710eSEric Fiselier V(7, 7),
415a83710eSEric Fiselier V(8, 8),
425a83710eSEric Fiselier V(9, 9),
435a83710eSEric Fiselier V(10, 10),
445a83710eSEric Fiselier V(11, 11),
455a83710eSEric Fiselier V(12, 12)
465a83710eSEric Fiselier };
478f55e629SEric Fiselier M m1;
485a83710eSEric Fiselier M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
495a83710eSEric Fiselier M m1_save = m1;
505a83710eSEric Fiselier M m2_save = m2;
515a83710eSEric Fiselier m1.swap(m2);
525a83710eSEric Fiselier assert(m1 == m2_save);
535a83710eSEric Fiselier assert(m2 == m1_save);
545a83710eSEric Fiselier }
555a83710eSEric Fiselier {
565a83710eSEric Fiselier V ar1[] =
575a83710eSEric Fiselier {
585a83710eSEric Fiselier V(1, 1),
595a83710eSEric Fiselier V(2, 2),
605a83710eSEric Fiselier V(3, 3),
615a83710eSEric Fiselier V(4, 4)
625a83710eSEric Fiselier };
635a83710eSEric Fiselier M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
648f55e629SEric Fiselier M m2;
655a83710eSEric Fiselier M m1_save = m1;
665a83710eSEric Fiselier M m2_save = m2;
675a83710eSEric Fiselier m1.swap(m2);
685a83710eSEric Fiselier assert(m1 == m2_save);
695a83710eSEric Fiselier assert(m2 == m1_save);
705a83710eSEric Fiselier }
715a83710eSEric Fiselier {
725a83710eSEric Fiselier V ar1[] =
735a83710eSEric Fiselier {
745a83710eSEric Fiselier V(1, 1),
755a83710eSEric Fiselier V(2, 2),
765a83710eSEric Fiselier V(3, 3),
775a83710eSEric Fiselier V(4, 4)
785a83710eSEric Fiselier };
795a83710eSEric Fiselier V ar2[] =
805a83710eSEric Fiselier {
815a83710eSEric Fiselier V(5, 5),
825a83710eSEric Fiselier V(6, 6),
835a83710eSEric Fiselier V(7, 7),
845a83710eSEric Fiselier V(8, 8),
855a83710eSEric Fiselier V(9, 9),
865a83710eSEric Fiselier V(10, 10),
875a83710eSEric Fiselier V(11, 11),
885a83710eSEric Fiselier V(12, 12)
895a83710eSEric Fiselier };
905a83710eSEric Fiselier M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
915a83710eSEric Fiselier M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
925a83710eSEric Fiselier M m1_save = m1;
935a83710eSEric Fiselier M m2_save = m2;
945a83710eSEric Fiselier m1.swap(m2);
955a83710eSEric Fiselier assert(m1 == m2_save);
965a83710eSEric Fiselier assert(m2 == m1_save);
975a83710eSEric Fiselier }
985a83710eSEric Fiselier }
99f2f2a639SEric Fiselier #if TEST_STD_VER >= 11
1005a83710eSEric Fiselier {
1015a83710eSEric Fiselier typedef std::multimap<int, double, std::less<int>, min_allocator<std::pair<const int, double>>> M;
1025a83710eSEric Fiselier {
1038f55e629SEric Fiselier M m1;
1048f55e629SEric Fiselier M m2;
1055a83710eSEric Fiselier M m1_save = m1;
1065a83710eSEric Fiselier M m2_save = m2;
1075a83710eSEric Fiselier m1.swap(m2);
1085a83710eSEric Fiselier assert(m1 == m2_save);
1095a83710eSEric Fiselier assert(m2 == m1_save);
1105a83710eSEric Fiselier }
1115a83710eSEric Fiselier {
1125a83710eSEric Fiselier V ar2[] =
1135a83710eSEric Fiselier {
1145a83710eSEric Fiselier V(5, 5),
1155a83710eSEric Fiselier V(6, 6),
1165a83710eSEric Fiselier V(7, 7),
1175a83710eSEric Fiselier V(8, 8),
1185a83710eSEric Fiselier V(9, 9),
1195a83710eSEric Fiselier V(10, 10),
1205a83710eSEric Fiselier V(11, 11),
1215a83710eSEric Fiselier V(12, 12)
1225a83710eSEric Fiselier };
1238f55e629SEric Fiselier M m1;
1245a83710eSEric Fiselier M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
1255a83710eSEric Fiselier M m1_save = m1;
1265a83710eSEric Fiselier M m2_save = m2;
1275a83710eSEric Fiselier m1.swap(m2);
1285a83710eSEric Fiselier assert(m1 == m2_save);
1295a83710eSEric Fiselier assert(m2 == m1_save);
1305a83710eSEric Fiselier }
1315a83710eSEric Fiselier {
1325a83710eSEric Fiselier V ar1[] =
1335a83710eSEric Fiselier {
1345a83710eSEric Fiselier V(1, 1),
1355a83710eSEric Fiselier V(2, 2),
1365a83710eSEric Fiselier V(3, 3),
1375a83710eSEric Fiselier V(4, 4)
1385a83710eSEric Fiselier };
1395a83710eSEric Fiselier M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
1408f55e629SEric Fiselier M m2;
1415a83710eSEric Fiselier M m1_save = m1;
1425a83710eSEric Fiselier M m2_save = m2;
1435a83710eSEric Fiselier m1.swap(m2);
1445a83710eSEric Fiselier assert(m1 == m2_save);
1455a83710eSEric Fiselier assert(m2 == m1_save);
1465a83710eSEric Fiselier }
1475a83710eSEric Fiselier {
1485a83710eSEric Fiselier V ar1[] =
1495a83710eSEric Fiselier {
1505a83710eSEric Fiselier V(1, 1),
1515a83710eSEric Fiselier V(2, 2),
1525a83710eSEric Fiselier V(3, 3),
1535a83710eSEric Fiselier V(4, 4)
1545a83710eSEric Fiselier };
1555a83710eSEric Fiselier V ar2[] =
1565a83710eSEric Fiselier {
1575a83710eSEric Fiselier V(5, 5),
1585a83710eSEric Fiselier V(6, 6),
1595a83710eSEric Fiselier V(7, 7),
1605a83710eSEric Fiselier V(8, 8),
1615a83710eSEric Fiselier V(9, 9),
1625a83710eSEric Fiselier V(10, 10),
1635a83710eSEric Fiselier V(11, 11),
1645a83710eSEric Fiselier V(12, 12)
1655a83710eSEric Fiselier };
1665a83710eSEric Fiselier M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
1675a83710eSEric Fiselier M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
1685a83710eSEric Fiselier M m1_save = m1;
1695a83710eSEric Fiselier M m2_save = m2;
1705a83710eSEric Fiselier m1.swap(m2);
1715a83710eSEric Fiselier assert(m1 == m2_save);
1725a83710eSEric Fiselier assert(m2 == m1_save);
1735a83710eSEric Fiselier }
1745a83710eSEric Fiselier }
1755a83710eSEric Fiselier #endif
1762df59c50SJF Bastien
1772df59c50SJF Bastien return 0;
1785a83710eSEric Fiselier }
179