From: Dodji Seketeli Date: Mon, 19 Dec 2011 09:47:46 +0000 (+0000) Subject: PR c++/51477 - ICE with invalid NSDMI X-Git-Tag: releases/gcc-4.7.0~1455 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=7063212f9a3b6db6ae912451963cc184ceff94ea;p=thirdparty%2Fgcc.git PR c++/51477 - ICE with invalid NSDMI gcc/cp/ PR c++/51477 * search.c (lookup_member): Get out early on invalid base type. gcc/testsuite/ PR c++/51477 * g++.dg/cpp0x/nsdmi6.C: New test. From-SVN: r182474 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6f1bc26c9a91..640bf9a90922 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2011-12-19 Dodji Seketeli + + PR c++/51477 + * search.c (lookup_member): Get out early on invalid base type. + 2011-12-19 Jason Merrill PR c++/51489 diff --git a/gcc/cp/search.c b/gcc/cp/search.c index 3894c6858842..0ceb5bc14f8d 100644 --- a/gcc/cp/search.c +++ b/gcc/cp/search.c @@ -1171,7 +1171,9 @@ lookup_member (tree xbasetype, tree name, int protect, bool want_type, const char *errstr = 0; - if (name == error_mark_node) + if (name == error_mark_node + || xbasetype == NULL_TREE + || xbasetype == error_mark_node) return NULL_TREE; gcc_assert (TREE_CODE (name) == IDENTIFIER_NODE); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 936ef1ae2334..a8c71f2d0a97 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2011-12-19 Dodji Seketeli + + PR c++/51477 + * g++.dg/cpp0x/nsdmi6.C: New test. + 2011-12-19 Tobias Burnus * gfortran.dg/coarray_poly_3.f90: New. diff --git a/gcc/testsuite/g++.dg/cpp0x/nsdmi6.C b/gcc/testsuite/g++.dg/cpp0x/nsdmi6.C new file mode 100644 index 000000000000..bb455e778e4c --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/nsdmi6.C @@ -0,0 +1,8 @@ +// Origin PR c++/51477 +// { dg-options "-std=c++11" } + +struct A +{ + typedef int int T; // { dg-error "two or more data types in declaration" } + struct T x[1] = { 0 }; // { dg-error "invalid|forward" } +};