//===----------------------------------------------------------------------===// // // 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 // priority_queue(const Compare& comp, 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; } template struct test : public std::priority_queue > > { typedef std::priority_queue > > base; typedef typename base::container_type container_type; typedef typename base::value_compare value_compare; explicit test(const test_allocator& a) : base(a) {} test(const value_compare& comp, const test_allocator& a) : base(comp, a) {} test(const value_compare& comp, const container_type& c, const test_allocator& a) : base(comp, c, a) {} #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES test(const value_compare& comp, container_type&& c, const test_allocator& a) : base(comp, 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();} using base::c; }; int main() { typedef std::vector > C; test q(std::less(), make(5), test_allocator(3)); assert(q.c.get_allocator() == test_allocator(3)); assert(q.size() == 5); assert(q.top() == 4); }