[cfe-commits] r144556 - in /cfe/trunk: lib/Analysis/AnalysisDeclContext.cpp test/Analysis/misc-ps.m

Ted Kremenek kremenek at apple.com
Mon Nov 14 11:36:08 PST 2011


Author: kremenek
Date: Mon Nov 14 13:36:08 2011
New Revision: 144556

URL: http://llvm.org/viewvc/llvm-project?rev=144556&view=rev
Log:
[analyzer] teach AnalysisDeclContext::getSelfDecl() about blocks that capture the 'self' variable of the enclosing ObjC method decl.  Fixes <rdar://problem/10380300>.

Modified:
    cfe/trunk/lib/Analysis/AnalysisDeclContext.cpp
    cfe/trunk/test/Analysis/misc-ps.m

Modified: cfe/trunk/lib/Analysis/AnalysisDeclContext.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Analysis/AnalysisDeclContext.cpp?rev=144556&r1=144555&r2=144556&view=diff
==============================================================================
--- cfe/trunk/lib/Analysis/AnalysisDeclContext.cpp (original)
+++ cfe/trunk/lib/Analysis/AnalysisDeclContext.cpp Mon Nov 14 13:36:08 2011
@@ -95,6 +95,15 @@
 const ImplicitParamDecl *AnalysisDeclContext::getSelfDecl() const {
   if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D))
     return MD->getSelfDecl();
+  if (const BlockDecl *BD = dyn_cast<BlockDecl>(D)) {
+    // See if 'self' was captured by the block.
+    for (BlockDecl::capture_const_iterator it = BD->capture_begin(),
+         et = BD->capture_end(); it != et; ++it) {
+      const VarDecl *VD = it->getVariable();
+      if (VD->getName() == "self")
+        return dyn_cast<ImplicitParamDecl>(VD);
+    }    
+  }
 
   return NULL;
 }

Modified: cfe/trunk/test/Analysis/misc-ps.m
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/misc-ps.m?rev=144556&r1=144555&r2=144556&view=diff
==============================================================================
--- cfe/trunk/test/Analysis/misc-ps.m (original)
+++ cfe/trunk/test/Analysis/misc-ps.m Mon Nov 14 13:36:08 2011
@@ -1321,3 +1321,16 @@
 @implementation RDar9465344
 @end
 
+// Don't crash when analyzing access to 'self' within a block.
+ at interface Rdar10380300Base 
+- (void) foo;
+ at end
+ at interface Rdar10380300 : Rdar10380300Base @end
+ at implementation Rdar10380300
+- (void)foo {
+  ^{
+    [super foo];
+  }();
+}
+ at end
+





More information about the cfe-commits mailing list