From f4c6616d9dd65a0c364d80ade1dd5618457e8d82 Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Fri, 9 Jan 2009 01:04:21 +0000 Subject: [PATCH] Fix crash on null deference when searching for readwrite properties in categories. - Also, simplify nesting via early return. llvm-svn: 61968 --- clang/lib/AST/DeclObjC.cpp | 28 ++++++++++++----------- clang/test/SemaObjC/property-category-1.m | 17 ++++++++++++++ 2 files changed, 32 insertions(+), 13 deletions(-) diff --git a/clang/lib/AST/DeclObjC.cpp b/clang/lib/AST/DeclObjC.cpp index 194544f9fa81..cf3bd0abeaf4 100644 --- a/clang/lib/AST/DeclObjC.cpp +++ b/clang/lib/AST/DeclObjC.cpp @@ -252,24 +252,26 @@ void ObjCMethodDecl::setMethodParams(ParmVarDecl **NewParamInfo, } } -/// isPropertyReadonly - Return true if property is a readonly, by seaching +/// isPropertyReadonly - Return true if property is readonly, by searching /// for the property in the class and in its categories. /// bool ObjCInterfaceDecl::isPropertyReadonly(ObjCPropertyDecl *PDecl) const { - if (PDecl->isReadOnly()) { - // Main class has the property as 'readyonly'. Must search - // through the category list to see if the property's - // attribute has been over-ridden to 'readwrite'. - for (ObjCCategoryDecl *Category = getCategoryList(); - Category; Category = Category->getNextClassCategory()) { - PDecl= Category->FindPropertyDeclaration(PDecl->getIdentifier()); - if (PDecl && !PDecl->isReadOnly()) - return false; - } - return true; + if (!PDecl->isReadOnly()) + return false; + + // Main class has the property as 'readonly'. Must search + // through the category list to see if the property's + // attribute has been over-ridden to 'readwrite'. + for (ObjCCategoryDecl *Category = getCategoryList(); + Category; Category = Category->getNextClassCategory()) { + ObjCPropertyDecl *P = + Category->FindPropertyDeclaration(PDecl->getIdentifier()); + if (P && !P->isReadOnly()) + return false; } - return false; + + return true; } /// FindPropertyDeclaration - Finds declaration of the property given its name diff --git a/clang/test/SemaObjC/property-category-1.m b/clang/test/SemaObjC/property-category-1.m index 32e14f00c19d..926f96420250 100644 --- a/clang/test/SemaObjC/property-category-1.m +++ b/clang/test/SemaObjC/property-category-1.m @@ -33,3 +33,20 @@ int main(int argc, char **argv) { return test.object - 12345 + test.Anotherobject - 200; } +/// + +@interface I0 +@property(readonly) int p0; +@end + +@interface I0 (Cat0) +@end + +@interface I0 (Cat1) +@end + +@implementation I0 +- (void) foo { + self.p0 = 0; // expected-error {{assigning to property with 'readonly' attribute not allowed}} +} +@end