1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8
9 // <unordered_map>
10
11 // template <class Key, class T, class Hash, class Pred, class Alloc>
12 // bool
13 // operator==(const unordered_multimap<Key, T, Hash, Pred, Alloc>& x,
14 // const unordered_multimap<Key, T, Hash, Pred, Alloc>& y);
15 //
16 // template <class Key, class T, class Hash, class Pred, class Alloc>
17 // bool
18 // operator!=(const unordered_multimap<Key, T, Hash, Pred, Alloc>& x,
19 // const unordered_multimap<Key, T, Hash, Pred, Alloc>& y);
20
21 #include <unordered_map>
22 #include <string>
23 #include <cassert>
24
25 #include "test_macros.h"
26 #include "min_allocator.h"
27
main(int,char **)28 int main(int, char**)
29 {
30 {
31 typedef std::unordered_multimap<int, std::string> C;
32 typedef std::pair<int, std::string> P;
33 P a[] =
34 {
35 P(10, "ten"),
36 P(20, "twenty"),
37 P(20, "twenty 2"),
38 P(30, "thirty"),
39 P(40, "forty"),
40 P(50, "fifty"),
41 P(50, "fifty 2"),
42 P(50, "fifty 3"),
43 P(60, "sixty"),
44 P(70, "seventy"),
45 P(80, "eighty"),
46 };
47 const C c1(std::begin(a), std::end(a));
48 const C c2;
49 assert(!(c1 == c2));
50 assert( (c1 != c2));
51 }
52 {
53 typedef std::unordered_multimap<int, std::string> C;
54 typedef std::pair<int, std::string> P;
55 P a[] =
56 {
57 P(10, "ten"),
58 P(20, "twenty"),
59 P(20, "twenty 2"),
60 P(30, "thirty"),
61 P(40, "forty"),
62 P(50, "fifty"),
63 P(50, "fifty 2"),
64 P(50, "fifty 3"),
65 P(60, "sixty"),
66 P(70, "seventy"),
67 P(80, "eighty"),
68 };
69 const C c1(std::begin(a), std::end(a));
70 const C c2 = c1;
71 assert( (c1 == c2));
72 assert(!(c1 != c2));
73 }
74 {
75 typedef std::unordered_multimap<int, std::string> C;
76 typedef std::pair<int, std::string> P;
77 P a[] =
78 {
79 P(10, "ten"),
80 P(20, "twenty"),
81 P(20, "twenty 2"),
82 P(30, "thirty"),
83 P(40, "forty"),
84 P(50, "fifty"),
85 P(50, "fifty 2"),
86 P(50, "fifty 3"),
87 P(60, "sixty"),
88 P(70, "seventy"),
89 P(80, "eighty"),
90 };
91 C c1(std::begin(a), std::end(a));
92 C c2 = c1;
93 c2.rehash(30);
94 assert( (c1 == c2));
95 assert(!(c1 != c2));
96 c2.insert(P(90, "ninety"));
97 assert(!(c1 == c2));
98 assert( (c1 != c2));
99 c1.insert(P(90, "ninety"));
100 assert( (c1 == c2));
101 assert(!(c1 != c2));
102 }
103 #if TEST_STD_VER >= 11
104 {
105 typedef std::unordered_multimap<int, std::string, std::hash<int>, std::equal_to<int>,
106 min_allocator<std::pair<const int, std::string>>> C;
107 typedef std::pair<int, std::string> P;
108 P a[] =
109 {
110 P(10, "ten"),
111 P(20, "twenty"),
112 P(20, "twenty 2"),
113 P(30, "thirty"),
114 P(40, "forty"),
115 P(50, "fifty"),
116 P(50, "fifty 2"),
117 P(50, "fifty 3"),
118 P(60, "sixty"),
119 P(70, "seventy"),
120 P(80, "eighty"),
121 };
122 const C c1(std::begin(a), std::end(a));
123 const C c2;
124 assert(!(c1 == c2));
125 assert( (c1 != c2));
126 }
127 {
128 typedef std::unordered_multimap<int, std::string, std::hash<int>, std::equal_to<int>,
129 min_allocator<std::pair<const int, std::string>>> C;
130 typedef std::pair<int, std::string> P;
131 P a[] =
132 {
133 P(10, "ten"),
134 P(20, "twenty"),
135 P(20, "twenty 2"),
136 P(30, "thirty"),
137 P(40, "forty"),
138 P(50, "fifty"),
139 P(50, "fifty 2"),
140 P(50, "fifty 3"),
141 P(60, "sixty"),
142 P(70, "seventy"),
143 P(80, "eighty"),
144 };
145 const C c1(std::begin(a), std::end(a));
146 const C c2 = c1;
147 assert( (c1 == c2));
148 assert(!(c1 != c2));
149 }
150 {
151 typedef std::unordered_multimap<int, std::string, std::hash<int>, std::equal_to<int>,
152 min_allocator<std::pair<const int, std::string>>> C;
153 typedef std::pair<int, std::string> P;
154 P a[] =
155 {
156 P(10, "ten"),
157 P(20, "twenty"),
158 P(20, "twenty 2"),
159 P(30, "thirty"),
160 P(40, "forty"),
161 P(50, "fifty"),
162 P(50, "fifty 2"),
163 P(50, "fifty 3"),
164 P(60, "sixty"),
165 P(70, "seventy"),
166 P(80, "eighty"),
167 };
168 C c1(std::begin(a), std::end(a));
169 C c2 = c1;
170 c2.rehash(30);
171 assert( (c1 == c2));
172 assert(!(c1 != c2));
173 c2.insert(P(90, "ninety"));
174 assert(!(c1 == c2));
175 assert( (c1 != c2));
176 c1.insert(P(90, "ninety"));
177 assert( (c1 == c2));
178 assert(!(c1 != c2));
179 }
180 #endif
181
182 return 0;
183 }
184