sl@0
|
1 |
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
|
sl@0
|
2 |
// All rights reserved.
|
sl@0
|
3 |
// This component and the accompanying materials are made available
|
sl@0
|
4 |
// under the terms of "Eclipse Public License v1.0"
|
sl@0
|
5 |
// which accompanies this distribution, and is available
|
sl@0
|
6 |
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
|
sl@0
|
7 |
//
|
sl@0
|
8 |
// Initial Contributors:
|
sl@0
|
9 |
// Nokia Corporation - initial contribution.
|
sl@0
|
10 |
//
|
sl@0
|
11 |
// Contributors:
|
sl@0
|
12 |
//
|
sl@0
|
13 |
// Description:
|
sl@0
|
14 |
//
|
sl@0
|
15 |
|
sl@0
|
16 |
//Has to be first for StackAllocator swap overload to be taken
|
sl@0
|
17 |
//into account (at least using GCC 4.0.1)
|
sl@0
|
18 |
#include "stack_allocator.h"
|
sl@0
|
19 |
#include <e32std.h>
|
sl@0
|
20 |
|
sl@0
|
21 |
#include <vector>
|
sl@0
|
22 |
#include <algorithm>
|
sl@0
|
23 |
#if !defined (STLPORT) || defined (_STLP_USE_EXCEPTIONS)
|
sl@0
|
24 |
# include <stdexcept>
|
sl@0
|
25 |
#endif
|
sl@0
|
26 |
|
sl@0
|
27 |
#include "cppunit/cppunit_proxy.h"
|
sl@0
|
28 |
|
sl@0
|
29 |
#if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES)
|
sl@0
|
30 |
using namespace std;
|
sl@0
|
31 |
#endif
|
sl@0
|
32 |
|
sl@0
|
33 |
//
|
sl@0
|
34 |
// TestCase class
|
sl@0
|
35 |
//
|
sl@0
|
36 |
class VectorTest : public CPPUNIT_NS::TestCase
|
sl@0
|
37 |
{
|
sl@0
|
38 |
CPPUNIT_TEST_SUITE(VectorTest);
|
sl@0
|
39 |
CPPUNIT_TEST(vec_test_1);
|
sl@0
|
40 |
CPPUNIT_TEST(vec_test_2);
|
sl@0
|
41 |
CPPUNIT_TEST(vec_test_3);
|
sl@0
|
42 |
CPPUNIT_TEST(vec_test_4);
|
sl@0
|
43 |
CPPUNIT_TEST(vec_test_5);
|
sl@0
|
44 |
CPPUNIT_TEST(vec_test_6);
|
sl@0
|
45 |
CPPUNIT_TEST(vec_test_7);
|
sl@0
|
46 |
CPPUNIT_TEST(capacity);
|
sl@0
|
47 |
CPPUNIT_TEST(at);
|
sl@0
|
48 |
CPPUNIT_TEST(pointer);
|
sl@0
|
49 |
CPPUNIT_TEST(auto_ref);
|
sl@0
|
50 |
CPPUNIT_TEST(allocator_with_state);
|
sl@0
|
51 |
CPPUNIT_TEST(iterators);
|
sl@0
|
52 |
#if defined (STLPORT) && defined (_STLP_NO_MEMBER_TEMPLATES)
|
sl@0
|
53 |
CPPUNIT_IGNORE;
|
sl@0
|
54 |
#endif
|
sl@0
|
55 |
CPPUNIT_TEST(optimizations_check);
|
sl@0
|
56 |
CPPUNIT_STOP_IGNORE;
|
sl@0
|
57 |
CPPUNIT_TEST(ebo);
|
sl@0
|
58 |
CPPUNIT_TEST(vec_cov1);
|
sl@0
|
59 |
CPPUNIT_TEST(vec_cov2);
|
sl@0
|
60 |
CPPUNIT_TEST(vec_cov3);
|
sl@0
|
61 |
CPPUNIT_TEST(vec_cov4);
|
sl@0
|
62 |
CPPUNIT_TEST_SUITE_END();
|
sl@0
|
63 |
|
sl@0
|
64 |
protected:
|
sl@0
|
65 |
void vec_test_1();
|
sl@0
|
66 |
void vec_test_2();
|
sl@0
|
67 |
void vec_test_3();
|
sl@0
|
68 |
void vec_test_4();
|
sl@0
|
69 |
void vec_test_5();
|
sl@0
|
70 |
void vec_test_6();
|
sl@0
|
71 |
void vec_test_7();
|
sl@0
|
72 |
void capacity();
|
sl@0
|
73 |
void at();
|
sl@0
|
74 |
void pointer();
|
sl@0
|
75 |
void auto_ref();
|
sl@0
|
76 |
void allocator_with_state();
|
sl@0
|
77 |
void iterators();
|
sl@0
|
78 |
void optimizations_check();
|
sl@0
|
79 |
void ebo();
|
sl@0
|
80 |
void vec_cov1();
|
sl@0
|
81 |
void vec_cov2();
|
sl@0
|
82 |
void vec_cov3();
|
sl@0
|
83 |
void vec_cov4();
|
sl@0
|
84 |
};
|
sl@0
|
85 |
|
sl@0
|
86 |
CPPUNIT_TEST_SUITE_REGISTRATION(VectorTest);
|
sl@0
|
87 |
|
sl@0
|
88 |
//
|
sl@0
|
89 |
// tests implementation
|
sl@0
|
90 |
//
|
sl@0
|
91 |
void VectorTest::vec_test_1()
|
sl@0
|
92 |
{
|
sl@0
|
93 |
vector<int> v1; // Empty vector of integers.
|
sl@0
|
94 |
|
sl@0
|
95 |
CPPUNIT_ASSERT( v1.empty() == true );
|
sl@0
|
96 |
CPPUNIT_ASSERT( v1.size() == 0 );
|
sl@0
|
97 |
|
sl@0
|
98 |
// CPPUNIT_ASSERT( v1.max_size() == INT_MAX / sizeof(int) );
|
sl@0
|
99 |
// cout << "max_size = " << v1.max_size() << endl;
|
sl@0
|
100 |
v1.push_back(42); // Add an integer to the vector.
|
sl@0
|
101 |
|
sl@0
|
102 |
CPPUNIT_ASSERT( v1.size() == 1 );
|
sl@0
|
103 |
|
sl@0
|
104 |
CPPUNIT_ASSERT( v1[0] == 42 );
|
sl@0
|
105 |
|
sl@0
|
106 |
{
|
sl@0
|
107 |
vector<vector<int> > vect(10);
|
sl@0
|
108 |
vector<vector<int> >::iterator it(vect.begin()), end(vect.end());
|
sl@0
|
109 |
for (; it != end; ++it) {
|
sl@0
|
110 |
CPPUNIT_ASSERT( (*it).empty() );
|
sl@0
|
111 |
CPPUNIT_ASSERT( (*it).size() == 0 );
|
sl@0
|
112 |
CPPUNIT_ASSERT( (*it).capacity() == 0 );
|
sl@0
|
113 |
CPPUNIT_ASSERT( (*it).begin() == (*it).end() );
|
sl@0
|
114 |
}
|
sl@0
|
115 |
}
|
sl@0
|
116 |
}
|
sl@0
|
117 |
|
sl@0
|
118 |
void VectorTest::vec_test_2()
|
sl@0
|
119 |
{
|
sl@0
|
120 |
vector<double> v1; // Empty vector of doubles.
|
sl@0
|
121 |
v1.push_back(32.1);
|
sl@0
|
122 |
v1.push_back(40.5);
|
sl@0
|
123 |
vector<double> v2; // Another empty vector of doubles.
|
sl@0
|
124 |
v2.push_back(3.56);
|
sl@0
|
125 |
|
sl@0
|
126 |
CPPUNIT_ASSERT( v1.size() == 2 );
|
sl@0
|
127 |
CPPUNIT_ASSERT( v1[0] == 32.1 );
|
sl@0
|
128 |
CPPUNIT_ASSERT( v1[1] == 40.5 );
|
sl@0
|
129 |
|
sl@0
|
130 |
CPPUNIT_ASSERT( v2.size() == 1 );
|
sl@0
|
131 |
CPPUNIT_ASSERT( v2[0] == 3.56 );
|
sl@0
|
132 |
v1.swap(v2); // Swap the vector's contents.
|
sl@0
|
133 |
|
sl@0
|
134 |
CPPUNIT_ASSERT( v1.size() == 1 );
|
sl@0
|
135 |
CPPUNIT_ASSERT( v1[0] == 3.56 );
|
sl@0
|
136 |
|
sl@0
|
137 |
CPPUNIT_ASSERT( v2.size() == 2 );
|
sl@0
|
138 |
CPPUNIT_ASSERT( v2[0] == 32.1 );
|
sl@0
|
139 |
CPPUNIT_ASSERT( v2[1] == 40.5 );
|
sl@0
|
140 |
|
sl@0
|
141 |
v2 = v1; // Assign one vector to another.
|
sl@0
|
142 |
|
sl@0
|
143 |
CPPUNIT_ASSERT( v2.size() == 1 );
|
sl@0
|
144 |
CPPUNIT_ASSERT( v2[0] == 3.56 );
|
sl@0
|
145 |
}
|
sl@0
|
146 |
|
sl@0
|
147 |
void VectorTest::vec_test_3()
|
sl@0
|
148 |
{
|
sl@0
|
149 |
typedef vector<char> vec_type;
|
sl@0
|
150 |
|
sl@0
|
151 |
vec_type v1; // Empty vector of characters.
|
sl@0
|
152 |
v1.push_back('h');
|
sl@0
|
153 |
v1.push_back('i');
|
sl@0
|
154 |
|
sl@0
|
155 |
CPPUNIT_ASSERT( v1.size() == 2 );
|
sl@0
|
156 |
CPPUNIT_ASSERT( v1[0] == 'h' );
|
sl@0
|
157 |
CPPUNIT_ASSERT( v1[1] == 'i' );
|
sl@0
|
158 |
|
sl@0
|
159 |
vec_type v2(v1.begin(), v1.end());
|
sl@0
|
160 |
v2[1] = 'o'; // Replace second character.
|
sl@0
|
161 |
|
sl@0
|
162 |
CPPUNIT_ASSERT( v2.size() == 2 );
|
sl@0
|
163 |
CPPUNIT_ASSERT( v2[0] == 'h' );
|
sl@0
|
164 |
CPPUNIT_ASSERT( v2[1] == 'o' );
|
sl@0
|
165 |
|
sl@0
|
166 |
CPPUNIT_ASSERT( (v1 == v2) == false );
|
sl@0
|
167 |
|
sl@0
|
168 |
CPPUNIT_ASSERT( (v1 < v2) == true );
|
sl@0
|
169 |
}
|
sl@0
|
170 |
|
sl@0
|
171 |
void VectorTest::vec_test_4()
|
sl@0
|
172 |
{
|
sl@0
|
173 |
vector<int> v(4);
|
sl@0
|
174 |
|
sl@0
|
175 |
v[0] = 1;
|
sl@0
|
176 |
v[1] = 4;
|
sl@0
|
177 |
v[2] = 9;
|
sl@0
|
178 |
v[3] = 16;
|
sl@0
|
179 |
|
sl@0
|
180 |
CPPUNIT_ASSERT( v.front() == 1 );
|
sl@0
|
181 |
CPPUNIT_ASSERT( v.back() == 16 );
|
sl@0
|
182 |
|
sl@0
|
183 |
v.push_back(25);
|
sl@0
|
184 |
|
sl@0
|
185 |
CPPUNIT_ASSERT( v.back() == 25 );
|
sl@0
|
186 |
CPPUNIT_ASSERT( v.size() == 5 );
|
sl@0
|
187 |
|
sl@0
|
188 |
v.pop_back();
|
sl@0
|
189 |
|
sl@0
|
190 |
CPPUNIT_ASSERT( v.back() == 16 );
|
sl@0
|
191 |
CPPUNIT_ASSERT( v.size() == 4 );
|
sl@0
|
192 |
}
|
sl@0
|
193 |
|
sl@0
|
194 |
void VectorTest::vec_test_5()
|
sl@0
|
195 |
{
|
sl@0
|
196 |
int array [] = { 1, 4, 9, 16 };
|
sl@0
|
197 |
|
sl@0
|
198 |
vector<int> v(array, array + 4);
|
sl@0
|
199 |
|
sl@0
|
200 |
CPPUNIT_ASSERT( v.size() == 4 );
|
sl@0
|
201 |
|
sl@0
|
202 |
CPPUNIT_ASSERT( v[0] == 1 );
|
sl@0
|
203 |
CPPUNIT_ASSERT( v[1] == 4 );
|
sl@0
|
204 |
CPPUNIT_ASSERT( v[2] == 9 );
|
sl@0
|
205 |
CPPUNIT_ASSERT( v[3] == 16 );
|
sl@0
|
206 |
}
|
sl@0
|
207 |
|
sl@0
|
208 |
void VectorTest::vec_test_6()
|
sl@0
|
209 |
{
|
sl@0
|
210 |
int array [] = { 1, 4, 9, 16, 25, 36 };
|
sl@0
|
211 |
|
sl@0
|
212 |
vector<int> v(array, array + 6);
|
sl@0
|
213 |
vector<int>::iterator vit;
|
sl@0
|
214 |
|
sl@0
|
215 |
CPPUNIT_ASSERT( v.size() == 6 );
|
sl@0
|
216 |
CPPUNIT_ASSERT( v[0] == 1 );
|
sl@0
|
217 |
CPPUNIT_ASSERT( v[1] == 4 );
|
sl@0
|
218 |
CPPUNIT_ASSERT( v[2] == 9 );
|
sl@0
|
219 |
CPPUNIT_ASSERT( v[3] == 16 );
|
sl@0
|
220 |
CPPUNIT_ASSERT( v[4] == 25 );
|
sl@0
|
221 |
CPPUNIT_ASSERT( v[5] == 36 );
|
sl@0
|
222 |
|
sl@0
|
223 |
vit = v.erase( v.begin() ); // Erase first element.
|
sl@0
|
224 |
CPPUNIT_ASSERT( *vit == 4 );
|
sl@0
|
225 |
|
sl@0
|
226 |
CPPUNIT_ASSERT( v.size() == 5 );
|
sl@0
|
227 |
CPPUNIT_ASSERT( v[0] == 4 );
|
sl@0
|
228 |
CPPUNIT_ASSERT( v[1] == 9 );
|
sl@0
|
229 |
CPPUNIT_ASSERT( v[2] == 16 );
|
sl@0
|
230 |
CPPUNIT_ASSERT( v[3] == 25 );
|
sl@0
|
231 |
CPPUNIT_ASSERT( v[4] == 36 );
|
sl@0
|
232 |
|
sl@0
|
233 |
vit = v.erase(v.end() - 1); // Erase last element.
|
sl@0
|
234 |
CPPUNIT_ASSERT( vit == v.end() );
|
sl@0
|
235 |
|
sl@0
|
236 |
CPPUNIT_ASSERT( v.size() == 4 );
|
sl@0
|
237 |
CPPUNIT_ASSERT( v[0] == 4 );
|
sl@0
|
238 |
CPPUNIT_ASSERT( v[1] == 9 );
|
sl@0
|
239 |
CPPUNIT_ASSERT( v[2] == 16 );
|
sl@0
|
240 |
CPPUNIT_ASSERT( v[3] == 25 );
|
sl@0
|
241 |
|
sl@0
|
242 |
|
sl@0
|
243 |
v.erase(v.begin() + 1, v.end() - 1); // Erase all but first and last.
|
sl@0
|
244 |
|
sl@0
|
245 |
CPPUNIT_ASSERT( v.size() == 2 );
|
sl@0
|
246 |
CPPUNIT_ASSERT( v[0] == 4 );
|
sl@0
|
247 |
CPPUNIT_ASSERT( v[1] == 25 );
|
sl@0
|
248 |
|
sl@0
|
249 |
}
|
sl@0
|
250 |
|
sl@0
|
251 |
void VectorTest::vec_test_7()
|
sl@0
|
252 |
{
|
sl@0
|
253 |
int array1 [] = { 1, 4, 25 };
|
sl@0
|
254 |
int array2 [] = { 9, 16 };
|
sl@0
|
255 |
|
sl@0
|
256 |
vector<int> v(array1, array1 + 3);
|
sl@0
|
257 |
vector<int>::iterator vit;
|
sl@0
|
258 |
vit = v.insert(v.begin(), 0); // Insert before first element.
|
sl@0
|
259 |
CPPUNIT_ASSERT( *vit == 0 );
|
sl@0
|
260 |
|
sl@0
|
261 |
vit = v.insert(v.end(), 36); // Insert after last element.
|
sl@0
|
262 |
CPPUNIT_ASSERT( *vit == 36 );
|
sl@0
|
263 |
|
sl@0
|
264 |
CPPUNIT_ASSERT( v.size() == 5 );
|
sl@0
|
265 |
CPPUNIT_ASSERT( v[0] == 0 );
|
sl@0
|
266 |
CPPUNIT_ASSERT( v[1] == 1 );
|
sl@0
|
267 |
CPPUNIT_ASSERT( v[2] == 4 );
|
sl@0
|
268 |
CPPUNIT_ASSERT( v[3] == 25 );
|
sl@0
|
269 |
CPPUNIT_ASSERT( v[4] == 36 );
|
sl@0
|
270 |
|
sl@0
|
271 |
// Insert contents of array2 before fourth element.
|
sl@0
|
272 |
v.insert(v.begin() + 3, array2, array2 + 2);
|
sl@0
|
273 |
|
sl@0
|
274 |
CPPUNIT_ASSERT( v.size() == 7 );
|
sl@0
|
275 |
|
sl@0
|
276 |
CPPUNIT_ASSERT( v[0] == 0 );
|
sl@0
|
277 |
CPPUNIT_ASSERT( v[1] == 1 );
|
sl@0
|
278 |
CPPUNIT_ASSERT( v[2] == 4 );
|
sl@0
|
279 |
CPPUNIT_ASSERT( v[3] == 9 );
|
sl@0
|
280 |
CPPUNIT_ASSERT( v[4] == 16 );
|
sl@0
|
281 |
CPPUNIT_ASSERT( v[5] == 25 );
|
sl@0
|
282 |
CPPUNIT_ASSERT( v[6] == 36 );
|
sl@0
|
283 |
|
sl@0
|
284 |
v.clear();
|
sl@0
|
285 |
CPPUNIT_ASSERT( v.empty() );
|
sl@0
|
286 |
|
sl@0
|
287 |
v.insert(v.begin(), 5, 10);
|
sl@0
|
288 |
CPPUNIT_ASSERT( v.size() == 5 );
|
sl@0
|
289 |
CPPUNIT_ASSERT( v[0] == 10 );
|
sl@0
|
290 |
CPPUNIT_ASSERT( v[1] == 10 );
|
sl@0
|
291 |
CPPUNIT_ASSERT( v[2] == 10 );
|
sl@0
|
292 |
CPPUNIT_ASSERT( v[3] == 10 );
|
sl@0
|
293 |
CPPUNIT_ASSERT( v[4] == 10 );
|
sl@0
|
294 |
|
sl@0
|
295 |
/*
|
sl@0
|
296 |
{
|
sl@0
|
297 |
vector<float> vf(2.0f, 3.0f);
|
sl@0
|
298 |
CPPUNIT_ASSERT( vf.size() == 2 );
|
sl@0
|
299 |
CPPUNIT_ASSERT( vf.front() == 3.0f );
|
sl@0
|
300 |
CPPUNIT_ASSERT( vf.back() == 3.0f );
|
sl@0
|
301 |
}
|
sl@0
|
302 |
*/
|
sl@0
|
303 |
}
|
sl@0
|
304 |
|
sl@0
|
305 |
struct TestStruct
|
sl@0
|
306 |
{
|
sl@0
|
307 |
unsigned int a[3];
|
sl@0
|
308 |
};
|
sl@0
|
309 |
|
sl@0
|
310 |
void VectorTest::capacity()
|
sl@0
|
311 |
{
|
sl@0
|
312 |
{
|
sl@0
|
313 |
vector<int> v;
|
sl@0
|
314 |
|
sl@0
|
315 |
CPPUNIT_ASSERT( v.capacity() == 0 );
|
sl@0
|
316 |
v.push_back(42);
|
sl@0
|
317 |
CPPUNIT_ASSERT( v.capacity() >= 1 );
|
sl@0
|
318 |
v.reserve(5000);
|
sl@0
|
319 |
CPPUNIT_ASSERT( v.capacity() >= 5000 );
|
sl@0
|
320 |
}
|
sl@0
|
321 |
|
sl@0
|
322 |
{
|
sl@0
|
323 |
//Test that used to generate an assertion when using __debug_alloc.
|
sl@0
|
324 |
vector<TestStruct> va;
|
sl@0
|
325 |
va.reserve(1);
|
sl@0
|
326 |
va.reserve(2);
|
sl@0
|
327 |
}
|
sl@0
|
328 |
}
|
sl@0
|
329 |
|
sl@0
|
330 |
void VectorTest::at() {
|
sl@0
|
331 |
vector<int> v;
|
sl@0
|
332 |
vector<int> const& cv = v;
|
sl@0
|
333 |
|
sl@0
|
334 |
v.push_back(10);
|
sl@0
|
335 |
CPPUNIT_ASSERT( v.at(0) == 10 );
|
sl@0
|
336 |
v.at(0) = 20;
|
sl@0
|
337 |
CPPUNIT_ASSERT( cv.at(0) == 20 );
|
sl@0
|
338 |
|
sl@0
|
339 |
#if !defined (STLPORT) || defined (_STLP_USE_EXCEPTIONS)
|
sl@0
|
340 |
for (;;) {
|
sl@0
|
341 |
try {
|
sl@0
|
342 |
v.at(1) = 20;
|
sl@0
|
343 |
CPPUNIT_ASSERT(false);
|
sl@0
|
344 |
}
|
sl@0
|
345 |
catch (out_of_range const&) {
|
sl@0
|
346 |
return;
|
sl@0
|
347 |
}
|
sl@0
|
348 |
catch (...) {
|
sl@0
|
349 |
CPPUNIT_ASSERT(false);
|
sl@0
|
350 |
}
|
sl@0
|
351 |
}
|
sl@0
|
352 |
#endif
|
sl@0
|
353 |
}
|
sl@0
|
354 |
|
sl@0
|
355 |
void VectorTest::pointer()
|
sl@0
|
356 |
{
|
sl@0
|
357 |
vector<int *> v1;
|
sl@0
|
358 |
vector<int *> v2 = v1;
|
sl@0
|
359 |
vector<int *> v3;
|
sl@0
|
360 |
|
sl@0
|
361 |
v3.insert( v3.end(), v1.begin(), v1.end() );
|
sl@0
|
362 |
}
|
sl@0
|
363 |
|
sl@0
|
364 |
void VectorTest::auto_ref()
|
sl@0
|
365 |
{
|
sl@0
|
366 |
vector<int> ref;
|
sl@0
|
367 |
for (int i = 0; i < 5; ++i) {
|
sl@0
|
368 |
ref.push_back(i);
|
sl@0
|
369 |
}
|
sl@0
|
370 |
|
sl@0
|
371 |
vector<vector<int> > v_v_int(1, ref);
|
sl@0
|
372 |
v_v_int.push_back(v_v_int[0]);
|
sl@0
|
373 |
v_v_int.push_back(ref);
|
sl@0
|
374 |
v_v_int.push_back(v_v_int[0]);
|
sl@0
|
375 |
v_v_int.push_back(v_v_int[0]);
|
sl@0
|
376 |
v_v_int.push_back(ref);
|
sl@0
|
377 |
|
sl@0
|
378 |
vector<vector<int> >::iterator vvit(v_v_int.begin()), vvitEnd(v_v_int.end());
|
sl@0
|
379 |
for (; vvit != vvitEnd; ++vvit) {
|
sl@0
|
380 |
CPPUNIT_ASSERT( *vvit == ref );
|
sl@0
|
381 |
}
|
sl@0
|
382 |
|
sl@0
|
383 |
/*
|
sl@0
|
384 |
* Forbidden by the Standard:
|
sl@0
|
385 |
v_v_int.insert(v_v_int.end(), v_v_int.begin(), v_v_int.end());
|
sl@0
|
386 |
for (vvit = v_v_int.begin(), vvitEnd = v_v_int.end();
|
sl@0
|
387 |
vvit != vvitEnd; ++vvit) {
|
sl@0
|
388 |
CPPUNIT_ASSERT( *vvit == ref );
|
sl@0
|
389 |
}
|
sl@0
|
390 |
*/
|
sl@0
|
391 |
}
|
sl@0
|
392 |
|
sl@0
|
393 |
void VectorTest::allocator_with_state()
|
sl@0
|
394 |
{
|
sl@0
|
395 |
char buf1[1024];
|
sl@0
|
396 |
StackAllocator<int> stack1(buf1, buf1 + sizeof(buf1));
|
sl@0
|
397 |
|
sl@0
|
398 |
char buf2[1024];
|
sl@0
|
399 |
StackAllocator<int> stack2(buf2, buf2 + sizeof(buf2));
|
sl@0
|
400 |
|
sl@0
|
401 |
{
|
sl@0
|
402 |
typedef vector<int, StackAllocator<int> > VectorInt;
|
sl@0
|
403 |
VectorInt vint1(10, 0, stack1);
|
sl@0
|
404 |
VectorInt vint1Cpy(vint1);
|
sl@0
|
405 |
|
sl@0
|
406 |
VectorInt vint2(10, 1, stack2);
|
sl@0
|
407 |
VectorInt vint2Cpy(vint2);
|
sl@0
|
408 |
|
sl@0
|
409 |
vint1.swap(vint2);
|
sl@0
|
410 |
|
sl@0
|
411 |
CPPUNIT_ASSERT( vint1.get_allocator().swaped() );
|
sl@0
|
412 |
CPPUNIT_ASSERT( vint2.get_allocator().swaped() );
|
sl@0
|
413 |
|
sl@0
|
414 |
CPPUNIT_ASSERT( vint1 == vint2Cpy );
|
sl@0
|
415 |
CPPUNIT_ASSERT( vint2 == vint1Cpy );
|
sl@0
|
416 |
CPPUNIT_ASSERT( vint1.get_allocator() == stack2 );
|
sl@0
|
417 |
CPPUNIT_ASSERT( vint2.get_allocator() == stack1 );
|
sl@0
|
418 |
}
|
sl@0
|
419 |
CPPUNIT_ASSERT( stack1.ok() );
|
sl@0
|
420 |
CPPUNIT_ASSERT( stack2.ok() );
|
sl@0
|
421 |
}
|
sl@0
|
422 |
|
sl@0
|
423 |
struct Point {
|
sl@0
|
424 |
int x, y;
|
sl@0
|
425 |
};
|
sl@0
|
426 |
|
sl@0
|
427 |
struct PointEx : public Point {
|
sl@0
|
428 |
PointEx() : builtFromBase(false) {}
|
sl@0
|
429 |
PointEx(const Point&) : builtFromBase(true) {}
|
sl@0
|
430 |
|
sl@0
|
431 |
bool builtFromBase;
|
sl@0
|
432 |
};
|
sl@0
|
433 |
|
sl@0
|
434 |
#if defined (STLPORT)
|
sl@0
|
435 |
namespace std {
|
sl@0
|
436 |
template <>
|
sl@0
|
437 |
struct __type_traits<PointEx> {
|
sl@0
|
438 |
typedef __false_type has_trivial_default_constructor;
|
sl@0
|
439 |
typedef __true_type has_trivial_copy_constructor;
|
sl@0
|
440 |
typedef __true_type has_trivial_assignment_operator;
|
sl@0
|
441 |
typedef __true_type has_trivial_destructor;
|
sl@0
|
442 |
typedef __true_type is_POD_type;
|
sl@0
|
443 |
};
|
sl@0
|
444 |
}
|
sl@0
|
445 |
#endif
|
sl@0
|
446 |
|
sl@0
|
447 |
//This test check that vector implementation do not over optimize
|
sl@0
|
448 |
//operation as PointEx copy constructor is trivial
|
sl@0
|
449 |
void VectorTest::optimizations_check()
|
sl@0
|
450 |
{
|
sl@0
|
451 |
#if !defined (STLPORT) || !defined (_STLP_NO_MEMBER_TEMPLATES)
|
sl@0
|
452 |
vector<Point> v1(1);
|
sl@0
|
453 |
CPPUNIT_ASSERT( v1.size() == 1 );
|
sl@0
|
454 |
|
sl@0
|
455 |
vector<PointEx> v2(v1.begin(), v1.end());
|
sl@0
|
456 |
CPPUNIT_ASSERT( v2.size() == 1 );
|
sl@0
|
457 |
CPPUNIT_ASSERT( v2[0].builtFromBase == true );
|
sl@0
|
458 |
#endif
|
sl@0
|
459 |
}
|
sl@0
|
460 |
|
sl@0
|
461 |
void VectorTest::iterators()
|
sl@0
|
462 |
{
|
sl@0
|
463 |
vector<int> vint(10, 0);
|
sl@0
|
464 |
vector<int> const& crvint = vint;
|
sl@0
|
465 |
|
sl@0
|
466 |
CPPUNIT_ASSERT( vint.begin() == vint.begin() );
|
sl@0
|
467 |
CPPUNIT_ASSERT( crvint.begin() == vint.begin() );
|
sl@0
|
468 |
CPPUNIT_ASSERT( vint.begin() == crvint.begin() );
|
sl@0
|
469 |
CPPUNIT_ASSERT( crvint.begin() == crvint.begin() );
|
sl@0
|
470 |
|
sl@0
|
471 |
CPPUNIT_ASSERT( vint.begin() != vint.end() );
|
sl@0
|
472 |
CPPUNIT_ASSERT( crvint.begin() != vint.end() );
|
sl@0
|
473 |
CPPUNIT_ASSERT( vint.begin() != crvint.end() );
|
sl@0
|
474 |
CPPUNIT_ASSERT( crvint.begin() != crvint.end() );
|
sl@0
|
475 |
|
sl@0
|
476 |
CPPUNIT_ASSERT( vint.rbegin() == vint.rbegin() );
|
sl@0
|
477 |
// Not Standard:
|
sl@0
|
478 |
//CPPUNIT_ASSERT( vint.rbegin() == crvint.rbegin() );
|
sl@0
|
479 |
//CPPUNIT_ASSERT( crvint.rbegin() == vint.rbegin() );
|
sl@0
|
480 |
CPPUNIT_ASSERT( crvint.rbegin() == crvint.rbegin() );
|
sl@0
|
481 |
|
sl@0
|
482 |
CPPUNIT_ASSERT( vint.rbegin() != vint.rend() );
|
sl@0
|
483 |
// Not Standard:
|
sl@0
|
484 |
//CPPUNIT_ASSERT( vint.rbegin() != crvint.rend() );
|
sl@0
|
485 |
//CPPUNIT_ASSERT( crvint.rbegin() != vint.rend() );
|
sl@0
|
486 |
CPPUNIT_ASSERT( crvint.rbegin() != crvint.rend() );
|
sl@0
|
487 |
}
|
sl@0
|
488 |
|
sl@0
|
489 |
#if defined (STLPORT)
|
sl@0
|
490 |
# define NOTHROW _STLP_NOTHROW
|
sl@0
|
491 |
#else
|
sl@0
|
492 |
# define NOTHROW throw()
|
sl@0
|
493 |
#endif
|
sl@0
|
494 |
|
sl@0
|
495 |
/* This allocator implementation purpose is simply to break some
|
sl@0
|
496 |
* internal STLport mecanism specific to the STLport own allocator
|
sl@0
|
497 |
* implementation. */
|
sl@0
|
498 |
template <class _Tp>
|
sl@0
|
499 |
struct NotSTLportAllocator : public allocator<_Tp> {
|
sl@0
|
500 |
#if !defined (STLPORT) || defined (_STLP_MEMBER_TEMPLATE_CLASSES)
|
sl@0
|
501 |
template <class _Tp1> struct rebind {
|
sl@0
|
502 |
typedef NotSTLportAllocator<_Tp1> other;
|
sl@0
|
503 |
};
|
sl@0
|
504 |
#endif
|
sl@0
|
505 |
NotSTLportAllocator() _STLP_NOTHROW {}
|
sl@0
|
506 |
#if !defined (STLPORT) || defined (_STLP_MEMBER_TEMPLATES)
|
sl@0
|
507 |
template <class _Tp1> NotSTLportAllocator(const NotSTLportAllocator<_Tp1>&) NOTHROW {}
|
sl@0
|
508 |
#endif
|
sl@0
|
509 |
NotSTLportAllocator(const NotSTLportAllocator<_Tp>&) NOTHROW {}
|
sl@0
|
510 |
~NotSTLportAllocator() NOTHROW {}
|
sl@0
|
511 |
};
|
sl@0
|
512 |
|
sl@0
|
513 |
/* This test check a potential issue with empty base class
|
sl@0
|
514 |
* optimization. Some compilers (VC6) do not implement it
|
sl@0
|
515 |
* correctly resulting ina wrong behavior. */
|
sl@0
|
516 |
void VectorTest::ebo()
|
sl@0
|
517 |
{
|
sl@0
|
518 |
// We use heap memory as test failure can corrupt vector internal
|
sl@0
|
519 |
// representation making executable crash on vector destructor invocation.
|
sl@0
|
520 |
// We prefer a simple memory leak, internal corruption should be reveal
|
sl@0
|
521 |
// by size or capacity checks.
|
sl@0
|
522 |
typedef vector<int, NotSTLportAllocator<int> > V;
|
sl@0
|
523 |
V *pv1 = new V(1, 1);
|
sl@0
|
524 |
V *pv2 = new V(10, 2);
|
sl@0
|
525 |
|
sl@0
|
526 |
size_t v1Capacity = pv1->capacity();
|
sl@0
|
527 |
size_t v2Capacity = pv2->capacity();
|
sl@0
|
528 |
|
sl@0
|
529 |
pv1->swap(*pv2);
|
sl@0
|
530 |
|
sl@0
|
531 |
CPPUNIT_ASSERT( pv1->size() == 10 );
|
sl@0
|
532 |
CPPUNIT_ASSERT( pv1->capacity() == v2Capacity );
|
sl@0
|
533 |
CPPUNIT_ASSERT( (*pv1)[5] == 2 );
|
sl@0
|
534 |
|
sl@0
|
535 |
CPPUNIT_ASSERT( pv2->size() == 1 );
|
sl@0
|
536 |
CPPUNIT_ASSERT( pv2->capacity() == v1Capacity );
|
sl@0
|
537 |
CPPUNIT_ASSERT( (*pv2)[0] == 1 );
|
sl@0
|
538 |
|
sl@0
|
539 |
delete pv2;
|
sl@0
|
540 |
delete pv1;
|
sl@0
|
541 |
}
|
sl@0
|
542 |
void VectorTest::vec_cov1()
|
sl@0
|
543 |
{
|
sl@0
|
544 |
__UHEAP_MARK;
|
sl@0
|
545 |
{
|
sl@0
|
546 |
vector<int> v;
|
sl@0
|
547 |
vector<int> const& cv = v;
|
sl@0
|
548 |
v.push_back(10);
|
sl@0
|
549 |
v.push_back(20);
|
sl@0
|
550 |
v.push_back(30);
|
sl@0
|
551 |
v.push_back(40);
|
sl@0
|
552 |
v.push_back(50);
|
sl@0
|
553 |
CPPUNIT_ASSERT( cv.front() == 10 );
|
sl@0
|
554 |
CPPUNIT_ASSERT( cv.back() == 50 );
|
sl@0
|
555 |
}
|
sl@0
|
556 |
{
|
sl@0
|
557 |
int i;
|
sl@0
|
558 |
vector<int> vec;
|
sl@0
|
559 |
for (i = 1 ; i < 6 ; ++i )
|
sl@0
|
560 |
{
|
sl@0
|
561 |
vec.push_back ( 3 * i );
|
sl@0
|
562 |
}
|
sl@0
|
563 |
vector <int>::reverse_iterator rVPOS1 = vec.rend ( ) - 1;
|
sl@0
|
564 |
rVPOS1-=2;
|
sl@0
|
565 |
CPPUNIT_ASSERT( *rVPOS1 == 9 );
|
sl@0
|
566 |
vector <int>::reverse_iterator rVPOS2 =rVPOS1 + 2;
|
sl@0
|
567 |
CPPUNIT_ASSERT( *rVPOS2 == 3 );
|
sl@0
|
568 |
}
|
sl@0
|
569 |
{
|
sl@0
|
570 |
int i;
|
sl@0
|
571 |
vector<int> vec;
|
sl@0
|
572 |
for (i = 1 ; i < 6 ; ++i )
|
sl@0
|
573 |
{
|
sl@0
|
574 |
vec.push_back ( 2 * i );
|
sl@0
|
575 |
}
|
sl@0
|
576 |
vector <int>::reverse_iterator rVPOS1 = vec.rbegin ( );
|
sl@0
|
577 |
rVPOS1+=2;
|
sl@0
|
578 |
CPPUNIT_ASSERT( *rVPOS1 == 6 );
|
sl@0
|
579 |
}
|
sl@0
|
580 |
__UHEAP_MARKEND;
|
sl@0
|
581 |
}
|
sl@0
|
582 |
void VectorTest::vec_cov2()
|
sl@0
|
583 |
{
|
sl@0
|
584 |
__UHEAP_MARK;
|
sl@0
|
585 |
{
|
sl@0
|
586 |
int i;
|
sl@0
|
587 |
vector<int> vec;
|
sl@0
|
588 |
for (i = 1 ; i < 6 ; ++i )
|
sl@0
|
589 |
{
|
sl@0
|
590 |
vec.push_back ( 2 * i - 1 );
|
sl@0
|
591 |
}
|
sl@0
|
592 |
vector <int>::reverse_iterator rVPOS1 = vec.rend ( ) - 1;
|
sl@0
|
593 |
rVPOS1--;
|
sl@0
|
594 |
CPPUNIT_ASSERT( *rVPOS1 == 3 );
|
sl@0
|
595 |
}
|
sl@0
|
596 |
{
|
sl@0
|
597 |
int i;
|
sl@0
|
598 |
vector<int> vec;
|
sl@0
|
599 |
for (i = 1 ; i < 6 ; ++i )
|
sl@0
|
600 |
{
|
sl@0
|
601 |
vec.push_back ( 2 * i );
|
sl@0
|
602 |
}
|
sl@0
|
603 |
vector <int>::iterator pos;
|
sl@0
|
604 |
pos = find ( vec.begin ( ), vec.end ( ), 8 );
|
sl@0
|
605 |
reverse_iterator<vector<int>::iterator> rpos ( pos );
|
sl@0
|
606 |
reverse_iterator<vector<int>::iterator>::difference_type diff = 2;
|
sl@0
|
607 |
reverse_iterator<vector<int>::iterator>::reference refrpos = rpos [diff];
|
sl@0
|
608 |
CPPUNIT_ASSERT( refrpos == 2 );
|
sl@0
|
609 |
}
|
sl@0
|
610 |
{
|
sl@0
|
611 |
int i;
|
sl@0
|
612 |
vector<int> vec;
|
sl@0
|
613 |
for ( i = 1 ; i < 6 ; ++i )
|
sl@0
|
614 |
{
|
sl@0
|
615 |
vec.push_back ( i );
|
sl@0
|
616 |
}
|
sl@0
|
617 |
vector <int>::iterator pos;
|
sl@0
|
618 |
pos = find ( vec.begin ( ), vec.end ( ), 4 );
|
sl@0
|
619 |
vector <int>::reverse_iterator rpos ( pos );
|
sl@0
|
620 |
CPPUNIT_ASSERT( *rpos == 3 );
|
sl@0
|
621 |
}
|
sl@0
|
622 |
__UHEAP_MARKEND;
|
sl@0
|
623 |
}
|
sl@0
|
624 |
void VectorTest::vec_cov3()
|
sl@0
|
625 |
{
|
sl@0
|
626 |
__UHEAP_MARK;
|
sl@0
|
627 |
{
|
sl@0
|
628 |
int i;
|
sl@0
|
629 |
vector<int> vec;
|
sl@0
|
630 |
for (i = 1 ; i < 3 ; ++i )
|
sl@0
|
631 |
{
|
sl@0
|
632 |
vec.push_back ( 10 * i );
|
sl@0
|
633 |
}
|
sl@0
|
634 |
back_insert_iterator<vector<int> > backiter ( vec );
|
sl@0
|
635 |
*backiter = 30;
|
sl@0
|
636 |
backiter++;
|
sl@0
|
637 |
*backiter = 40;
|
sl@0
|
638 |
backiter++;
|
sl@0
|
639 |
vector <int>::iterator vIter;
|
sl@0
|
640 |
vIter = vec.begin ( ) ;
|
sl@0
|
641 |
CPPUNIT_ASSERT( *vIter == 10 );
|
sl@0
|
642 |
vIter++;
|
sl@0
|
643 |
CPPUNIT_ASSERT( *vIter == 20 );
|
sl@0
|
644 |
vIter++;
|
sl@0
|
645 |
CPPUNIT_ASSERT( *vIter == 30 );
|
sl@0
|
646 |
vIter++;
|
sl@0
|
647 |
CPPUNIT_ASSERT( *vIter == 40 );
|
sl@0
|
648 |
}
|
sl@0
|
649 |
{
|
sl@0
|
650 |
vector<int> vec;
|
sl@0
|
651 |
vec.push_back (10);
|
sl@0
|
652 |
insert_iterator<vector<int> > ii ( vec, vec.begin ( ) );
|
sl@0
|
653 |
*ii = 30;
|
sl@0
|
654 |
vector <int>::iterator vIter;
|
sl@0
|
655 |
vIter = vec.begin ( ) ;
|
sl@0
|
656 |
CPPUNIT_ASSERT( *vIter == 30 );
|
sl@0
|
657 |
}
|
sl@0
|
658 |
{
|
sl@0
|
659 |
int i;
|
sl@0
|
660 |
vector<int> vec;
|
sl@0
|
661 |
for (i = 1 ; i < 6 ; ++i )
|
sl@0
|
662 |
{
|
sl@0
|
663 |
vec.push_back ( 3 * i );
|
sl@0
|
664 |
}
|
sl@0
|
665 |
vector <int>::reverse_iterator rVPOS1 = vec.rend ( ) - 1;
|
sl@0
|
666 |
vector <int>::reverse_iterator rVPOS2 = vec.rbegin ( );
|
sl@0
|
667 |
CPPUNIT_ASSERT(*rVPOS2 > *rVPOS1);
|
sl@0
|
668 |
}
|
sl@0
|
669 |
__UHEAP_MARKEND;
|
sl@0
|
670 |
}
|
sl@0
|
671 |
|
sl@0
|
672 |
void VectorTest::vec_cov4()
|
sl@0
|
673 |
{
|
sl@0
|
674 |
__UHEAP_MARK;
|
sl@0
|
675 |
vector<int> v;
|
sl@0
|
676 |
size_t x;
|
sl@0
|
677 |
v.push_back(10);
|
sl@0
|
678 |
v.push_back(20);
|
sl@0
|
679 |
v.push_back(30);
|
sl@0
|
680 |
v.push_back(40);
|
sl@0
|
681 |
v.push_back(50);
|
sl@0
|
682 |
x=v.max_size();
|
sl@0
|
683 |
#if !defined (STLPORT) || defined (_STLP_USE_EXCEPTIONS)
|
sl@0
|
684 |
for (;;) {
|
sl@0
|
685 |
try {
|
sl@0
|
686 |
v.reserve(x+1);
|
sl@0
|
687 |
CPPUNIT_ASSERT(false);
|
sl@0
|
688 |
}
|
sl@0
|
689 |
catch (length_error const&) {
|
sl@0
|
690 |
return;
|
sl@0
|
691 |
}
|
sl@0
|
692 |
catch (...) {
|
sl@0
|
693 |
CPPUNIT_ASSERT(false);
|
sl@0
|
694 |
}
|
sl@0
|
695 |
}
|
sl@0
|
696 |
#endif
|
sl@0
|
697 |
__UHEAP_MARKEND;
|
sl@0
|
698 |
}
|