mirror of git://gcc.gnu.org/git/gcc.git
In gcc/: 2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com>
In gcc/: 2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com> PR objc/47078 * c-parser.c (c_parser_objc_type_name): If the type is unknown, for error recovery purposes behave as if it was not specified so that the default type is usd. In gcc/testsuite/: 2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com> PR objc/47078 * objc.dg/invalid-method-2.m: New. * obj-c++.dg/invalid-method-2.mm: New. In gcc/cp/: 2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com> PR objc/47078 * parser.c (cp_parser_objc_typename): If the type is unknown, for error recovery purposes behave as if it was not specified so that the default type is used. From-SVN: r168601
This commit is contained in:
parent
f1f39033ac
commit
046608a3e0
|
|
@ -1,3 +1,10 @@
|
||||||
|
2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com>
|
||||||
|
|
||||||
|
PR objc/47078
|
||||||
|
* c-parser.c (c_parser_objc_type_name): If the type is unknown,
|
||||||
|
for error recovery purposes behave as if it was not specified so
|
||||||
|
that the default type is usd.
|
||||||
|
|
||||||
2011-01-07 Jan Hubicka <jh@suse.cz>
|
2011-01-07 Jan Hubicka <jh@suse.cz>
|
||||||
|
|
||||||
PR tree-optmization/46469
|
PR tree-optmization/46469
|
||||||
|
|
|
||||||
|
|
@ -7482,6 +7482,14 @@ c_parser_objc_type_name (c_parser *parser)
|
||||||
type_name = c_parser_type_name (parser);
|
type_name = c_parser_type_name (parser);
|
||||||
if (type_name)
|
if (type_name)
|
||||||
type = groktypename (type_name, NULL, NULL);
|
type = groktypename (type_name, NULL, NULL);
|
||||||
|
|
||||||
|
/* If the type is unknown, and error has already been produced and
|
||||||
|
we need to recover from the error. In that case, use NULL_TREE
|
||||||
|
for the type, as if no type had been specified; this will use the
|
||||||
|
default type ('id') which is good for error recovery. */
|
||||||
|
if (type == error_mark_node)
|
||||||
|
type = NULL_TREE;
|
||||||
|
|
||||||
return build_tree_list (quals, type);
|
return build_tree_list (quals, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,10 @@
|
||||||
|
2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com>
|
||||||
|
|
||||||
|
PR objc/47078
|
||||||
|
* parser.c (cp_parser_objc_typename): If the type is unknown, for
|
||||||
|
error recovery purposes behave as if it was not specified so that
|
||||||
|
the default type is used.
|
||||||
|
|
||||||
2011-01-07 Jakub Jelinek <jakub@redhat.com>
|
2011-01-07 Jakub Jelinek <jakub@redhat.com>
|
||||||
|
|
||||||
PR c++/47022
|
PR c++/47022
|
||||||
|
|
|
||||||
|
|
@ -21915,7 +21915,25 @@ cp_parser_objc_typename (cp_parser* parser)
|
||||||
/* An ObjC type name may consist of just protocol qualifiers, in which
|
/* An ObjC type name may consist of just protocol qualifiers, in which
|
||||||
case the type shall default to 'id'. */
|
case the type shall default to 'id'. */
|
||||||
if (cp_lexer_next_token_is_not (parser->lexer, CPP_CLOSE_PAREN))
|
if (cp_lexer_next_token_is_not (parser->lexer, CPP_CLOSE_PAREN))
|
||||||
cp_type = cp_parser_type_id (parser);
|
{
|
||||||
|
cp_type = cp_parser_type_id (parser);
|
||||||
|
|
||||||
|
/* If the type could not be parsed, an error has already
|
||||||
|
been produced. For error recovery, behave as if it had
|
||||||
|
not been specified, which will use the default type
|
||||||
|
'id'. */
|
||||||
|
if (cp_type == error_mark_node)
|
||||||
|
{
|
||||||
|
cp_type = NULL_TREE;
|
||||||
|
/* We need to skip to the closing parenthesis as
|
||||||
|
cp_parser_type_id() does not seem to do it for
|
||||||
|
us. */
|
||||||
|
cp_parser_skip_to_closing_parenthesis (parser,
|
||||||
|
/*recovering=*/true,
|
||||||
|
/*or_comma=*/false,
|
||||||
|
/*consume_paren=*/false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
cp_parser_require (parser, CPP_CLOSE_PAREN, RT_CLOSE_PAREN);
|
cp_parser_require (parser, CPP_CLOSE_PAREN, RT_CLOSE_PAREN);
|
||||||
type_name = build_tree_list (proto_quals, cp_type);
|
type_name = build_tree_list (proto_quals, cp_type);
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,9 @@
|
||||||
|
2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com>
|
||||||
|
|
||||||
|
PR objc/47078
|
||||||
|
* objc.dg/invalid-method-2.m: New.
|
||||||
|
* obj-c++.dg/invalid-method-2.mm: New.
|
||||||
|
|
||||||
2011-01-08 Paul Thomas <pault@gcc.gnu.org>
|
2011-01-08 Paul Thomas <pault@gcc.gnu.org>
|
||||||
|
|
||||||
PR fortran/46896
|
PR fortran/46896
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,18 @@
|
||||||
|
/* { dg-do compile } */
|
||||||
|
|
||||||
|
/* Test that using an invalid type in a method declaration produces a
|
||||||
|
friendly error without a compiler crash. */
|
||||||
|
|
||||||
|
@interface MyClass
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation MyClass
|
||||||
|
- (x) method /* { dg-error "expected" } */
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
- (id) method2: (x)argument /* { dg-error "expected" } */
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@end
|
||||||
|
|
@ -0,0 +1,18 @@
|
||||||
|
/* { dg-do compile } */
|
||||||
|
|
||||||
|
/* Test that using an invalid type in a method declaration produces a
|
||||||
|
friendly error without a compiler crash. */
|
||||||
|
|
||||||
|
@interface MyClass
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation MyClass
|
||||||
|
- (x) method /* { dg-error "unknown type name" } */
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
- (id) method2: (x)argument /* { dg-error "unknown type name" } */
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@end
|
||||||
Loading…
Reference in New Issue