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 // UNSUPPORTED: c++03
10 
11 // <set>
12 
13 // class set
14 
15 // set& operator=(set&& s);
16 
17 #include <set>
18 #include <cassert>
19 
20 #include "test_macros.h"
21 #include "MoveOnly.h"
22 #include "../../../test_compare.h"
23 #include "test_allocator.h"
24 #include "min_allocator.h"
25 
main(int,char **)26 int main(int, char**)
27 {
28     {
29         typedef MoveOnly V;
30         typedef test_compare<std::less<MoveOnly> > C;
31         typedef test_allocator<V> A;
32         typedef std::set<MoveOnly, C, A> M;
33         typedef std::move_iterator<V*> I;
34         V a1[] =
35         {
36             V(1),
37             V(1),
38             V(1),
39             V(2),
40             V(2),
41             V(2),
42             V(3),
43             V(3),
44             V(3)
45         };
46         M m1(I(a1), I(a1+sizeof(a1)/sizeof(a1[0])), C(5), A(7));
47         V a2[] =
48         {
49             V(1),
50             V(1),
51             V(1),
52             V(2),
53             V(2),
54             V(2),
55             V(3),
56             V(3),
57             V(3)
58         };
59         M m2(I(a2), I(a2+sizeof(a2)/sizeof(a2[0])), C(5), A(7));
60         M m3(C(3), A(7));
61         m3 = std::move(m1);
62         assert(m3 == m2);
63         assert(m3.get_allocator() == A(7));
64         assert(m3.key_comp() == C(5));
65         assert(m1.empty());
66     }
67     {
68         typedef MoveOnly V;
69         typedef test_compare<std::less<MoveOnly> > C;
70         typedef test_allocator<V> A;
71         typedef std::set<MoveOnly, C, A> M;
72         typedef std::move_iterator<V*> I;
73         V a1[] =
74         {
75             V(1),
76             V(1),
77             V(1),
78             V(2),
79             V(2),
80             V(2),
81             V(3),
82             V(3),
83             V(3)
84         };
85         M m1(I(a1), I(a1+sizeof(a1)/sizeof(a1[0])), C(5), A(7));
86         V a2[] =
87         {
88             V(1),
89             V(1),
90             V(1),
91             V(2),
92             V(2),
93             V(2),
94             V(3),
95             V(3),
96             V(3)
97         };
98         M m2(I(a2), I(a2+sizeof(a2)/sizeof(a2[0])), C(5), A(7));
99         M m3(C(3), A(5));
100         m3 = std::move(m1);
101         assert(m3 == m2);
102         assert(m3.get_allocator() == A(5));
103         assert(m3.key_comp() == C(5));
104         LIBCPP_ASSERT(m1.empty());
105     }
106     {
107         typedef MoveOnly V;
108         typedef test_compare<std::less<MoveOnly> > C;
109         typedef other_allocator<V> A;
110         typedef std::set<MoveOnly, C, A> M;
111         typedef std::move_iterator<V*> I;
112         V a1[] =
113         {
114             V(1),
115             V(1),
116             V(1),
117             V(2),
118             V(2),
119             V(2),
120             V(3),
121             V(3),
122             V(3)
123         };
124         M m1(I(a1), I(a1+sizeof(a1)/sizeof(a1[0])), C(5), A(7));
125         V a2[] =
126         {
127             V(1),
128             V(1),
129             V(1),
130             V(2),
131             V(2),
132             V(2),
133             V(3),
134             V(3),
135             V(3)
136         };
137         M m2(I(a2), I(a2+sizeof(a2)/sizeof(a2[0])), C(5), A(7));
138         M m3(C(3), A(5));
139         m3 = std::move(m1);
140         assert(m3 == m2);
141         assert(m3.get_allocator() == A(7));
142         assert(m3.key_comp() == C(5));
143         assert(m1.empty());
144     }
145     {
146         typedef MoveOnly V;
147         typedef test_compare<std::less<MoveOnly> > C;
148         typedef min_allocator<V> A;
149         typedef std::set<MoveOnly, C, A> M;
150         typedef std::move_iterator<V*> I;
151         V a1[] =
152         {
153             V(1),
154             V(1),
155             V(1),
156             V(2),
157             V(2),
158             V(2),
159             V(3),
160             V(3),
161             V(3)
162         };
163         M m1(I(a1), I(a1+sizeof(a1)/sizeof(a1[0])), C(5), A());
164         V a2[] =
165         {
166             V(1),
167             V(1),
168             V(1),
169             V(2),
170             V(2),
171             V(2),
172             V(3),
173             V(3),
174             V(3)
175         };
176         M m2(I(a2), I(a2+sizeof(a2)/sizeof(a2[0])), C(5), A());
177         M m3(C(3), A());
178         m3 = std::move(m1);
179         assert(m3 == m2);
180         assert(m3.get_allocator() == A());
181         assert(m3.key_comp() == C(5));
182         assert(m1.empty());
183     }
184 
185   return 0;
186 }
187