// Copyright (C) 2019-2022 Free Software Foundation, Inc. // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the // Free Software Foundation; either version 3, or (at your option) // any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License along // with this library; see the file COPYING3. If not see // . // { dg-do compile { target c++17 } } #include #include #include #include template struct require_same; template struct require_same { using type = void; }; template typename require_same::type check_type(U&) { } void test01() { std::queue s0; std::queue s1 = s0; check_type>(s1); std::queue s2 = std::move(s0); check_type>(s2); const std::queue s3 = s0; check_type>(s3); const std::queue s4 = s3; check_type>(s4); std::allocator a; std::queue s5(s0, a); check_type>(s5); std::queue s6(std::move(s0), a); check_type>(s6); const std::queue s7(s3, a); check_type>(s7); } void test02() { std::deque d; std::list l; std::queue s1(d); check_type>(s1); std::queue s2(d, d.get_allocator()); check_type>(s2); std::queue s3(std::move(d)); check_type>(s3); std::queue s4(std::move(d), d.get_allocator()); check_type>(s4); std::queue s5(l); check_type>>(s5); std::queue s6(l, l.get_allocator()); check_type>>(s6); std::queue s7(std::move(l)); check_type>>(s7); std::queue s8(std::move(l), l.get_allocator()); check_type>>(s8); } struct Pool; template struct Alloc : __gnu_test::SimpleAllocator { Alloc(Pool*) { } template Alloc(const Alloc&) { } }; void test_p1518r2() { // P1518R2 - Stop overconstraining allocators in container deduction guides. // This is a C++23 feature but we support it for C++17 too. using Deque = std::deque>; using List = std::list>; Pool* p = nullptr; Deque d(p); List l(p); std::queue q1(d, p); check_type>(q1); std::queue q2(l, p); check_type>(q2); std::queue q3(q2, p); check_type>(q3); }