1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
//===----------------------------------------------------------------------===//
//
// The LLVM Compiler Infrastructure
//
// This file is dual licensed under the MIT and the University of Illinois Open
// Source Licenses. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
// <memory>
// template <class OuterAlloc, class... InnerAllocs>
// class scoped_allocator_adaptor
// template <class OuterA2>
// scoped_allocator_adaptor(OuterA2&& outerAlloc,
// const InnerAllocs& ...innerAllocs);
#include <scoped_allocator>
#include <cassert>
#include "allocators.h"
int main()
{
#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
{
typedef std::scoped_allocator_adaptor<A1<int>> A;
A1<int> a3(3);
A a(a3);
assert(a.outer_allocator() == A1<int>(3));
assert(a.inner_allocator() == a);
assert(A1<int>::copy_called == true);
assert(A1<int>::move_called == false);
}
A1<int>::copy_called = false;
{
typedef std::scoped_allocator_adaptor<A1<int>> A;
A a(A1<int>(3));
assert(a.outer_allocator() == A1<int>(3));
assert(a.inner_allocator() == a);
assert(A1<int>::copy_called == false);
assert(A1<int>::move_called == true);
}
A1<int>::move_called = false;
{
typedef std::scoped_allocator_adaptor<A1<int>, A2<int>> A;
A1<int> a4(4);
A a(a4, A2<int>(5));
assert(A1<int>::copy_called == true);
assert(A1<int>::move_called == false);
assert(A2<int>::copy_called == true);
assert(A2<int>::move_called == false);
assert(a.outer_allocator() == A1<int>(4));
assert(a.inner_allocator() == std::scoped_allocator_adaptor<A2<int>>(A2<int>(5)));
}
A1<int>::copy_called = false;
A1<int>::move_called = false;
A2<int>::copy_called = false;
A2<int>::move_called = false;
{
typedef std::scoped_allocator_adaptor<A1<int>, A2<int>> A;
A a(A1<int>(4), A2<int>(5));
assert(A1<int>::copy_called == false);
assert(A1<int>::move_called == true);
assert(A2<int>::copy_called == true);
assert(A2<int>::move_called == false);
assert(a.outer_allocator() == A1<int>(4));
assert(a.inner_allocator() == std::scoped_allocator_adaptor<A2<int>>(A2<int>(5)));
}
A1<int>::copy_called = false;
A1<int>::move_called = false;
A2<int>::copy_called = false;
A2<int>::move_called = false;
A1<int>::move_called = false;
{
typedef std::scoped_allocator_adaptor<A1<int>, A2<int>, A3<int>> A;
A1<int> a4(4);
A a(a4, A2<int>(5), A3<int>(6));
assert(A1<int>::copy_called == true);
assert(A1<int>::move_called == false);
assert(A2<int>::copy_called == true);
assert(A2<int>::move_called == false);
assert(A3<int>::copy_called == true);
assert(A3<int>::move_called == false);
assert(a.outer_allocator() == A1<int>(4));
assert((a.inner_allocator() ==
std::scoped_allocator_adaptor<A2<int>, A3<int>>(A2<int>(5), A3<int>(6))));
}
A1<int>::copy_called = false;
A1<int>::move_called = false;
A2<int>::copy_called = false;
A2<int>::move_called = false;
A3<int>::copy_called = false;
A3<int>::move_called = false;
{
typedef std::scoped_allocator_adaptor<A1<int>, A2<int>, A3<int>> A;
A a(A1<int>(4), A2<int>(5), A3<int>(6));
assert(A1<int>::copy_called == false);
assert(A1<int>::move_called == true);
assert(A2<int>::copy_called == true);
assert(A2<int>::move_called == false);
assert(A3<int>::copy_called == true);
assert(A3<int>::move_called == false);
assert(a.outer_allocator() == A1<int>(4));
assert((a.inner_allocator() ==
std::scoped_allocator_adaptor<A2<int>, A3<int>>(A2<int>(5), A3<int>(6))));
}
#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
}
|