//===----------------------------------------------------------------------===// // // 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 priority_queue& q, const Alloc& a); #include #include template C make(int n) { C c; for (int i = 0; i < n; ++i) c.push_back(i); return c; } #include "test_allocator.h" 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, c, a) {} test(const value_compare& comp, const container_type& c, const test_allocator& a) : base(comp, c, a) {} test(const test& q, const test_allocator& a) : base(q, a) {} test_allocator get_allocator() {return c.get_allocator();} using base::c; }; int main() { test qo(std::less(), make > >(5), test_allocator(2)); test q(qo, test_allocator(6)); assert(q.size() == 5); assert(q.c.get_allocator() == test_allocator(6)); assert(q.top() == int(4)); }