ac05e291067c80e0c1ac3c2645c3232a0ca9c173
[platform/framework/web/crosswalk.git] / src / third_party / libc++ / trunk / test / containers / associative / map / map.cons / copy_assign.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 // <map>
11
12 // class map
13
14 // map& operator=(const map& m);
15
16 #include <map>
17 #include <cassert>
18
19 #include "../../../test_compare.h"
20 #include "test_allocator.h"
21 #include "min_allocator.h"
22
23 int main()
24 {
25     {
26         typedef std::pair<const int, double> V;
27         V ar[] =
28         {
29             V(1, 1),
30             V(1, 1.5),
31             V(1, 2),
32             V(2, 1),
33             V(2, 1.5),
34             V(2, 2),
35             V(3, 1),
36             V(3, 1.5),
37             V(3, 2)
38         };
39         typedef test_compare<std::less<int> > C;
40         typedef test_allocator<V> A;
41         std::map<int, double, C, A> mo(ar, ar+sizeof(ar)/sizeof(ar[0]), C(5), A(2));
42         std::map<int, double, C, A> m(ar, ar+sizeof(ar)/sizeof(ar[0])/2, C(3), A(7));
43         m = mo;
44         assert(m.get_allocator() == A(7));
45         assert(m.key_comp() == C(5));
46         assert(m.size() == 3);
47         assert(distance(m.begin(), m.end()) == 3);
48         assert(*m.begin() == V(1, 1));
49         assert(*next(m.begin()) == V(2, 1));
50         assert(*next(m.begin(), 2) == V(3, 1));
51
52         assert(mo.get_allocator() == A(2));
53         assert(mo.key_comp() == C(5));
54         assert(mo.size() == 3);
55         assert(distance(mo.begin(), mo.end()) == 3);
56         assert(*mo.begin() == V(1, 1));
57         assert(*next(mo.begin()) == V(2, 1));
58         assert(*next(mo.begin(), 2) == V(3, 1));
59     }
60     {
61         typedef std::pair<const int, double> V;
62         V ar[] =
63         {
64             V(1, 1),
65             V(1, 1.5),
66             V(1, 2),
67             V(2, 1),
68             V(2, 1.5),
69             V(2, 2),
70             V(3, 1),
71             V(3, 1.5),
72             V(3, 2)
73         };
74         typedef test_compare<std::less<int> > C;
75         typedef other_allocator<V> A;
76         std::map<int, double, C, A> mo(ar, ar+sizeof(ar)/sizeof(ar[0]), C(5), A(2));
77         std::map<int, double, C, A> m(ar, ar+sizeof(ar)/sizeof(ar[0])/2, C(3), A(7));
78         m = mo;
79         assert(m.get_allocator() == A(2));
80         assert(m.key_comp() == C(5));
81         assert(m.size() == 3);
82         assert(distance(m.begin(), m.end()) == 3);
83         assert(*m.begin() == V(1, 1));
84         assert(*next(m.begin()) == V(2, 1));
85         assert(*next(m.begin(), 2) == V(3, 1));
86
87         assert(mo.get_allocator() == A(2));
88         assert(mo.key_comp() == C(5));
89         assert(mo.size() == 3);
90         assert(distance(mo.begin(), mo.end()) == 3);
91         assert(*mo.begin() == V(1, 1));
92         assert(*next(mo.begin()) == V(2, 1));
93         assert(*next(mo.begin(), 2) == V(3, 1));
94     }
95 #if __cplusplus >= 201103L
96     {
97         typedef std::pair<const int, double> V;
98         V ar[] =
99         {
100             V(1, 1),
101             V(1, 1.5),
102             V(1, 2),
103             V(2, 1),
104             V(2, 1.5),
105             V(2, 2),
106             V(3, 1),
107             V(3, 1.5),
108             V(3, 2)
109         };
110         typedef test_compare<std::less<int> > C;
111         typedef min_allocator<V> A;
112         std::map<int, double, C, A> mo(ar, ar+sizeof(ar)/sizeof(ar[0]), C(5), A());
113         std::map<int, double, C, A> m(ar, ar+sizeof(ar)/sizeof(ar[0])/2, C(3), A());
114         m = mo;
115         assert(m.get_allocator() == A());
116         assert(m.key_comp() == C(5));
117         assert(m.size() == 3);
118         assert(distance(m.begin(), m.end()) == 3);
119         assert(*m.begin() == V(1, 1));
120         assert(*next(m.begin()) == V(2, 1));
121         assert(*next(m.begin(), 2) == V(3, 1));
122
123         assert(mo.get_allocator() == A());
124         assert(mo.key_comp() == C(5));
125         assert(mo.size() == 3);
126         assert(distance(mo.begin(), mo.end()) == 3);
127         assert(*mo.begin() == V(1, 1));
128         assert(*next(mo.begin()) == V(2, 1));
129         assert(*next(mo.begin(), 2) == V(3, 1));
130     }
131     {
132         typedef std::pair<const int, double> V;
133         V ar[] =
134         {
135             V(1, 1),
136             V(1, 1.5),
137             V(1, 2),
138             V(2, 1),
139             V(2, 1.5),
140             V(2, 2),
141             V(3, 1),
142             V(3, 1.5),
143             V(3, 2)
144         };
145         typedef test_compare<std::less<int> > C;
146         typedef min_allocator<V> A;
147         std::map<int, double, C, A> mo(ar, ar+sizeof(ar)/sizeof(ar[0]), C(5), A());
148         std::map<int, double, C, A> m(ar, ar+sizeof(ar)/sizeof(ar[0])/2, C(3), A());
149         m = mo;
150         assert(m.get_allocator() == A());
151         assert(m.key_comp() == C(5));
152         assert(m.size() == 3);
153         assert(distance(m.begin(), m.end()) == 3);
154         assert(*m.begin() == V(1, 1));
155         assert(*next(m.begin()) == V(2, 1));
156         assert(*next(m.begin(), 2) == V(3, 1));
157
158         assert(mo.get_allocator() == A());
159         assert(mo.key_comp() == C(5));
160         assert(mo.size() == 3);
161         assert(distance(mo.begin(), mo.end()) == 3);
162         assert(*mo.begin() == V(1, 1));
163         assert(*next(mo.begin()) == V(2, 1));
164         assert(*next(mo.begin(), 2) == V(3, 1));
165     }
166 #endif
167 }