diff options
author | Anna Zaks <ganna@apple.com> | 2012-05-15 22:31:56 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2012-05-15 22:31:56 +0000 |
commit | 58d986c866074f0ddcd063212837453302be9cd9 (patch) | |
tree | 05b430deaafb59d6c297648b6ef05c9bf462ed1e /clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp | |
parent | a1626369b6e2242ad296204a650eb3de13682448 (diff) | |
download | bcm5719-llvm-58d986c866074f0ddcd063212837453302be9cd9.tar.gz bcm5719-llvm-58d986c866074f0ddcd063212837453302be9cd9.zip |
[analyzer] Fix a regression in ObjCUnusedIVars checker.
We can no longer rely on children iterator to visit all the AST
tree children of an expression (OpaqueValueExpr has no children).
llvm-svn: 156870
Diffstat (limited to 'clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp')
-rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp index ea6f8e109b6..8792144ddef 100644 --- a/clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/ObjCUnusedIVarsChecker.cpp @@ -47,6 +47,15 @@ static void Scan(IvarUsageMap& M, const Stmt *S) { return; } + if (const PseudoObjectExpr *POE = dyn_cast<PseudoObjectExpr>(S)) + for (PseudoObjectExpr::const_semantics_iterator + i = POE->semantics_begin(), e = POE->semantics_end(); i != e; ++i) { + const Expr *sub = *i; + if (const OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(sub)) + sub = OVE->getSourceExpr(); + Scan(M, sub); + } + for (Stmt::const_child_iterator I=S->child_begin(),E=S->child_end(); I!=E;++I) Scan(M, *I); } |