//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // UNSUPPORTED: c++98, c++03, c++11, c++14 // UNSUPPORTED: libcpp-no-deduction-guides // template // priority_queue(Compare, Container) // -> priority_queue; // // template::value_type>, // class Container = vector::value_type>> // priority_queue(InputIterator, InputIterator, Compare = Compare(), Container = Container()) // -> priority_queue::value_type, Container, Compare>; // // template // priority_queue(Compare, Container, Allocator) // -> priority_queue; #include #include #include #include #include #include // INT_MAX #include "test_macros.h" #include "test_iterators.h" #include "test_allocator.h" struct A {}; int main() { // Test the explicit deduction guides { std::vector v{0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; std::priority_queue pri(std::greater(), v); // priority_queue(Compare, Container) static_assert(std::is_same_v, std::greater>>, ""); assert(pri.size() == v.size()); assert(pri.top() == 0); } { std::vector> v{10, 11, 12, 13, 14, 15, 16, 17, 18, 19 }; std::priority_queue pri(std::greater(), v, test_allocator(2)); // priority_queue(Compare, Container, Allocator) static_assert(std::is_same_v>, std::greater>>, ""); assert(pri.size() == v.size()); assert(pri.top() == 10); } { std::vector v{10, 11, 12, 13, 14, 15, 28, 17, 18, 19 }; std::priority_queue pri(v.begin(), v.end()); // priority_queue(Iter, Iter) static_assert(std::is_same_v>, ""); assert(pri.size() == v.size()); assert(pri.top() == 28); } { std::vector v{10, 11, 12, 13, 6, 15, 28, 17, 18, 19 }; std::priority_queue pri(v.begin(), v.end(), std::greater()); // priority_queue(Iter, Iter, Comp) static_assert(std::is_same_v, std::greater>>, ""); assert(pri.size() == v.size()); assert(pri.top() == 6); } { std::vector v{10, 6, 15, 28, 4, 18, 19 }; std::deque deq; std::priority_queue pri(v.begin(), v.end(), std::greater(), deq); // priority_queue(Iter, Iter, Comp, Container) static_assert(std::is_same_v, std::greater>>, ""); assert(pri.size() == v.size()); assert(pri.top() == 4); } // Test the implicit deduction guides { // We don't expect this one to work - no way to implicitly get value_type // std::priority_queue pri(std::allocator()); // queue (allocator &) } { std::priority_queue source; std::priority_queue pri(source); // priority_queue(priority_queue &) static_assert(std::is_same_v, ""); static_assert(std::is_same_v>, ""); assert(pri.size() == 0); } { // This one is odd - you can pass an allocator in to use, but the allocator // has to match the type of the one used by the underlying container typedef long double T; typedef std::greater Comp; typedef test_allocator A; typedef std::deque Cont; Cont c{2,3,0,1}; std::priority_queue source(Comp(), c); std::priority_queue pri(source, A(2)); // queue(queue &, allocator) static_assert(std::is_same_v, ""); static_assert(std::is_same_v, ""); assert(pri.size() == 4); assert(pri.top() == 0); } }