aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2012-09-12 16:50:30 +0000
committerTed Kremenek <kremenek@apple.com>2012-09-12 16:50:30 +0000
commite62b1295ec71d4f0ca05b973e88d4b4e858eb96e (patch)
tree35225c1f49e495f4f54871e68d18c0d40d1e095e
parent0098d23677f498e650c5ecc5ee7425d81bf6117b (diff)
Revert "objective-C: warn if selector has nothing but bare"
We plan on discussing this more. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@163719 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/clang/Basic/DiagnosticParseKinds.td3
-rw-r--r--lib/Parse/ParseObjc.cpp9
-rw-r--r--test/SemaObjC/warn-missing-selector-arg-name.m11
3 files changed, 4 insertions, 19 deletions
diff --git a/include/clang/Basic/DiagnosticParseKinds.td b/include/clang/Basic/DiagnosticParseKinds.td
index ccdea4aabb..5f8e8aa3ac 100644
--- a/include/clang/Basic/DiagnosticParseKinds.td
+++ b/include/clang/Basic/DiagnosticParseKinds.td
@@ -361,9 +361,6 @@ def warn_missing_argument_name : Warning<
"no parameter name in the middle of a selector"
" may result in incomplete selector name">,
InGroup<DiagGroup<"missing-argument-name-in-selector">>, DefaultIgnore;
-def warn_selector_with_bare_colon : Warning<
- "selector has only bare colons in its name">,
- InGroup<DiagGroup<"selector-with-bare-colons">>, DefaultIgnore;
def note_missing_argument_name : Note<
"did you mean %0 as the selector name">;
diff --git a/lib/Parse/ParseObjc.cpp b/lib/Parse/ParseObjc.cpp
index 2bcb7a786a..6d5f35a799 100644
--- a/lib/Parse/ParseObjc.cpp
+++ b/lib/Parse/ParseObjc.cpp
@@ -1032,7 +1032,6 @@ Decl *Parser::ParseObjCMethodDecl(SourceLocation mLoc,
AttributePool allParamAttrs(AttrFactory);
bool warnSelectorName = false;
- bool warnHasNoName = true;
while (1) {
ParsedAttributes paramAttrs(AttrFactory);
Sema::ObjCArgInfo ArgInfo;
@@ -1110,8 +1109,7 @@ Decl *Parser::ParseObjCMethodDecl(SourceLocation mLoc,
Diag(Tok, diag::warn_missing_argument_name); // missing argument name.
warnSelectorName = true;
}
- else
- warnHasNoName = false;
+
// We have a selector or a colon, continue parsing.
}
@@ -1152,11 +1150,8 @@ Decl *Parser::ParseObjCMethodDecl(SourceLocation mLoc,
Selector Sel = PP.getSelectorTable().getSelector(KeyIdents.size(),
&KeyIdents[0]);
- if (warnSelectorName) {
- if (warnHasNoName)
- Diag(mLoc, diag::warn_selector_with_bare_colon);
+ if (warnSelectorName)
Diag(mLoc, diag::note_missing_argument_name) << Sel.getAsString();
- }
Decl *Result
= Actions.ActOnMethodDeclaration(getCurScope(), mLoc, Tok.getLocation(),
diff --git a/test/SemaObjC/warn-missing-selector-arg-name.m b/test/SemaObjC/warn-missing-selector-arg-name.m
index 3d2a75a1eb..97bcd0db91 100644
--- a/test/SemaObjC/warn-missing-selector-arg-name.m
+++ b/test/SemaObjC/warn-missing-selector-arg-name.m
@@ -1,15 +1,11 @@
-// RUN: %clang_cc1 -fsyntax-only -verify -Wselector-with-bare-colons -Wmissing-argument-name-in-selector %s
-// RUN: %clang_cc1 -x objective-c++ -fsyntax-only -verify -Wselector-with-bare-colons -Wmissing-argument-name-in-selector %s
-// rdar://8366823
+// RUN: %clang_cc1 -fsyntax-only -verify -Wno-objc-root-class -Wmissing-argument-name-in-selector %s
+// RUN: %clang_cc1 -x objective-c++ -fsyntax-only -verify -Wno-objc-root-class -Wmissing-argument-name-in-selector %s
// rdar://12263549
@interface Super @end
@interface INTF : Super
-- (void) MMM;
-- (void)bar:(id)b;
-(void) Name1:(id)Arg1 Name2:(id)Arg2; // Name1:Name2:
-(void) Name1:(id) Name2:(id)Arg2; // expected-warning {{no parameter name in the middle of a selector may result in incomplete selector name}} \
- // expected-warning {{selector has only bare colons in its name}} \
// expected-note {{did you mean Name1:: as the selector name}}
-(void) Name1:(id)Arg1 Name2:(id)Arg2 Name3:(id)Arg3; // Name1:Name2:Name3:
-(void) Name1:(id)Arg1 Name2:(id) Name3:(id)Arg3; // expected-warning {{no parameter name in the middle of a selector may result in incomplete selector name}} \
@@ -17,11 +13,8 @@
@end
@implementation INTF
-- (void) MMM{}
-- (void)bar:(id)b{}
-(void) Name1:(id)Arg1 Name2:(id)Arg2{}
-(void) Name1:(id) Name2:(id)Arg2 {} // expected-warning {{no parameter name in the middle of a selector may result in incomplete selector name}} \
- // expected-warning {{selector has only bare colons in its name}} \
// expected-note {{did you mean Name1:: as the selector name}}
-(void) Name1:(id)Arg1 Name2:(id)Arg2 Name3:(id)Arg3 {}
-(void) Name1:(id)Arg1 Name2:(id) Name3:(id)Arg3 {} // expected-warning {{no parameter name in the middle of a selector may result in incomplete selector name}} \