1bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//===----------------------------------------------------------------------===//
2bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//
3f5256e16dfc425c1d466f6308d4026d529ce9e0bHoward Hinnant//                     The LLVM Compiler Infrastructure
4bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//
5b64f8b07c104c6cc986570ac8ee0ed16a9f23976Howard Hinnant// This file is dual licensed under the MIT and the University of Illinois Open
6b64f8b07c104c6cc986570ac8ee0ed16a9f23976Howard Hinnant// Source Licenses. See LICENSE.TXT for details.
7bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//
8bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//===----------------------------------------------------------------------===//
9bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant
10bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// <vector>
11bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// vector<bool>
12bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant
13bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// void swap(vector& x);
14bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant
15bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant#include <vector>
16bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant#include <cassert>
171b92188a82b01e76ac6e8ad5f997293c2a078adcMarshall Clow#include "test_allocator.h"
18061d0cc4db18d17bf01ed14c5db0be098205bd47Marshall Clow#include "min_allocator.h"
19bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant
20bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnantint main()
21bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant{
22bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant    {
23bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        std::vector<bool> v1(100);
24bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        std::vector<bool> v2(200);
25bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        v1.swap(v2);
26bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.size() == 200);
27bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.capacity() >= 200);
28bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.size() == 100);
29bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.capacity() >= 100);
30bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant    }
31bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant    {
32bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        typedef test_allocator<bool> A;
3311f64dcc5864f3d237dd4fd35f56793022567257Eric Fiselier        std::vector<bool, A> v1(100, true, A(1, 1));
3411f64dcc5864f3d237dd4fd35f56793022567257Eric Fiselier        std::vector<bool, A> v2(200, false, A(1, 2));
35bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        swap(v1, v2);
36bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.size() == 200);
37bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.capacity() >= 200);
38bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.size() == 100);
39bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.capacity() >= 100);
4011f64dcc5864f3d237dd4fd35f56793022567257Eric Fiselier        assert(v1.get_allocator().get_id() == 1);
4111f64dcc5864f3d237dd4fd35f56793022567257Eric Fiselier        assert(v2.get_allocator().get_id() == 2);
42bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant    }
43bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant    {
44bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        typedef other_allocator<bool> A;
45bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        std::vector<bool, A> v1(100, true, A(1));
46bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        std::vector<bool, A> v2(200, false, A(2));
47bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        swap(v1, v2);
48bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.size() == 200);
49bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.capacity() >= 200);
50bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.size() == 100);
51bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.capacity() >= 100);
52bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v1.get_allocator() == A(2));
53bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant        assert(v2.get_allocator() == A(1));
54bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant    }
55d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant    {
56d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        std::vector<bool> v(2);
57d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        std::vector<bool>::reference r1 = v[0];
58d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        std::vector<bool>::reference r2 = v[1];
59d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        r1 = true;
60d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        using std::swap;
61d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        swap(r1, r2);
62d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        assert(v[0] == false);
63d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant        assert(v[1] == true);
64d9cdb2dcfd5d8f1f77194975d4b746065ed9aeb8Howard Hinnant    }
65d24c465beaec2fe9a0e365e6379cd5d3acaeb2caEric Fiselier#if TEST_STD_VER >= 11
662c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant    {
672c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, min_allocator<bool>> v1(100);
682c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, min_allocator<bool>> v2(200);
692c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        v1.swap(v2);
702c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v1.size() == 200);
712c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v1.capacity() >= 200);
722c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v2.size() == 100);
732c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v2.capacity() >= 100);
742c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant    }
752c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant    {
762c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        typedef min_allocator<bool> A;
772c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, A> v1(100, true, A());
782c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, A> v2(200, false, A());
792c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        swap(v1, v2);
802c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v1.size() == 200);
812c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v1.capacity() >= 200);
822c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v2.size() == 100);
832c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v2.capacity() >= 100);
842c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v1.get_allocator() == A());
852c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v2.get_allocator() == A());
862c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant    }
872c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant    {
882c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, min_allocator<bool>> v(2);
892c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, min_allocator<bool>>::reference r1 = v[0];
902c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        std::vector<bool, min_allocator<bool>>::reference r2 = v[1];
912c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        r1 = true;
922c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        using std::swap;
932c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        swap(r1, r2);
942c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v[0] == false);
952c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant        assert(v[1] == true);
962c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant    }
972c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant#endif
98bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant}
99