Message ID | 0EFAB2BDD0F67E4FB6CCC8B9F87D756969ACB196@IRSMSX101.ger.corp.intel.com |
---|---|
State | New |
Headers | show |
On 07/31/14 13:51, Zamyatin, Igor wrote: > Hi! > > This patch fixes the ICE on invalid code by adding missed check for error_mark_node. > > Regtested on x86_64. Ok for trunk/4.9? > > Thanks, > Igor > > Changelog: > > gcc/cp: > > 2014-07-31 Igor Zamyatin <igor.zamyatin@intel.com> > > PR other/61963 > * parser.c (cp_parser_array_notation): Added check for array_type. > > > gcc/testsuite: > > 2014-07-31 Igor Zamyatin <igor.zamyatin@intel.com> > > PR other/61963 > * c-c++-common/cilk-plus/AN/pr61963.c: New test. This is fine too. Thanks, Jeff
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index 32c7a3f..be071a8 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -6376,7 +6376,7 @@ cp_parser_array_notation (location_t loc, cp_parser *parser, tree *init_index, parser->colon_corrects_to_scope_p = saved_colon_corrects; if (*init_index == error_mark_node || length_index == error_mark_node - || stride == error_mark_node) + || stride == error_mark_node || array_type == error_mark_node) { if (cp_lexer_peek_token (parser->lexer)->type == CPP_CLOSE_SQUARE) cp_lexer_consume_token (parser->lexer); diff --git a/gcc/testsuite/c-c++-common/cilk-plus/AN/pr61963.c b/gcc/testsuite/c-c++-common/cilk-plus/AN/pr61963. new file mode 100644 index 0000000..dfa713c --- /dev/null +++ b/gcc/testsuite/c-c++-common/cilk-plus/AN/pr61963.c @@ -0,0 +1,9 @@ +/* PR other/61963 */ +/* { dg-do compile } */ +/* { dg-options "-fcilkplus" } */ + +void f (int * int *a) /* { dg-error "expected" } */ +{ + a[0:64] = 0; /* { dg-error "was not declared" "" { target c++ } 7 } */ + a[0:64] = 0; +}