// Copyright (C) 2019-2024 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::stack s0; std::stack s1 = s0; check_type>(s1); std::stack s2 = std::move(s0); check_type>(s2); const std::stack s3 = s0; check_type>(s3); const std::stack s4 = s3; check_type>(s4); std::allocator a; std::stack s5(s0, a); check_type>(s5); std::stack s6(std::move(s0), a); check_type>(s6); const std::stack s7(s3, a); check_type>(s7); } void test02() { std::deque d; std::list l; std::stack s1(d); check_type>(s1); std::stack s2(d, d.get_allocator()); check_type>(s2); std::stack s3(std::move(d)); check_type>(s3); std::stack s4(std::move(d), d.get_allocator()); check_type>(s4); std::stack s5(l); check_type>>(s5); std::stack s6(l, l.get_allocator()); check_type>>(s6); std::stack s7(std::move(l)); check_type>>(s7); std::stack s8(std::move(l), l.get_allocator()); check_type>>(s8); } #if __cpp_lib_adaptor_iterator_pair_constructor void test03() { std::list l; std::stack s1(l.begin(), l.end()); check_type>(s1); std::stack s2(l.begin(), l.end(), std::allocator()); check_type>(s2); } #endif