Commit 9d780cb2 by Nicola Pero Committed by Nicola Pero

In gcc/cp/: 2010-11-27 Nicola Pero <nicola.pero@meta-innovation.com>

In gcc/cp/:
2010-11-27  Nicola Pero  <nicola.pero@meta-innovation.com>

	PR objc++/46222
	* decl.c (grokdeclarator): Replaced an assert (for a case that can
	never happen in C++, but could happen in ObjC++ for invalid code)
	with a check that prints an error message and returns
	error_mark_node.

In gcc/testsuite/:
2010-11-27  Nicola Pero  <nicola.pero@meta-innovation.com>

	PR objc++/46222	
	* obj-c++.dg/property/at-property-2.mm: Uncommented testcase.

From-SVN: r167202
parent 559d6055
2010-11-27 Nicola Pero <nicola.pero@meta-innovation.com>
PR objc++/46222
* decl.c (grokdeclarator): Replaced an assert (for a case that can
never happen in C++, but could happen in ObjC++ for invalid code)
with a check that prints an error message and returns
error_mark_node.
2010-11-23 Jeffrey Yasskin <jyasskin@google.com> 2010-11-23 Jeffrey Yasskin <jyasskin@google.com>
PR c++/46527 PR c++/46527
......
...@@ -9531,7 +9531,21 @@ grokdeclarator (const cp_declarator *declarator, ...@@ -9531,7 +9531,21 @@ grokdeclarator (const cp_declarator *declarator,
if (friendp == 0) if (friendp == 0)
{ {
gcc_assert (ctype); /* This should never happen in pure C++ (the check
could be an assert). It could happen in
Objective-C++ if someone writes invalid code that
uses a function declaration for an instance
variable or property (instance variables and
properties are parsed as FIELD_DECLs, but they are
part of an Objective-C class, not a C++ class).
That code is invalid and is caught by this
check. */
if (!ctype)
{
error ("declaration of function %qD in invalid context",
unqualified_id);
return error_mark_node;
}
/* ``A union may [ ... ] not [ have ] virtual functions.'' /* ``A union may [ ... ] not [ have ] virtual functions.''
ARM 9.5 */ ARM 9.5 */
......
2010-11-27 Nicola Pero <nicola.pero@meta-innovation.com> 2010-11-27 Nicola Pero <nicola.pero@meta-innovation.com>
PR objc++/46222
* obj-c++.dg/property/at-property-2.mm: Uncommented testcase.
2010-11-27 Nicola Pero <nicola.pero@meta-innovation.com>
* objc.dg/property/at-property-24.m: New. * objc.dg/property/at-property-24.m: New.
* objc.dg/property/at-property-25.m: New. * objc.dg/property/at-property-25.m: New.
* obj-c++.dg/property/at-property-24.mm: New. * obj-c++.dg/property/at-property-24.mm: New.
......
...@@ -8,7 +8,6 @@ ...@@ -8,7 +8,6 @@
} }
@property int name __attribute__((deprecated)); @property int name __attribute__((deprecated));
@property int table __attribute__((xxx)); /* { dg-warning ".xxx. attribute directive ignored" } */ @property int table __attribute__((xxx)); /* { dg-warning ".xxx. attribute directive ignored" } */
/* FIXME: the test below should not ICE. @property void function (void); /* { dg-error "declaration of function .function. in invalid context" } */
@property void function (void); { dg-error "can.t make .function. into a method" } */
@property typedef int j; /* { dg-error "invalid type for property" } */ @property typedef int j; /* { dg-error "invalid type for property" } */
@end @end
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment