[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