//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // template // stack(const container_type& c, const Alloc& a); #include #include #include "test_allocator.h" template C make(int n) { C c; for (int i = 0; i < n; ++i) c.push_back(i); return c; } typedef std::deque > C; struct test : public std::stack { typedef std::stack base; explicit test(const test_allocator& a) : base(a) {} test(const container_type& c, const test_allocator& a) : base(c, a) {} #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES test(container_type&& c, const test_allocator& a) : base(std::move(c), a) {} test(test&& q, const test_allocator& a) : base(std::move(q), a) {} #endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES test_allocator get_allocator() {return c.get_allocator();} }; int main() { C d = make(5); test q(d, test_allocator(4)); assert(q.get_allocator() == test_allocator(4)); assert(q.size() == 5); for (int i = 0; i < d.size(); ++i) { assert(q.top() == d[d.size() - i - 1]); q.pop(); } }