diff options
author | Paolo Carlini <paolo.carlini@oracle.com> | 2010-09-15 09:06:32 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2010-09-15 09:06:32 +0000 |
commit | 6809f4b50e4832e87fc3d68c3a813f8c6b4a17ee (patch) | |
tree | 42c7eaaecea214d2ce95be1f7d1c1b6d4c01ef5b /gcc | |
parent | 1093719080cda3aedc8a17dfa379def891044ba7 (diff) | |
download | gcc-6809f4b50e4832e87fc3d68c3a813f8c6b4a17ee.zip gcc-6809f4b50e4832e87fc3d68c3a813f8c6b4a17ee.tar.gz gcc-6809f4b50e4832e87fc3d68c3a813f8c6b4a17ee.tar.bz2 |
re PR c++/45665 (ICE: tree check: expected class 'type', have 'exceptional' (error_mark) in grokdeclarator, at cp/decl.c:8797 on invalid code)
/cp
2010-09-15 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/45665
* decl.c (grokdeclarator): Check build_memfn_type return value
for error_mark_node.
/testsuite
2010-09-15 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/45665
* g++.dg/template/crash103.C: New.
From-SVN: r164299
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/cp/decl.c | 2 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 9 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/template/crash103.C | 4 |
4 files changed, 19 insertions, 2 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ee9944c..20887a0 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2010-09-15 Paolo Carlini <paolo.carlini@oracle.com> + + PR c++/45665 + * decl.c (grokdeclarator): Check build_memfn_type return value + for error_mark_node. + 2010-09-13 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com> * semantics.c (finish_for_stmt): Always test flag_new_for_scope. diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 8ca69da..3d1420a 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -8762,6 +8762,8 @@ grokdeclarator (const cp_declarator *declarator, type = build_memfn_type (type, declarator->u.pointer.class_type, memfn_quals); + if (type == error_mark_node) + return error_mark_node; memfn_quals = TYPE_UNQUALIFIED; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index dc91d21..72f7e71 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-09-15 Paolo Carlini <paolo.carlini@oracle.com> + + PR c++/45665 + * g++.dg/template/crash103.C: New. + 2010-09-15 Nicola Pero <nicola.pero@meta-innovation.com> Merge from 'apple/trunk' branch on FSF servers. @@ -12,7 +17,7 @@ Radar 4219590 * objc.dg/break-in-ifstmt.m: New. - + 2005-08-22 Ziemowit Laski <zlaski@apple.com> Radar 4174166 @@ -24,7 +29,7 @@ Radar 4216500 * obj-c++.dg/proto-lossage-7.mm: New. * objc.dg/proto-lossage-7.m: New. - + 2010-09-14 Jan Hubicka <jh@suse.cz> * gfortran.dg/vect/fast-math-pr38968.f90: Add common to prevent diff --git a/gcc/testsuite/g++.dg/template/crash103.C b/gcc/testsuite/g++.dg/template/crash103.C new file mode 100644 index 0000000..9f3e224 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/crash103.C @@ -0,0 +1,4 @@ +// PR c++/45665 + +template < typename > struct S; +void (S <0>::*ptr) (); // { dg-error "type" } |