diff options
-rw-r--r-- | lib/Parse/ParseObjc.cpp | 3 | ||||
-rw-r--r-- | test/SemaObjC/selector-1.m | 8 |
2 files changed, 10 insertions, 1 deletions
diff --git a/lib/Parse/ParseObjc.cpp b/lib/Parse/ParseObjc.cpp index 338e770cd6..8bb6e114d9 100644 --- a/lib/Parse/ParseObjc.cpp +++ b/lib/Parse/ParseObjc.cpp @@ -687,7 +687,8 @@ Parser::DeclTy *Parser::ParseObjCMethodDecl(SourceLocation mLoc, SourceLocation selLoc; IdentifierInfo *SelIdent = ParseObjCSelector(selLoc); - if (!SelIdent) { // missing selector name. + // An unnamed colon is valid. + if (!SelIdent && Tok.isNot(tok::colon)) { // missing selector name. Diag(Tok, diag::err_expected_selector_for_method) << SourceRange(mLoc, Tok.getLocation()); // Skip until we get a ; or {}. diff --git a/test/SemaObjC/selector-1.m b/test/SemaObjC/selector-1.m index 476568f6ca..1fd1d444a1 100644 --- a/test/SemaObjC/selector-1.m +++ b/test/SemaObjC/selector-1.m @@ -1,5 +1,13 @@ // RUN: clang -verify %s +@interface Lancelot @end +@implementation Lancelot + +- (void):(int)x {} +- (void)xx:(int)x :(int)y { } + +@end + int main() { SEL s = @selector(retain); SEL s1 = @selector(meth1:); |