From: abutcher Date: Mon, 23 Sep 2013 22:43:44 +0000 (+0000) Subject: Fix 58500. X-Git-Tag: upstream/4.9.2~4103 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=bd0e09febecbbad553ec244811461708cf2c1589;p=platform%2Fupstream%2Flinaro-gcc.git Fix 58500. gcc/cp/ PR c++/58500 * type-utils.h (find_type_usage): Only traverse one type level into member function pointers. gcc/testsuite/ PR c++/58500 * g++.dg/cpp1y/pr58500.C: New testcase. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@202851 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 380fae9..ec40ed5 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,11 @@ 2013-09-23 Adam Butcher + PR c++/58500 + * type-utils.h (find_type_usage): Only traverse one type level into + member function pointers. + +2013-09-23 Adam Butcher + * parser.c (cp_parser_init_declarator): Defer calling finish_fully_implicit_template for forward declarations until after other decl processing is complete. Cleanup for clarity: Extract 'else' diff --git a/gcc/cp/type-utils.h b/gcc/cp/type-utils.h index 3e82ca4..2febce7 100644 --- a/gcc/cp/type-utils.h +++ b/gcc/cp/type-utils.h @@ -47,7 +47,7 @@ find_type_usage (tree t, bool (*pred) (const_tree)) if (TYPE_PTRMEMFUNC_P (t)) return find_type_usage - (TREE_TYPE (TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (t))), pred); + (TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (t)), pred); return NULL_TREE; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8a19710..4101cc2 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-09-23 Adam Butcher + + PR c++/58500 + * g++.dg/cpp1y/pr58500.C: New testcase. + 2013-09-23 Eric Botcazou * gnat.dg/opt28.ad[sb]: New test. diff --git a/gcc/testsuite/g++.dg/cpp1y/pr58500.C b/gcc/testsuite/g++.dg/cpp1y/pr58500.C new file mode 100644 index 0000000..b9d4a26 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp1y/pr58500.C @@ -0,0 +1,8 @@ +// { dg-do compile } +// { dg-options "-std=gnu++1y" } + +// PR c++/58500 + +struct A {}; + +void foo(auto (A::*)());