diff options
author | Ted Kremenek <kremenek@apple.com> | 2009-08-07 21:13:23 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2009-08-07 21:13:23 +0000 |
commit | 0e8e1fde255319bbf491c3fb204419ae2650375d (patch) | |
tree | 891fa94917d65e909cd1c6dc31c2685fa1befcd1 /clang/lib/Analysis/CheckObjCUnusedIVars.cpp | |
parent | d0470d74dfec5c6e4e921c47ecce771e904f8f98 (diff) | |
download | bcm5719-llvm-0e8e1fde255319bbf491c3fb204419ae2650375d.tar.gz bcm5719-llvm-0e8e1fde255319bbf491c3fb204419ae2650375d.zip |
Fix: <rdar://problem/7075531> static analyzer wrongly detects unused ivars used in blocks
llvm-svn: 78409
Diffstat (limited to 'clang/lib/Analysis/CheckObjCUnusedIVars.cpp')
-rw-r--r-- | clang/lib/Analysis/CheckObjCUnusedIVars.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/clang/lib/Analysis/CheckObjCUnusedIVars.cpp b/clang/lib/Analysis/CheckObjCUnusedIVars.cpp index dbc90d65c30..3a69e00499d 100644 --- a/clang/lib/Analysis/CheckObjCUnusedIVars.cpp +++ b/clang/lib/Analysis/CheckObjCUnusedIVars.cpp @@ -30,14 +30,20 @@ static void Scan(IvarUsageMap& M, const Stmt* S) { if (!S) return; - if (const ObjCIvarRefExpr* Ex = dyn_cast<ObjCIvarRefExpr>(S)) { - const ObjCIvarDecl* D = Ex->getDecl(); + if (const ObjCIvarRefExpr *Ex = dyn_cast<ObjCIvarRefExpr>(S)) { + const ObjCIvarDecl *D = Ex->getDecl(); IvarUsageMap::iterator I = M.find(D); if (I != M.end()) I->second = Used; return; } + // Blocks can reference an instance variable of a class. + if (const BlockExpr *BE = dyn_cast<BlockExpr>(S)) { + Scan(M, BE->getBody()); + return; + } + for (Stmt::const_child_iterator I=S->child_begin(),E=S->child_end(); I!=E;++I) Scan(M, *I); } |