mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-02-16 14:10:25 +08:00
re PR libstdc++/44487 ([C++0x] pair of references doesn't work)
2010-06-10 Paolo Carlini <paolo.carlini@oracle.com> PR libstdc++/44487 * include/bits/stl_pair.h (pair(pair&&)): Remove. (pair(pair<_U1, _U2>&&): Use forward, consistently with Bullet 5 of LWG 1326. * include/std/tuple (tuple(pair<_U1, _U2>&&)): Likewise. * testsuite/20_util/pair/44487.cc: Add. * testsuite/20_util/tuple/cons/44487.cc: Likewise. * testsuite/20_util/weak_ptr/comparison/cmp_neg.cc: Adjust dg-warning line numbers. From-SVN: r160528
This commit is contained in:
parent
cefab2e482
commit
87b2e74657
@ -1,3 +1,15 @@
|
|||||||
|
2010-06-10 Paolo Carlini <paolo.carlini@oracle.com>
|
||||||
|
|
||||||
|
PR libstdc++/44487
|
||||||
|
* include/bits/stl_pair.h (pair(pair&&)): Remove.
|
||||||
|
(pair(pair<_U1, _U2>&&): Use forward, consistently with Bullet 5
|
||||||
|
of LWG 1326.
|
||||||
|
* include/std/tuple (tuple(pair<_U1, _U2>&&)): Likewise.
|
||||||
|
* testsuite/20_util/pair/44487.cc: Add.
|
||||||
|
* testsuite/20_util/tuple/cons/44487.cc: Likewise.
|
||||||
|
* testsuite/20_util/weak_ptr/comparison/cmp_neg.cc: Adjust dg-warning
|
||||||
|
line numbers.
|
||||||
|
|
||||||
2010-06-09 Paolo Carlini <paolo.carlini@oracle.com>
|
2010-06-09 Paolo Carlini <paolo.carlini@oracle.com>
|
||||||
|
|
||||||
* include/std/type_traits (is_nothrow_constructible): Add.
|
* include/std/type_traits (is_nothrow_constructible): Add.
|
||||||
|
@ -120,10 +120,6 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
|
|||||||
: first(std::forward<_U1>(__x)),
|
: first(std::forward<_U1>(__x)),
|
||||||
second(std::forward<_U2>(__y)) { }
|
second(std::forward<_U2>(__y)) { }
|
||||||
|
|
||||||
pair(pair&& __p)
|
|
||||||
: first(std::move(__p.first)),
|
|
||||||
second(std::move(__p.second)) { }
|
|
||||||
|
|
||||||
template<class... _Args1, class... _Args2>
|
template<class... _Args1, class... _Args2>
|
||||||
pair(piecewise_construct_t,
|
pair(piecewise_construct_t,
|
||||||
tuple<_Args1...> __first_args,
|
tuple<_Args1...> __first_args,
|
||||||
@ -141,8 +137,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
|
|||||||
#ifdef __GXX_EXPERIMENTAL_CXX0X__
|
#ifdef __GXX_EXPERIMENTAL_CXX0X__
|
||||||
template<class _U1, class _U2>
|
template<class _U1, class _U2>
|
||||||
pair(pair<_U1, _U2>&& __p)
|
pair(pair<_U1, _U2>&& __p)
|
||||||
: first(std::move(__p.first)),
|
: first(std::forward<_U1>(__p.first)),
|
||||||
second(std::move(__p.second)) { }
|
second(std::forward<_U2>(__p.second)) { }
|
||||||
|
|
||||||
pair&
|
pair&
|
||||||
operator=(pair&& __p)
|
operator=(pair&& __p)
|
||||||
|
@ -341,7 +341,8 @@ namespace std
|
|||||||
|
|
||||||
template<typename _U1, typename _U2>
|
template<typename _U1, typename _U2>
|
||||||
tuple(pair<_U1, _U2>&& __in)
|
tuple(pair<_U1, _U2>&& __in)
|
||||||
: _Inherited(std::move(__in.first), std::move(__in.second)) { }
|
: _Inherited(std::forward<_U1>(__in.first),
|
||||||
|
std::forward<_U2>(__in.second)) { }
|
||||||
|
|
||||||
tuple&
|
tuple&
|
||||||
operator=(const tuple& __in)
|
operator=(const tuple& __in)
|
||||||
|
51
libstdc++-v3/testsuite/20_util/pair/44487.cc
Normal file
51
libstdc++-v3/testsuite/20_util/pair/44487.cc
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
// { dg-options "-std=gnu++0x" }
|
||||||
|
// { dg-do compile }
|
||||||
|
|
||||||
|
// Copyright (C) 2010 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
|
||||||
|
// <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
|
int x, y;
|
||||||
|
|
||||||
|
std::pair<int&, int&>
|
||||||
|
foo1()
|
||||||
|
{
|
||||||
|
std::pair<int&, int&> blah(x, y);
|
||||||
|
return blah;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::pair<int&, int&>
|
||||||
|
foo2()
|
||||||
|
{
|
||||||
|
const std::pair<int&, int&> blah(x, y);
|
||||||
|
return blah;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::pair<int&, int&>
|
||||||
|
foo3()
|
||||||
|
{
|
||||||
|
std::pair<int&, int&> blah(x, y);
|
||||||
|
return std::pair<int&, int&>(std::move(blah));
|
||||||
|
}
|
||||||
|
|
||||||
|
std::pair<int&, int&>
|
||||||
|
foo4()
|
||||||
|
{
|
||||||
|
const std::pair<int&, int&> blah(x, y);
|
||||||
|
return std::pair<int&, int&>(std::move(blah));
|
||||||
|
}
|
51
libstdc++-v3/testsuite/20_util/tuple/cons/44487.cc
Normal file
51
libstdc++-v3/testsuite/20_util/tuple/cons/44487.cc
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
// { dg-options "-std=gnu++0x" }
|
||||||
|
// { dg-do compile }
|
||||||
|
|
||||||
|
// Copyright (C) 2010 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
|
||||||
|
// <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include <tuple>
|
||||||
|
|
||||||
|
int x, y;
|
||||||
|
|
||||||
|
std::tuple<int&, int&>
|
||||||
|
foo1()
|
||||||
|
{
|
||||||
|
std::pair<int&, int&> blah(x, y);
|
||||||
|
return blah;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::tuple<int&, int&>
|
||||||
|
foo2()
|
||||||
|
{
|
||||||
|
const std::pair<int&, int&> blah(x, y);
|
||||||
|
return blah;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::tuple<int&, int&>
|
||||||
|
foo3()
|
||||||
|
{
|
||||||
|
std::pair<int&, int&> blah(x, y);
|
||||||
|
return std::tuple<int&, int&>(std::move(blah));
|
||||||
|
}
|
||||||
|
|
||||||
|
std::tuple<int&, int&>
|
||||||
|
foo4()
|
||||||
|
{
|
||||||
|
const std::pair<int&, int&> blah(x, y);
|
||||||
|
return std::tuple<int&, int&>(std::move(blah));
|
||||||
|
}
|
@ -44,8 +44,8 @@ main()
|
|||||||
// { dg-warning "note" "" { target *-*-* } 324 }
|
// { dg-warning "note" "" { target *-*-* } 324 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 423 }
|
// { dg-warning "note" "" { target *-*-* } 423 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 862 }
|
// { dg-warning "note" "" { target *-*-* } 862 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 511 }
|
// { dg-warning "note" "" { target *-*-* } 512 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 1005 }
|
// { dg-warning "note" "" { target *-*-* } 1005 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 340 }
|
// { dg-warning "note" "" { target *-*-* } 340 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 290 }
|
// { dg-warning "note" "" { target *-*-* } 290 }
|
||||||
// { dg-warning "note" "" { target *-*-* } 201 }
|
// { dg-warning "note" "" { target *-*-* } 197 }
|
||||||
|
Loading…
Reference in New Issue
Block a user