1 //===----------------------------------------------------------------------===//
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
7 //===----------------------------------------------------------------------===//
13 // iterator lower_bound(const key_type& k);
14 // const_iterator lower_bound(const key_type& k) const;
19 #include "test_macros.h"
20 #include "min_allocator.h"
21 #include "private_constructor.h"
22 #include "is_transparent.h"
26 typedef std::pair
<const int, double> V
;
28 typedef std::multimap
<int, double> M
;
30 typedef M::iterator R
;
43 M
m(ar
, ar
+sizeof(ar
)/sizeof(ar
[0]));
44 R r
= m
.lower_bound(4);
45 assert(r
== m
.begin());
47 assert(r
== m
.begin());
49 assert(r
== std::next(m
.begin(), 3));
51 assert(r
== std::next(m
.begin(), 3));
53 assert(r
== std::next(m
.begin(), 6));
55 assert(r
== std::next(m
.begin(), 6));
56 r
= m
.lower_bound(10);
60 typedef M::const_iterator R
;
73 const M
m(ar
, ar
+sizeof(ar
)/sizeof(ar
[0]));
74 R r
= m
.lower_bound(4);
75 assert(r
== m
.begin());
77 assert(r
== m
.begin());
79 assert(r
== std::next(m
.begin(), 3));
81 assert(r
== std::next(m
.begin(), 3));
83 assert(r
== std::next(m
.begin(), 6));
85 assert(r
== std::next(m
.begin(), 6));
86 r
= m
.lower_bound(10);
90 #if TEST_STD_VER >= 11
92 typedef std::multimap
<int, double, std::less
<int>, min_allocator
<std::pair
<const int, double>>> M
;
94 typedef M::iterator R
;
107 M
m(ar
, ar
+sizeof(ar
)/sizeof(ar
[0]));
108 R r
= m
.lower_bound(4);
109 assert(r
== m
.begin());
110 r
= m
.lower_bound(5);
111 assert(r
== m
.begin());
112 r
= m
.lower_bound(6);
113 assert(r
== std::next(m
.begin(), 3));
114 r
= m
.lower_bound(7);
115 assert(r
== std::next(m
.begin(), 3));
116 r
= m
.lower_bound(8);
117 assert(r
== std::next(m
.begin(), 6));
118 r
= m
.lower_bound(9);
119 assert(r
== std::next(m
.begin(), 6));
120 r
= m
.lower_bound(10);
121 assert(r
== m
.end());
124 typedef M::const_iterator R
;
137 const M
m(ar
, ar
+sizeof(ar
)/sizeof(ar
[0]));
138 R r
= m
.lower_bound(4);
139 assert(r
== m
.begin());
140 r
= m
.lower_bound(5);
141 assert(r
== m
.begin());
142 r
= m
.lower_bound(6);
143 assert(r
== std::next(m
.begin(), 3));
144 r
= m
.lower_bound(7);
145 assert(r
== std::next(m
.begin(), 3));
146 r
= m
.lower_bound(8);
147 assert(r
== std::next(m
.begin(), 6));
148 r
= m
.lower_bound(9);
149 assert(r
== std::next(m
.begin(), 6));
150 r
= m
.lower_bound(10);
151 assert(r
== m
.end());
155 #if TEST_STD_VER > 11
157 typedef std::multimap
<int, double, std::less
<>> M
;
158 typedef M::iterator R
;
171 M
m(ar
, ar
+sizeof(ar
)/sizeof(ar
[0]));
172 R r
= m
.lower_bound(4);
173 assert(r
== m
.begin());
174 r
= m
.lower_bound(5);
175 assert(r
== m
.begin());
176 r
= m
.lower_bound(6);
177 assert(r
== std::next(m
.begin(), 3));
178 r
= m
.lower_bound(7);
179 assert(r
== std::next(m
.begin(), 3));
180 r
= m
.lower_bound(8);
181 assert(r
== std::next(m
.begin(), 6));
182 r
= m
.lower_bound(9);
183 assert(r
== std::next(m
.begin(), 6));
184 r
= m
.lower_bound(10);
185 assert(r
== m
.end());
187 r
= m
.lower_bound(C2Int(4));
188 assert(r
== m
.begin());
189 r
= m
.lower_bound(C2Int(5));
190 assert(r
== m
.begin());
191 r
= m
.lower_bound(C2Int(6));
192 assert(r
== std::next(m
.begin(), 3));
193 r
= m
.lower_bound(C2Int(7));
194 assert(r
== std::next(m
.begin(), 3));
195 r
= m
.lower_bound(C2Int(8));
196 assert(r
== std::next(m
.begin(), 6));
197 r
= m
.lower_bound(C2Int(9));
198 assert(r
== std::next(m
.begin(), 6));
199 r
= m
.lower_bound(C2Int(10));
200 assert(r
== m
.end());
204 typedef PrivateConstructor PC
;
205 typedef std::multimap
<PC
, double, std::less
<>> M
;
206 typedef M::iterator R
;
209 m
.insert ( std::make_pair
<PC
, double> ( PC::make(5), 1 ));
210 m
.insert ( std::make_pair
<PC
, double> ( PC::make(5), 2 ));
211 m
.insert ( std::make_pair
<PC
, double> ( PC::make(5), 3 ));
212 m
.insert ( std::make_pair
<PC
, double> ( PC::make(7), 1 ));
213 m
.insert ( std::make_pair
<PC
, double> ( PC::make(7), 2 ));
214 m
.insert ( std::make_pair
<PC
, double> ( PC::make(7), 3 ));
215 m
.insert ( std::make_pair
<PC
, double> ( PC::make(9), 1 ));
216 m
.insert ( std::make_pair
<PC
, double> ( PC::make(9), 2 ));
217 m
.insert ( std::make_pair
<PC
, double> ( PC::make(9), 3 ));
219 R r
= m
.lower_bound(4);
220 assert(r
== m
.begin());
221 r
= m
.lower_bound(5);
222 assert(r
== m
.begin());
223 r
= m
.lower_bound(6);
224 assert(r
== std::next(m
.begin(), 3));
225 r
= m
.lower_bound(7);
226 assert(r
== std::next(m
.begin(), 3));
227 r
= m
.lower_bound(8);
228 assert(r
== std::next(m
.begin(), 6));
229 r
= m
.lower_bound(9);
230 assert(r
== std::next(m
.begin(), 6));
231 r
= m
.lower_bound(10);
232 assert(r
== m
.end());