]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/std/containers/unord/unord.multiset/reserve.pass.cpp
Vendor import of libc++ trunk r290819:
[FreeBSD/FreeBSD.git] / test / std / containers / unord / unord.multiset / reserve.pass.cpp
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 // <unordered_set>
11
12 // template <class Value, class Hash = hash<Value>, class Pred = equal_to<Value>,
13 //           class Alloc = allocator<Value>>
14 // class unordered_multiset
15
16 // void reserve(size_type n);
17
18 #include <unordered_set>
19 #include <cassert>
20
21 #include "test_macros.h"
22 #include "min_allocator.h"
23
24 template <class C>
25 void test(const C& c)
26 {
27     assert(c.size() == 6);
28     assert(c.count(1) == 2);
29     assert(c.count(2) == 2);
30     assert(c.count(3) == 1);
31     assert(c.count(4) == 1);
32 }
33
34 void reserve_invariant(size_t n) // LWG #2156
35 {
36     for (size_t i = 0; i < n; ++i)
37     {
38         std::unordered_multiset<size_t> c;
39         c.reserve(n);
40         size_t buckets = c.bucket_count();
41         for (size_t j = 0; j < i; ++j)
42         {
43             c.insert(i);
44             assert(buckets == c.bucket_count());
45         }
46     }
47 }
48
49 int main()
50 {
51     {
52         typedef std::unordered_multiset<int> C;
53         typedef int P;
54         P a[] =
55         {
56             P(1),
57             P(2),
58             P(3),
59             P(4),
60             P(1),
61             P(2)
62         };
63         C c(a, a + sizeof(a)/sizeof(a[0]));
64         test(c);
65         assert(c.bucket_count() >= 7);
66         c.reserve(3);
67         LIBCPP_ASSERT(c.bucket_count() == 7);
68         test(c);
69         c.max_load_factor(2);
70         c.reserve(3);
71         LIBCPP_ASSERT(c.bucket_count() == 3);
72         test(c);
73         c.reserve(31);
74         assert(c.bucket_count() >= 16);
75         test(c);
76     }
77 #if TEST_STD_VER >= 11
78     {
79         typedef std::unordered_multiset<int, std::hash<int>,
80                                       std::equal_to<int>, min_allocator<int>> C;
81         typedef int P;
82         P a[] =
83         {
84             P(1),
85             P(2),
86             P(3),
87             P(4),
88             P(1),
89             P(2)
90         };
91         C c(a, a + sizeof(a)/sizeof(a[0]));
92         test(c);
93         assert(c.bucket_count() >= 7);
94         c.reserve(3);
95         LIBCPP_ASSERT(c.bucket_count() == 7);
96         test(c);
97         c.max_load_factor(2);
98         c.reserve(3);
99         LIBCPP_ASSERT(c.bucket_count() == 3);
100         test(c);
101         c.reserve(31);
102         assert(c.bucket_count() >= 16);
103         test(c);
104     }
105 #endif
106     reserve_invariant(20);
107 }