]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/std/containers/sequences/list/list.cons/input_iterator.pass.cpp
Vendor import of libc++ trunk r290819:
[FreeBSD/FreeBSD.git] / test / std / containers / sequences / list / list.cons / input_iterator.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 // <list>
11
12 // template <class InputIterator>
13 //   list(InputIterator first, InputIterator last, const Allocator& = Allocator());
14
15 #include <list>
16 #include <cassert>
17 #include "test_iterators.h"
18 #include "test_allocator.h"
19 #include "min_allocator.h"
20
21 int main()
22 {
23     {
24         int a[] = {0, 1, 2, 3};
25         std::list<int> l(input_iterator<const int*>(a),
26                          input_iterator<const int*>(a + sizeof(a)/sizeof(a[0])));
27         assert(l.size() == sizeof(a)/sizeof(a[0]));
28         assert(std::distance(l.begin(), l.end()) == sizeof(a)/sizeof(a[0]));
29         int j = 0;
30         for (std::list<int>::const_iterator i = l.begin(), e = l.end(); i != e; ++i, ++j)
31             assert(*i == j);
32     }
33     {
34         int a[] = {0, 1, 2, 3};
35         std::list<int> l(input_iterator<const int*>(a),
36                          input_iterator<const int*>(a + sizeof(a)/sizeof(a[0])),
37                          std::allocator<int>());
38         assert(l.size() == sizeof(a)/sizeof(a[0]));
39         assert(std::distance(l.begin(), l.end()) == sizeof(a)/sizeof(a[0]));
40         int j = 0;
41         for (std::list<int>::const_iterator i = l.begin(), e = l.end(); i != e; ++i, ++j)
42             assert(*i == j);
43     }
44     {
45         int a[] = {0, 1, 2, 3};
46         // Add 2 for implementations that dynamically allocate a sentinel node and container proxy.
47         std::list<int, limited_allocator<int, sizeof(a)/sizeof(a[0]) + 2> > l(input_iterator<const int*>(a),
48                          input_iterator<const int*>(a + sizeof(a)/sizeof(a[0])));
49         assert(l.size() == sizeof(a)/sizeof(a[0]));
50         assert(std::distance(l.begin(), l.end()) == sizeof(a)/sizeof(a[0]));
51         int j = 0;
52         for (std::list<int>::const_iterator i = l.begin(), e = l.end(); i != e; ++i, ++j)
53             assert(*i == j);
54     }
55 #if TEST_STD_VER >= 11
56     {
57         int a[] = {0, 1, 2, 3};
58         std::list<int, min_allocator<int>> l(input_iterator<const int*>(a),
59                          input_iterator<const int*>(a + sizeof(a)/sizeof(a[0])));
60         assert(l.size() == sizeof(a)/sizeof(a[0]));
61         assert(std::distance(l.begin(), l.end()) == sizeof(a)/sizeof(a[0]));
62         int j = 0;
63         for (std::list<int, min_allocator<int>>::const_iterator i = l.begin(), e = l.end(); i != e; ++i, ++j)
64             assert(*i == j);
65     }
66     {
67         int a[] = {0, 1, 2, 3};
68         std::list<int, min_allocator<int>> l(input_iterator<const int*>(a),
69                          input_iterator<const int*>(a + sizeof(a)/sizeof(a[0])),
70                          min_allocator<int>());
71         assert(l.size() == sizeof(a)/sizeof(a[0]));
72         assert(std::distance(l.begin(), l.end()) == sizeof(a)/sizeof(a[0]));
73         int j = 0;
74         for (std::list<int, min_allocator<int>>::const_iterator i = l.begin(), e = l.end(); i != e; ++i, ++j)
75             assert(*i == j);
76     }
77 #endif
78 }