xref: /llvm-project/libcxx/test/std/containers/unord/unord.set/eq.pass.cpp (revision 7fc6a55688c816f5fc1a5481ae7af25be7500356)
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 // <unordered_set>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // template <class Key, class Hash, class Pred, class Alloc>
125a83710eSEric Fiselier // bool
135a83710eSEric Fiselier // operator==(const unordered_set<Key, Hash, Pred, Alloc>& x,
145a83710eSEric Fiselier //            const unordered_set<Key, Hash, Pred, Alloc>& y);
155a83710eSEric Fiselier //
165a83710eSEric Fiselier // template <class Key, class Hash, class Pred, class Alloc>
175a83710eSEric Fiselier // bool
185a83710eSEric Fiselier // operator!=(const unordered_set<Key, Hash, Pred, Alloc>& x,
195a83710eSEric Fiselier //            const unordered_set<Key, Hash, Pred, Alloc>& y);
205a83710eSEric Fiselier 
215a83710eSEric Fiselier #include <unordered_set>
225a83710eSEric Fiselier #include <cassert>
235a83710eSEric Fiselier 
24*7fc6a556SMarshall Clow #include "test_macros.h"
255a83710eSEric Fiselier #include "min_allocator.h"
265a83710eSEric Fiselier 
main(int,char **)272df59c50SJF Bastien int main(int, char**)
285a83710eSEric Fiselier {
295a83710eSEric Fiselier     {
305a83710eSEric Fiselier         typedef std::unordered_set<int> C;
315a83710eSEric Fiselier         typedef int P;
325a83710eSEric Fiselier         P a[] =
335a83710eSEric Fiselier         {
345a83710eSEric Fiselier             P(10),
355a83710eSEric Fiselier             P(20),
365a83710eSEric Fiselier             P(30),
375a83710eSEric Fiselier             P(40),
385a83710eSEric Fiselier             P(50),
395a83710eSEric Fiselier             P(60),
405a83710eSEric Fiselier             P(70),
415a83710eSEric Fiselier             P(80)
425a83710eSEric Fiselier         };
435a83710eSEric Fiselier         const C c1(std::begin(a), std::end(a));
445a83710eSEric Fiselier         const C c2;
455a83710eSEric Fiselier         assert(!(c1 == c2));
465a83710eSEric Fiselier         assert( (c1 != c2));
475a83710eSEric Fiselier     }
485a83710eSEric Fiselier     {
495a83710eSEric Fiselier         typedef std::unordered_set<int> C;
505a83710eSEric Fiselier         typedef int P;
515a83710eSEric Fiselier         P a[] =
525a83710eSEric Fiselier         {
535a83710eSEric Fiselier             P(10),
545a83710eSEric Fiselier             P(20),
555a83710eSEric Fiselier             P(30),
565a83710eSEric Fiselier             P(40),
575a83710eSEric Fiselier             P(50),
585a83710eSEric Fiselier             P(60),
595a83710eSEric Fiselier             P(70),
605a83710eSEric Fiselier             P(80)
615a83710eSEric Fiselier         };
625a83710eSEric Fiselier         const C c1(std::begin(a), std::end(a));
635a83710eSEric Fiselier         const C c2 = c1;
645a83710eSEric Fiselier         assert( (c1 == c2));
655a83710eSEric Fiselier         assert(!(c1 != c2));
665a83710eSEric Fiselier     }
675a83710eSEric Fiselier     {
685a83710eSEric Fiselier         typedef std::unordered_set<int> C;
695a83710eSEric Fiselier         typedef int P;
705a83710eSEric Fiselier         P a[] =
715a83710eSEric Fiselier         {
725a83710eSEric Fiselier             P(10),
735a83710eSEric Fiselier             P(20),
745a83710eSEric Fiselier             P(30),
755a83710eSEric Fiselier             P(40),
765a83710eSEric Fiselier             P(50),
775a83710eSEric Fiselier             P(60),
785a83710eSEric Fiselier             P(70),
795a83710eSEric Fiselier             P(80)
805a83710eSEric Fiselier         };
815a83710eSEric Fiselier         C c1(std::begin(a), std::end(a));
825a83710eSEric Fiselier         C c2 = c1;
835a83710eSEric Fiselier         c2.rehash(30);
845a83710eSEric Fiselier         assert( (c1 == c2));
855a83710eSEric Fiselier         assert(!(c1 != c2));
865a83710eSEric Fiselier         c2.insert(P(90));
875a83710eSEric Fiselier         assert(!(c1 == c2));
885a83710eSEric Fiselier         assert( (c1 != c2));
895a83710eSEric Fiselier         c1.insert(P(90));
905a83710eSEric Fiselier         assert( (c1 == c2));
915a83710eSEric Fiselier         assert(!(c1 != c2));
925a83710eSEric Fiselier     }
93f2f2a639SEric Fiselier #if TEST_STD_VER >= 11
945a83710eSEric Fiselier     {
955a83710eSEric Fiselier         typedef std::unordered_set<int, std::hash<int>, std::equal_to<int>, min_allocator<int>> C;
965a83710eSEric Fiselier         typedef int P;
975a83710eSEric Fiselier         P a[] =
985a83710eSEric Fiselier         {
995a83710eSEric Fiselier             P(10),
1005a83710eSEric Fiselier             P(20),
1015a83710eSEric Fiselier             P(30),
1025a83710eSEric Fiselier             P(40),
1035a83710eSEric Fiselier             P(50),
1045a83710eSEric Fiselier             P(60),
1055a83710eSEric Fiselier             P(70),
1065a83710eSEric Fiselier             P(80)
1075a83710eSEric Fiselier         };
1085a83710eSEric Fiselier         const C c1(std::begin(a), std::end(a));
1095a83710eSEric Fiselier         const C c2;
1105a83710eSEric Fiselier         assert(!(c1 == c2));
1115a83710eSEric Fiselier         assert( (c1 != c2));
1125a83710eSEric Fiselier     }
1135a83710eSEric Fiselier     {
1145a83710eSEric Fiselier         typedef std::unordered_set<int, std::hash<int>, std::equal_to<int>, min_allocator<int>> C;
1155a83710eSEric Fiselier         typedef int P;
1165a83710eSEric Fiselier         P a[] =
1175a83710eSEric Fiselier         {
1185a83710eSEric Fiselier             P(10),
1195a83710eSEric Fiselier             P(20),
1205a83710eSEric Fiselier             P(30),
1215a83710eSEric Fiselier             P(40),
1225a83710eSEric Fiselier             P(50),
1235a83710eSEric Fiselier             P(60),
1245a83710eSEric Fiselier             P(70),
1255a83710eSEric Fiselier             P(80)
1265a83710eSEric Fiselier         };
1275a83710eSEric Fiselier         const C c1(std::begin(a), std::end(a));
1285a83710eSEric Fiselier         const C c2 = c1;
1295a83710eSEric Fiselier         assert( (c1 == c2));
1305a83710eSEric Fiselier         assert(!(c1 != c2));
1315a83710eSEric Fiselier     }
1325a83710eSEric Fiselier     {
1335a83710eSEric Fiselier         typedef std::unordered_set<int, std::hash<int>, std::equal_to<int>, min_allocator<int>> C;
1345a83710eSEric Fiselier         typedef int P;
1355a83710eSEric Fiselier         P a[] =
1365a83710eSEric Fiselier         {
1375a83710eSEric Fiselier             P(10),
1385a83710eSEric Fiselier             P(20),
1395a83710eSEric Fiselier             P(30),
1405a83710eSEric Fiselier             P(40),
1415a83710eSEric Fiselier             P(50),
1425a83710eSEric Fiselier             P(60),
1435a83710eSEric Fiselier             P(70),
1445a83710eSEric Fiselier             P(80)
1455a83710eSEric Fiselier         };
1465a83710eSEric Fiselier         C c1(std::begin(a), std::end(a));
1475a83710eSEric Fiselier         C c2 = c1;
1485a83710eSEric Fiselier         c2.rehash(30);
1495a83710eSEric Fiselier         assert( (c1 == c2));
1505a83710eSEric Fiselier         assert(!(c1 != c2));
1515a83710eSEric Fiselier         c2.insert(P(90));
1525a83710eSEric Fiselier         assert(!(c1 == c2));
1535a83710eSEric Fiselier         assert( (c1 != c2));
1545a83710eSEric Fiselier         c1.insert(P(90));
1555a83710eSEric Fiselier         assert( (c1 == c2));
1565a83710eSEric Fiselier         assert(!(c1 != c2));
1575a83710eSEric Fiselier     }
1585a83710eSEric Fiselier #endif
1592df59c50SJF Bastien 
1602df59c50SJF Bastien   return 0;
1615a83710eSEric Fiselier }
162