• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 // UNSUPPORTED: c++98, c++03
11 
12 // <set>
13 
14 // class multiset
15 
16 // template <class... Args>
17 //   iterator emplace(Args&&... args);
18 
19 #include <set>
20 #include <cassert>
21 
22 #include "../../Emplaceable.h"
23 #include "DefaultOnly.h"
24 #include "min_allocator.h"
25 
main()26 int main()
27 {
28     {
29         typedef std::multiset<DefaultOnly> M;
30         typedef M::iterator R;
31         M m;
32         assert(DefaultOnly::count == 0);
33         R r = m.emplace();
34         assert(r == m.begin());
35         assert(m.size() == 1);
36         assert(*m.begin() == DefaultOnly());
37         assert(DefaultOnly::count == 1);
38 
39         r = m.emplace();
40         assert(r == next(m.begin()));
41         assert(m.size() == 2);
42         assert(*m.begin() == DefaultOnly());
43         assert(DefaultOnly::count == 2);
44     }
45     assert(DefaultOnly::count == 0);
46     {
47         typedef std::multiset<Emplaceable> M;
48         typedef M::iterator R;
49         M m;
50         R r = m.emplace();
51         assert(r == m.begin());
52         assert(m.size() == 1);
53         assert(*m.begin() == Emplaceable());
54         r = m.emplace(2, 3.5);
55         assert(r == next(m.begin()));
56         assert(m.size() == 2);
57         assert(*r == Emplaceable(2, 3.5));
58         r = m.emplace(2, 3.5);
59         assert(r == next(m.begin(), 2));
60         assert(m.size() == 3);
61         assert(*r == Emplaceable(2, 3.5));
62     }
63     {
64         typedef std::multiset<int> M;
65         typedef M::iterator R;
66         M m;
67         R r = m.emplace(M::value_type(2));
68         assert(r == m.begin());
69         assert(m.size() == 1);
70         assert(*r == 2);
71     }
72     {
73         typedef std::multiset<int, std::less<int>, min_allocator<int>> M;
74         typedef M::iterator R;
75         M m;
76         R r = m.emplace(M::value_type(2));
77         assert(r == m.begin());
78         assert(m.size() == 1);
79         assert(*r == 2);
80     }
81 }
82