diff options
author | Ted Kremenek <kremenek@apple.com> | 2008-08-28 18:34:26 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2008-08-28 18:34:26 +0000 |
commit | e6c62e3d43728b0a4477fffd543723dd2170af1a (patch) | |
tree | ac7b63ae2dfa6991e914f0590c20e413a1777afd /lib/Analysis/GRExprEngine.cpp | |
parent | 9048891ff983d0681c116c6e8f1073aa31bdd6e8 (diff) |
Fixed analyzer caching bug in DeclStmt.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@55487 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/GRExprEngine.cpp')
-rw-r--r-- | lib/Analysis/GRExprEngine.cpp | 33 |
1 files changed, 11 insertions, 22 deletions
diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp index c92093cf00..75ba46051f 100644 --- a/lib/Analysis/GRExprEngine.cpp +++ b/lib/Analysis/GRExprEngine.cpp @@ -1452,25 +1452,19 @@ void GRExprEngine::VisitCast(Expr* CastE, Expr* Ex, NodeTy* Pred, NodeSet& Dst){ } void GRExprEngine::VisitDeclStmt(DeclStmt* DS, NodeTy* Pred, NodeSet& Dst) { - VisitDeclStmtAux(DS, DS->getDecl(), Pred, Dst); -} - -void GRExprEngine::VisitDeclStmtAux(DeclStmt* DS, ScopedDecl* D, - NodeTy* Pred, NodeSet& Dst) { - if (!D) - return; + // The CFG has one DeclStmt per Decl, so we don't need to walk the + // Decl chain. + + ScopedDecl* D = DS->getDecl(); - if (!isa<VarDecl>(D)) { - VisitDeclStmtAux(DS, D->getNextDeclarator(), Pred, Dst); + if (!D || !isa<VarDecl>(D)) return; - } const VarDecl* VD = dyn_cast<VarDecl>(D); // FIXME: Add support for local arrays. if (VD->getType()->isArrayType()) { - VisitDeclStmtAux(DS, D->getNextDeclarator(), Pred, Dst); return; } @@ -1480,21 +1474,16 @@ void GRExprEngine::VisitDeclStmtAux(DeclStmt* DS, ScopedDecl* D, // time a function is called those values may not be current. NodeSet Tmp; - if (Ex) Visit(Ex, Pred, Tmp); - if (Tmp.empty()) Tmp.Add(Pred); + if (Ex) + Visit(Ex, Pred, Tmp); + + if (Tmp.empty()) + Tmp.Add(Pred); for (NodeSet::iterator I=Tmp.begin(), E=Tmp.end(); I!=E; ++I) { const GRState* St = GetState(*I); St = StateMgr.AddDecl(St, VD, Ex, Builder->getCurrentBlockCount()); - - // Create a new node. We don't really need to create a new NodeSet - // here, but it simplifies things and doesn't cost much. - NodeSet Tmp2; - MakeNode(Tmp2, DS, *I, St); - if (Tmp2.empty()) Tmp2.Add(*I); - - for (NodeSet::iterator I2=Tmp2.begin(), E2=Tmp2.end(); I2!=E2; ++I2) - VisitDeclStmtAux(DS, D->getNextDeclarator(), *I2, Dst); + MakeNode(Dst, DS, *I, St); } } |