]> granicus.if.org Git - clang/commitdiff
[Sema] Fix crash-on-invalid-code issue:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>
Fri, 2 Mar 2012 19:14:29 +0000 (19:14 +0000)
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>
Fri, 2 Mar 2012 19:14:29 +0000 (19:14 +0000)
@class I;
@implementation I(cat) // crashes here
@end

rdar://10968158

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151931 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/DeclObjC.cpp
lib/Sema/SemaDeclObjC.cpp
test/SemaObjC/category-1.m

index 996e93a8f95ca508ffa8d7f5828bb62de679dd32..7822eb217fea7c54f650f74c05cd365a89ef4bef 100644 (file)
@@ -806,6 +806,10 @@ ObjCIvarDecl *ObjCInterfaceDecl::all_declared_ivar_begin() {
 ///
 ObjCCategoryDecl *
 ObjCInterfaceDecl::FindCategoryDeclaration(IdentifierInfo *CategoryId) const {
+  // FIXME: Should make sure no callers ever do this.
+  if (!hasDefinition())
+    return 0;
+
   if (data().ExternallyCompleted)
     LoadExternalDefinition();
 
index 9b492600ca1cedacac2da9842447e67454ab66ff..4df5ab39168fef4327550c0803d2a218c004bf98 100644 (file)
@@ -820,7 +820,7 @@ Decl *Sema::ActOnStartCategoryImplementation(
                       IdentifierInfo *CatName, SourceLocation CatLoc) {
   ObjCInterfaceDecl *IDecl = getObjCInterfaceDecl(ClassName, ClassLoc, true);
   ObjCCategoryDecl *CatIDecl = 0;
-  if (IDecl) {
+  if (IDecl && IDecl->hasDefinition()) {
     CatIDecl = IDecl->FindCategoryDeclaration(CatName);
     if (!CatIDecl) {
       // Category @implementation with no corresponding @interface.
index 137309f755d6895f9250d6d215a28a2002dc75e0..d5ca0e213a0914e9e988e880088f9157c4e7c8b1 100644 (file)
@@ -95,3 +95,7 @@
 @synthesize name = _name;
 @end
 
+// rdar://10968158
+@class I; // expected-note {{forward declaration}}
+@implementation I(cat) // expected-error{{cannot find interface declaration}}
+@end