1 //===----------------------------------------------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 // <set>
11
12 // class multiset
13
14 // pair<iterator,iterator> equal_range(const key_type& k);
15 // pair<const_iterator,const_iterator> equal_range(const key_type& k) const;
16
17 #include <set>
18 #include <cassert>
19
20 #include "test_macros.h"
21 #include "min_allocator.h"
22 #include "private_constructor.hpp"
23
main()24 int main()
25 {
26 {
27 typedef int V;
28 typedef std::multiset<int> M;
29 {
30 typedef std::pair<M::iterator, M::iterator> R;
31 V ar[] =
32 {
33 5,
34 5,
35 5,
36 7,
37 7,
38 7,
39 9,
40 9,
41 9
42 };
43 M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
44 R r = m.equal_range(4);
45 assert(r.first == next(m.begin(), 0));
46 assert(r.second == next(m.begin(), 0));
47 r = m.equal_range(5);
48 assert(r.first == next(m.begin(), 0));
49 assert(r.second == next(m.begin(), 3));
50 r = m.equal_range(6);
51 assert(r.first == next(m.begin(), 3));
52 assert(r.second == next(m.begin(), 3));
53 r = m.equal_range(7);
54 assert(r.first == next(m.begin(), 3));
55 assert(r.second == next(m.begin(), 6));
56 r = m.equal_range(8);
57 assert(r.first == next(m.begin(), 6));
58 assert(r.second == next(m.begin(), 6));
59 r = m.equal_range(9);
60 assert(r.first == next(m.begin(), 6));
61 assert(r.second == next(m.begin(), 9));
62 r = m.equal_range(10);
63 assert(r.first == next(m.begin(), 9));
64 assert(r.second == next(m.begin(), 9));
65 }
66 {
67 typedef std::pair<M::const_iterator, M::const_iterator> R;
68 V ar[] =
69 {
70 5,
71 5,
72 5,
73 7,
74 7,
75 7,
76 9,
77 9,
78 9
79 };
80 M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
81 R r = m.equal_range(4);
82 assert(r.first == next(m.begin(), 0));
83 assert(r.second == next(m.begin(), 0));
84 r = m.equal_range(5);
85 assert(r.first == next(m.begin(), 0));
86 assert(r.second == next(m.begin(), 3));
87 r = m.equal_range(6);
88 assert(r.first == next(m.begin(), 3));
89 assert(r.second == next(m.begin(), 3));
90 r = m.equal_range(7);
91 assert(r.first == next(m.begin(), 3));
92 assert(r.second == next(m.begin(), 6));
93 r = m.equal_range(8);
94 assert(r.first == next(m.begin(), 6));
95 assert(r.second == next(m.begin(), 6));
96 r = m.equal_range(9);
97 assert(r.first == next(m.begin(), 6));
98 assert(r.second == next(m.begin(), 9));
99 r = m.equal_range(10);
100 assert(r.first == next(m.begin(), 9));
101 assert(r.second == next(m.begin(), 9));
102 }
103 }
104 #if TEST_STD_VER >= 11
105 {
106 typedef int V;
107 typedef std::multiset<int, std::less<int>, min_allocator<int>> M;
108 {
109 typedef std::pair<M::iterator, M::iterator> R;
110 V ar[] =
111 {
112 5,
113 5,
114 5,
115 7,
116 7,
117 7,
118 9,
119 9,
120 9
121 };
122 M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
123 R r = m.equal_range(4);
124 assert(r.first == next(m.begin(), 0));
125 assert(r.second == next(m.begin(), 0));
126 r = m.equal_range(5);
127 assert(r.first == next(m.begin(), 0));
128 assert(r.second == next(m.begin(), 3));
129 r = m.equal_range(6);
130 assert(r.first == next(m.begin(), 3));
131 assert(r.second == next(m.begin(), 3));
132 r = m.equal_range(7);
133 assert(r.first == next(m.begin(), 3));
134 assert(r.second == next(m.begin(), 6));
135 r = m.equal_range(8);
136 assert(r.first == next(m.begin(), 6));
137 assert(r.second == next(m.begin(), 6));
138 r = m.equal_range(9);
139 assert(r.first == next(m.begin(), 6));
140 assert(r.second == next(m.begin(), 9));
141 r = m.equal_range(10);
142 assert(r.first == next(m.begin(), 9));
143 assert(r.second == next(m.begin(), 9));
144 }
145 {
146 typedef std::pair<M::const_iterator, M::const_iterator> R;
147 V ar[] =
148 {
149 5,
150 5,
151 5,
152 7,
153 7,
154 7,
155 9,
156 9,
157 9
158 };
159 M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
160 R r = m.equal_range(4);
161 assert(r.first == next(m.begin(), 0));
162 assert(r.second == next(m.begin(), 0));
163 r = m.equal_range(5);
164 assert(r.first == next(m.begin(), 0));
165 assert(r.second == next(m.begin(), 3));
166 r = m.equal_range(6);
167 assert(r.first == next(m.begin(), 3));
168 assert(r.second == next(m.begin(), 3));
169 r = m.equal_range(7);
170 assert(r.first == next(m.begin(), 3));
171 assert(r.second == next(m.begin(), 6));
172 r = m.equal_range(8);
173 assert(r.first == next(m.begin(), 6));
174 assert(r.second == next(m.begin(), 6));
175 r = m.equal_range(9);
176 assert(r.first == next(m.begin(), 6));
177 assert(r.second == next(m.begin(), 9));
178 r = m.equal_range(10);
179 assert(r.first == next(m.begin(), 9));
180 assert(r.second == next(m.begin(), 9));
181 }
182 }
183 #endif
184 #if TEST_STD_VER > 11
185 {
186 typedef int V;
187 typedef std::multiset<V, std::less<>> M;
188 typedef std::pair<M::iterator, M::iterator> R;
189 V ar[] =
190 {
191 5,
192 5,
193 5,
194 7,
195 7,
196 7,
197 9,
198 9,
199 9
200 };
201 M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
202 R r = m.equal_range(4);
203 assert(r.first == next(m.begin(), 0));
204 assert(r.second == next(m.begin(), 0));
205 r = m.equal_range(5);
206 assert(r.first == next(m.begin(), 0));
207 assert(r.second == next(m.begin(), 3));
208 r = m.equal_range(6);
209 assert(r.first == next(m.begin(), 3));
210 assert(r.second == next(m.begin(), 3));
211 r = m.equal_range(7);
212 assert(r.first == next(m.begin(), 3));
213 assert(r.second == next(m.begin(), 6));
214 r = m.equal_range(8);
215 assert(r.first == next(m.begin(), 6));
216 assert(r.second == next(m.begin(), 6));
217 r = m.equal_range(9);
218 assert(r.first == next(m.begin(), 6));
219 assert(r.second == next(m.begin(), 9));
220 r = m.equal_range(10);
221 assert(r.first == next(m.begin(), 9));
222 assert(r.second == next(m.begin(), 9));
223 }
224
225 {
226 typedef PrivateConstructor V;
227 typedef std::multiset<V, std::less<>> M;
228 typedef std::pair<M::iterator, M::iterator> R;
229
230 M m;
231 m.insert ( V::make ( 5 ));
232 m.insert ( V::make ( 5 ));
233 m.insert ( V::make ( 5 ));
234 m.insert ( V::make ( 7 ));
235 m.insert ( V::make ( 7 ));
236 m.insert ( V::make ( 7 ));
237 m.insert ( V::make ( 9 ));
238 m.insert ( V::make ( 9 ));
239 m.insert ( V::make ( 9 ));
240
241 R r = m.equal_range(4);
242 assert(r.first == next(m.begin(), 0));
243 assert(r.second == next(m.begin(), 0));
244 r = m.equal_range(5);
245 assert(r.first == next(m.begin(), 0));
246 assert(r.second == next(m.begin(), 3));
247 r = m.equal_range(6);
248 assert(r.first == next(m.begin(), 3));
249 assert(r.second == next(m.begin(), 3));
250 r = m.equal_range(7);
251 assert(r.first == next(m.begin(), 3));
252 assert(r.second == next(m.begin(), 6));
253 r = m.equal_range(8);
254 assert(r.first == next(m.begin(), 6));
255 assert(r.second == next(m.begin(), 6));
256 r = m.equal_range(9);
257 assert(r.first == next(m.begin(), 6));
258 assert(r.second == next(m.begin(), 9));
259 r = m.equal_range(10);
260 assert(r.first == next(m.begin(), 9));
261 assert(r.second == next(m.begin(), 9));
262 }
263 #endif
264 }
265