// { dg-do compile { target c++11 } } // Copyright (C) 2016-2018 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 // . // 20.7.1 Class template unique_ptr [unique.ptr] #include struct A { virtual ~A() = default; }; struct B : A { }; // Construction from objects with different cv-qualification struct A_pointer { operator A*() const { return nullptr; } }; void test07() { A_pointer p; // Disallow conversions from user-defined pointer-like types // for the array version std::unique_ptr upA3(p); // { dg-error "no matching function" } std::unique_ptr cA3(p); // { dg-error "no matching function" } std::unique_ptr vA3(p); // { dg-error "no matching function" } std::unique_ptr cvA3(p); // { dg-error "no matching function" } // { dg-prune-output "no type" } } template struct deleter { deleter() = default; template deleter(const deleter) { } typedef T pointer; void operator()(T) const { } }; void test08() { // Disallow conversions from non-assignable deleter std::unique_ptr> p; std::unique_ptr> upA(std::move(p)); // { dg-error "no matching function" } } void test011() { // Disallow conversions between different array types. std::unique_ptr upB; std::unique_ptr cA(std::move(upB)); // { dg-error "no matching function" } std::unique_ptr vA(std::move(upB)); // { dg-error "no matching function" } std::unique_ptr cvA(std::move(upB)); // { dg-error "no matching function" } }