re PR c++/55908 (Problem binding a const member function to a const object)

PR libstdc++/55908
	* include/std/functional (_Mem_fn::operator()): Fix constraints to
	avoid ambiguity.
	* testsuite/20_util/function_objects/mem_fn/55908.cc: New.
	* testsuite/20_util/bind/ref_neg.cc: Adjust dg-error line numbers.

From-SVN: r195035
This commit is contained in:
Jonathan Wakely 2013-01-08 21:01:14 +00:00 committed by Jonathan Wakely
parent 36b7291056
commit 890e166507
4 changed files with 50 additions and 7 deletions

View File

@ -1,3 +1,11 @@
2013-01-08 Jonathan Wakely <jwakely.gcc@gmail.com>
PR libstdc++/55908
* include/std/functional (_Mem_fn::operator()): Fix constraints to
avoid ambiguity.
* testsuite/20_util/function_objects/mem_fn/55908.cc: New.
* testsuite/20_util/bind/ref_neg.cc: Adjust dg-error line numbers.
2013-01-08 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
PR libstdc++/55594

View File

@ -648,7 +648,7 @@ _GLIBCXX_HAS_NESTED_TYPE(result_type)
template<typename _Tp, typename... _Args>
using _RequireValidArgs2
= _Require<_NotSame<_Class, _Tp>, _NotSame<_Class*, _Tp>,
= _Require<_NotSame<_Class, _Tp>, _NotSame<const _Class*, _Tp>,
_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
template<typename _Tp, typename... _Args>
@ -727,7 +727,7 @@ _GLIBCXX_HAS_NESTED_TYPE(result_type)
template<typename _Tp, typename... _Args>
using _RequireValidArgs2
= _Require<_NotSame<_Class, _Tp>, _NotSame<_Class*, _Tp>,
= _Require<_NotSame<_Class, _Tp>, _NotSame<volatile _Class*, _Tp>,
_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
template<typename _Tp, typename... _Args>
@ -807,7 +807,8 @@ _GLIBCXX_HAS_NESTED_TYPE(result_type)
template<typename _Tp, typename... _Args>
using _RequireValidArgs2
= _Require<_NotSame<_Class, _Tp>, _NotSame<_Class*, _Tp>,
= _Require<_NotSame<_Class, _Tp>,
_NotSame<const volatile _Class*, _Tp>,
_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
template<typename _Tp, typename... _Args>

View File

@ -30,10 +30,10 @@ void test01()
{
const int dummy = 0;
std::bind(&inc, _1)(0); // { dg-error "no match" }
// { dg-error "rvalue|const" "" { target *-*-* } 1346 }
// { dg-error "rvalue|const" "" { target *-*-* } 1360 }
// { dg-error "rvalue|const" "" { target *-*-* } 1374 }
// { dg-error "rvalue|const" "" { target *-*-* } 1388 }
// { dg-error "rvalue|const" "" { target *-*-* } 1347 }
// { dg-error "rvalue|const" "" { target *-*-* } 1361 }
// { dg-error "rvalue|const" "" { target *-*-* } 1375 }
// { dg-error "rvalue|const" "" { target *-*-* } 1389 }
std::bind(&inc, std::ref(dummy))(); // { dg-error "no match" }
}

View File

@ -0,0 +1,34 @@
// { dg-options "-std=gnu++11" }
// { dg-do compile }
// Copyright (C) 2013 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/>.
// PR libstdc++/55908 calling const member function via const pointer
#include <functional>
struct foo
{
void f(int) const { }
void g() const
{
auto mf = std::mem_fn(&foo::f);
mf(this, 1);
}
};