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 // <map>
10 
11 // class multimap
12 
13 // size_type count(const key_type& k) const;
14 
15 #include <map>
16 #include <cassert>
17 
18 #include "test_macros.h"
19 #include "min_allocator.h"
20 #include "private_constructor.h"
21 #include "is_transparent.h"
22 
main(int,char **)23 int main(int, char**)
24 {
25     typedef std::pair<const int, double> V;
26     {
27     typedef std::multimap<int, double> M;
28     {
29         typedef M::size_type R;
30         V ar[] =
31         {
32             V(5, 1),
33             V(5, 2),
34             V(5, 3),
35             V(7, 1),
36             V(7, 2),
37             V(7, 3),
38             V(9, 1),
39             V(9, 2),
40             V(9, 3)
41         };
42         const M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
43         R r = m.count(4);
44         assert(r == 0);
45         r = m.count(5);
46         assert(r == 3);
47         r = m.count(6);
48         assert(r == 0);
49         r = m.count(7);
50         assert(r == 3);
51         r = m.count(8);
52         assert(r == 0);
53         r = m.count(9);
54         assert(r == 3);
55         r = m.count(10);
56         assert(r == 0);
57     }
58     }
59 #if TEST_STD_VER >= 11
60     {
61     typedef std::multimap<int, double, std::less<int>, min_allocator<std::pair<const int, double>>> M;
62     {
63         typedef M::size_type R;
64         V ar[] =
65         {
66             V(5, 1),
67             V(5, 2),
68             V(5, 3),
69             V(7, 1),
70             V(7, 2),
71             V(7, 3),
72             V(9, 1),
73             V(9, 2),
74             V(9, 3)
75         };
76         const M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
77         R r = m.count(4);
78         assert(r == 0);
79         r = m.count(5);
80         assert(r == 3);
81         r = m.count(6);
82         assert(r == 0);
83         r = m.count(7);
84         assert(r == 3);
85         r = m.count(8);
86         assert(r == 0);
87         r = m.count(9);
88         assert(r == 3);
89         r = m.count(10);
90         assert(r == 0);
91     }
92     }
93 #endif
94 
95 #if TEST_STD_VER > 11
96     {
97     typedef std::multimap<int, double, std::less<>> M;
98     typedef M::size_type R;
99     V ar[] =
100     {
101         V(5, 1),
102         V(5, 2),
103         V(5, 3),
104         V(7, 1),
105         V(7, 2),
106         V(7, 3),
107         V(9, 1),
108         V(9, 2),
109         V(9, 3)
110     };
111     const M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
112     R r = m.count(4);
113     assert(r == 0);
114     r = m.count(5);
115     assert(r == 3);
116     r = m.count(6);
117     assert(r == 0);
118     r = m.count(7);
119     assert(r == 3);
120     r = m.count(8);
121     assert(r == 0);
122     r = m.count(9);
123     assert(r == 3);
124     r = m.count(10);
125     assert(r == 0);
126 
127     r = m.count(C2Int(4));
128     assert(r == 0);
129     r = m.count(C2Int(5));
130     assert(r == 3);
131     r = m.count(C2Int(6));
132     assert(r == 0);
133     r = m.count(C2Int(7));
134     assert(r == 3);
135     r = m.count(C2Int(8));
136     assert(r == 0);
137     r = m.count(C2Int(9));
138     assert(r == 3);
139     r = m.count(C2Int(10));
140     assert(r == 0);
141     }
142 
143     {
144     typedef PrivateConstructor PC;
145     typedef std::multimap<PC, double, std::less<>> M;
146     typedef M::size_type R;
147 
148     M m;
149     m.insert ( std::make_pair<PC, double> ( PC::make(5), 1 ));
150     m.insert ( std::make_pair<PC, double> ( PC::make(5), 2 ));
151     m.insert ( std::make_pair<PC, double> ( PC::make(5), 3 ));
152     m.insert ( std::make_pair<PC, double> ( PC::make(7), 1 ));
153     m.insert ( std::make_pair<PC, double> ( PC::make(7), 2 ));
154     m.insert ( std::make_pair<PC, double> ( PC::make(7), 3 ));
155     m.insert ( std::make_pair<PC, double> ( PC::make(9), 1 ));
156     m.insert ( std::make_pair<PC, double> ( PC::make(9), 2 ));
157     m.insert ( std::make_pair<PC, double> ( PC::make(9), 3 ));
158 
159     R r = m.count(4);
160     assert(r == 0);
161     r = m.count(5);
162     assert(r == 3);
163     r = m.count(6);
164     assert(r == 0);
165     r = m.count(7);
166     assert(r == 3);
167     r = m.count(8);
168     assert(r == 0);
169     r = m.count(9);
170     assert(r == 3);
171     r = m.count(10);
172     assert(r == 0);
173     }
174 #endif
175 
176   return 0;
177 }
178