]> granicus.if.org Git - clang/commitdiff
'self.myIvar = nil' (properties) only releases myIvar when the property has kind...
authorTed Kremenek <kremenek@apple.com>
Mon, 8 Dec 2008 21:44:15 +0000 (21:44 +0000)
committerTed Kremenek <kremenek@apple.com>
Mon, 8 Dec 2008 21:44:15 +0000 (21:44 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@60717 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/CheckObjCDealloc.cpp

index a9e5675ce212325c75fb53f54b67e4a52041755f..dda25017c34eceec14a1dbd74fb9e760cd10de3a 100644 (file)
@@ -73,8 +73,11 @@ static bool scan_ivar_release(Stmt* S, ObjCIvarDecl* ID,
       if(ObjCPropertyRefExpr* PRE = 
          dyn_cast<ObjCPropertyRefExpr>(BO->getLHS()->IgnoreParenCasts()))
           if(PRE->getProperty() == PD)
-            if(BO->getRHS()->isNullPointerConstant(Ctx))
-              return true;
+            if(BO->getRHS()->isNullPointerConstant(Ctx)) {
+              // This is only a 'release' if the property kind is not
+              // 'assign'.
+              return PD->getSetterKind() != ObjCPropertyDecl::Assign;;
+            }
   
   // Recurse to children.
   for (Stmt::child_iterator I = S->child_begin(), E= S->child_end(); I!=E; ++I)