summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-12-01 15:37:53 +0000
committerDouglas Gregor <dgregor@apple.com>2011-12-01 15:37:53 +0000
commit11bb3084575f9d545f7030bf6a98682becf6f1ef (patch)
tree7bb1cda580226fcd9ec977702c548efcc7e19598
parentb8e6cee9cadfe1e2704e3e0575e803870224c4b6 (diff)
downloadbcm5719-llvm-11bb3084575f9d545f7030bf6a98682becf6f1ef.tar.gz
bcm5719-llvm-11bb3084575f9d545f7030bf6a98682becf6f1ef.zip
When typo-correction an Objective-C superclass name, don't
typo-correct to ourselves. llvm-svn: 145583
-rw-r--r--clang/lib/Sema/SemaDeclObjC.cpp13
-rw-r--r--clang/test/SemaObjC/class-def-test-1.m4
2 files changed, 12 insertions, 5 deletions
diff --git a/clang/lib/Sema/SemaDeclObjC.cpp b/clang/lib/Sema/SemaDeclObjC.cpp
index 667a12fea44..49fcfbf2f37 100644
--- a/clang/lib/Sema/SemaDeclObjC.cpp
+++ b/clang/lib/Sema/SemaDeclObjC.cpp
@@ -417,10 +417,15 @@ ActOnStartClassInterface(SourceLocation AtInterfaceLoc,
DeclarationNameInfo(SuperName, SuperLoc), LookupOrdinaryName, TUScope,
NULL, NULL, false, CTC_NoKeywords);
if ((PrevDecl = Corrected.getCorrectionDeclAs<ObjCInterfaceDecl>())) {
- Diag(SuperLoc, diag::err_undef_superclass_suggest)
- << SuperName << ClassName << PrevDecl->getDeclName();
- Diag(PrevDecl->getLocation(), diag::note_previous_decl)
- << PrevDecl->getDeclName();
+ if (PrevDecl == IDecl) {
+ // Don't correct to the class we're defining.
+ PrevDecl = 0;
+ } else {
+ Diag(SuperLoc, diag::err_undef_superclass_suggest)
+ << SuperName << ClassName << PrevDecl->getDeclName();
+ Diag(PrevDecl->getLocation(), diag::note_previous_decl)
+ << PrevDecl->getDeclName();
+ }
}
}
diff --git a/clang/test/SemaObjC/class-def-test-1.m b/clang/test/SemaObjC/class-def-test-1.m
index 95a259bd527..0d114b99fb6 100644
--- a/clang/test/SemaObjC/class-def-test-1.m
+++ b/clang/test/SemaObjC/class-def-test-1.m
@@ -30,4 +30,6 @@ typedef NSObject TD_NSObject;
@interface XCElementUnit : TD_NSObject {}
@end
-
+// Make sure we don't typo-correct to ourselves.
+@interface SomeClassSub : SomeClassSup // expected-error{{cannot find interface declaration for 'SomeClassSup', superclass of 'SomeClassSub'}}
+@end
OpenPOWER on IntegriCloud