From: Douglas Gregor Date: Wed, 5 Jan 2011 01:10:06 +0000 (+0000) Subject: Use Parser::ExpectAndConsume() uniformly to eat semicolons after X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e6bf90aec0044342ffccd13201b8a3a31a985a4b;p=clang Use Parser::ExpectAndConsume() uniformly to eat semicolons after Objective-C declarations and statements. Fixes (wrong source line for diagnostics about missing ';'), and now we actually consume the ';' at the end of a @compatibility_alias directive! git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@122855 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Parse/ParseObjc.cpp b/lib/Parse/ParseObjc.cpp index e1c36e8eaa..2d293c5aeb 100644 --- a/lib/Parse/ParseObjc.cpp +++ b/lib/Parse/ParseObjc.cpp @@ -1398,10 +1398,8 @@ Decl *Parser::ParseObjCAtAliasDeclaration(SourceLocation atLoc) { } IdentifierInfo *classId = Tok.getIdentifierInfo(); SourceLocation classLoc = ConsumeToken(); // consume class-name; - if (Tok.isNot(tok::semi)) { - Diag(Tok, diag::err_expected_semi_after) << "@compatibility_alias"; - return 0; - } + ExpectAndConsume(tok::semi, diag::err_expected_semi_after, + "@compatibility_alias"); return Actions.ActOnCompatiblityAlias(atLoc, aliasId, aliasLoc, classId, classLoc); } @@ -1461,12 +1459,7 @@ Decl *Parser::ParseObjCPropertySynthesize(SourceLocation atLoc) { break; ConsumeToken(); // consume ',' } - if (Tok.isNot(tok::semi)) { - Diag(Tok, diag::err_expected_semi_after) << "@synthesize"; - SkipUntil(tok::semi); - } - else - ConsumeToken(); // consume ';' + ExpectAndConsume(tok::semi, diag::err_expected_semi_after, "@synthesize"); return 0; } @@ -1502,12 +1495,7 @@ Decl *Parser::ParseObjCPropertyDynamic(SourceLocation atLoc) { break; ConsumeToken(); // consume ',' } - if (Tok.isNot(tok::semi)) { - Diag(Tok, diag::err_expected_semi_after) << "@dynamic"; - SkipUntil(tok::semi); - } - else - ConsumeToken(); // consume ';' + ExpectAndConsume(tok::semi, diag::err_expected_semi_after, "@dynamic"); return 0; } diff --git a/test/Parser/objc-property-syntax.m b/test/Parser/objc-property-syntax.m index 064a2090b0..6ef2ad7c52 100644 --- a/test/Parser/objc-property-syntax.m +++ b/test/Parser/objc-property-syntax.m @@ -1,14 +1,17 @@ // RUN: %clang_cc1 -fsyntax-only -verify %s @interface MyClass { - + int prop; }; @property unsigned char bufferedUTF8Bytes[4]; // expected-error {{property cannot have array or function type}} @property unsigned char bufferedUTFBytes:1; // expected-error {{property name cannot be a bitfield}} @property(nonatomic, retain, setter=ab_setDefaultToolbarItems) MyClass *ab_defaultToolbarItems; // expected-error {{method name referenced in property setter attribute must end with ':'}} + +@property int prop; @end @implementation MyClass -@dynamic ab_defaultToolbarItems; +@dynamic ab_defaultToolbarItems // expected-error{{expected ';' after @dynamic}} +@synthesize prop // expected-error{{expected ';' after @synthesize}} @end diff --git a/test/Parser/objc-quirks.m b/test/Parser/objc-quirks.m index b6671d1cf9..591bca222a 100644 --- a/test/Parser/objc-quirks.m +++ b/test/Parser/objc-quirks.m @@ -1,4 +1,4 @@ -// RUN: %clang_cc1 -fsyntax-only -verify %s +// RUN: %clang_cc1 -fsyntax-only -verify -pedantic %s // FIXME: This is a horrible error message here. Fix. int @"s" = 5; // expected-error {{prefix attribute must be}} @@ -6,7 +6,9 @@ int @"s" = 5; // expected-error {{prefix attribute must be}} // rdar://6480479 @interface A -}; // expected-error {{missing @end}} expected-error {{expected external declaration}} +}; // expected-error {{missing @end}} \ +// expected-error {{expected external declaration}} \ +// expected-warning{{extra ';' outside of a function}} @@ -26,3 +28,5 @@ int @"s" = 5; // expected-error {{prefix attribute must be}} [(super) a]; // expected-error {{use of undeclared identifier 'super'}} } @end + +@compatibility_alias A3 A2;