mirror of
https://gcc.gnu.org/git/gcc.git
synced 2025-01-24 05:14:58 +08:00
PR libstdc++/48635 (again)
2011-04-17 Daniel Krugler <daniel.kruegler@googlemail.com> Paolo Carlini <paolo.carlini@oracle.com> PR libstdc++/48635 (again) * include/bits/unique_ptr.h (unique_ptr<>::unique_ptr(unique_ptr<>&&), unique_ptr<_Tp[]>::unique_ptr(unique_ptr<>&&), unique_ptr<>::operator=(unique_ptr<>&&), unique_ptr<_Tp[]>::operator=(unique_ptr<>&&)): Use forward<_Ep>, not forward<_Dp>, to forward the deleter. * testsuite/20_util/unique_ptr/assign/48635_neg.cc: New. Co-Authored-By: Paolo Carlini <paolo.carlini@oracle.com> From-SVN: r172619
This commit is contained in:
parent
e54170f4fd
commit
da8111a024
@ -1,3 +1,14 @@
|
||||
2011-04-17 Daniel Krugler <daniel.kruegler@googlemail.com>
|
||||
Paolo Carlini <paolo.carlini@oracle.com>
|
||||
|
||||
PR libstdc++/48635 (again)
|
||||
* include/bits/unique_ptr.h (unique_ptr<>::unique_ptr(unique_ptr<>&&),
|
||||
unique_ptr<_Tp[]>::unique_ptr(unique_ptr<>&&),
|
||||
unique_ptr<>::operator=(unique_ptr<>&&),
|
||||
unique_ptr<_Tp[]>::operator=(unique_ptr<>&&)): Use forward<_Ep>, not
|
||||
forward<_Dp>, to forward the deleter.
|
||||
* testsuite/20_util/unique_ptr/assign/48635_neg.cc: New.
|
||||
|
||||
2011-04-15 Daniel Krugler <daniel.kruegler@googlemail.com>
|
||||
Paolo Carlini <paolo.carlini@oracle.com>
|
||||
|
||||
|
@ -153,7 +153,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||
&& std::is_convertible<_Ep, _Dp>::value))>
|
||||
::type>
|
||||
unique_ptr(unique_ptr<_Up, _Ep>&& __u)
|
||||
: _M_t(__u.release(), std::forward<deleter_type>(__u.get_deleter()))
|
||||
: _M_t(__u.release(), std::forward<_Ep>(__u.get_deleter()))
|
||||
{ }
|
||||
|
||||
#if _GLIBCXX_USE_DEPRECATED
|
||||
@ -186,7 +186,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||
operator=(unique_ptr<_Up, _Ep>&& __u)
|
||||
{
|
||||
reset(__u.release());
|
||||
get_deleter() = std::forward<deleter_type>(__u.get_deleter());
|
||||
get_deleter() = std::forward<_Ep>(__u.get_deleter());
|
||||
return *this;
|
||||
}
|
||||
|
||||
@ -306,7 +306,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||
|
||||
template<typename _Up, typename _Ep>
|
||||
unique_ptr(unique_ptr<_Up, _Ep>&& __u)
|
||||
: _M_t(__u.release(), std::forward<deleter_type>(__u.get_deleter()))
|
||||
: _M_t(__u.release(), std::forward<_Ep>(__u.get_deleter()))
|
||||
{ }
|
||||
|
||||
// Destructor.
|
||||
@ -326,7 +326,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||
operator=(unique_ptr<_Up, _Ep>&& __u)
|
||||
{
|
||||
reset(__u.release());
|
||||
get_deleter() = std::forward<deleter_type>(__u.get_deleter());
|
||||
get_deleter() = std::forward<_Ep>(__u.get_deleter());
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
@ -0,0 +1,50 @@
|
||||
// { dg-options "-std=gnu++0x" }
|
||||
// { dg-do compile }
|
||||
|
||||
// Copyright (C) 2011 Free Software Foundation
|
||||
//
|
||||
// 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
|
||||
// <http://www.gnu.org/licenses/>.
|
||||
|
||||
#include <memory>
|
||||
|
||||
struct D;
|
||||
|
||||
struct B
|
||||
{
|
||||
B& operator=(D&) = delete; // { dg-error "declared here" }
|
||||
|
||||
template<class T>
|
||||
void operator()(T*) const {}
|
||||
};
|
||||
|
||||
struct D : B { };
|
||||
|
||||
// libstdc++/48635
|
||||
void f()
|
||||
{
|
||||
B b;
|
||||
D d;
|
||||
|
||||
std::unique_ptr<int, B&> ub(nullptr, b);
|
||||
std::unique_ptr<int, D&> ud(nullptr, d);
|
||||
ub = std::move(ud);
|
||||
// { dg-error "use of deleted function" "" { target *-*-* } 189 }
|
||||
|
||||
std::unique_ptr<int[], B&> uba(nullptr, b);
|
||||
std::unique_ptr<int[], D&> uda(nullptr, d);
|
||||
uba = std::move(uda);
|
||||
// { dg-error "use of deleted function" "" { target *-*-* } 329 }
|
||||
}
|
Loading…
Reference in New Issue
Block a user