copy_alloc.pass.cpp revision b64f8b07c104c6cc986570ac8ee0ed16a9f23976
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(const map& m, const allocator_type& a);
15
16#include <map>
17#include <cassert>
18
19#include "../../../test_compare.h"
20#include "../../../test_allocator.h"
21
22int main()
23{
24    typedef std::pair<const int, double> V;
25    V ar[] =
26    {
27        V(1, 1),
28        V(1, 1.5),
29        V(1, 2),
30        V(2, 1),
31        V(2, 1.5),
32        V(2, 2),
33        V(3, 1),
34        V(3, 1.5),
35        V(3, 2),
36    };
37    typedef test_compare<std::less<int> > C;
38    typedef test_allocator<V> A;
39    std::map<int, double, C, A> mo(ar, ar+sizeof(ar)/sizeof(ar[0]), C(5), A(7));
40    std::map<int, double, C, A> m(mo, A(3));
41    assert(m.get_allocator() == A(3));
42    assert(m.key_comp() == C(5));
43    assert(m.size() == 3);
44    assert(distance(m.begin(), m.end()) == 3);
45    assert(*m.begin() == V(1, 1));
46    assert(*next(m.begin()) == V(2, 1));
47    assert(*next(m.begin(), 2) == V(3, 1));
48
49    assert(mo.get_allocator() == A(7));
50    assert(mo.key_comp() == C(5));
51    assert(mo.size() == 3);
52    assert(distance(mo.begin(), mo.end()) == 3);
53    assert(*mo.begin() == V(1, 1));
54    assert(*next(mo.begin()) == V(2, 1));
55    assert(*next(mo.begin(), 2) == V(3, 1));
56}
57