summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-08-28 18:34:26 +0000
committerTed Kremenek <kremenek@apple.com>2008-08-28 18:34:26 +0000
commitb45e6b91c6678890c64f33a532ed28fc17aa5ec4 (patch)
treef00c9e5e7f559f0a275717674b9955944b2a3af2
parent26d54b3ef35545c0c3584989a15fc2c3c5fbe99d (diff)
downloadbcm5719-llvm-b45e6b91c6678890c64f33a532ed28fc17aa5ec4.tar.gz
bcm5719-llvm-b45e6b91c6678890c64f33a532ed28fc17aa5ec4.zip
Fixed analyzer caching bug in DeclStmt.
llvm-svn: 55487
-rw-r--r--clang/include/clang/Analysis/PathSensitive/GRExprEngine.h3
-rw-r--r--clang/lib/Analysis/GRExprEngine.cpp33
2 files changed, 11 insertions, 25 deletions
diff --git a/clang/include/clang/Analysis/PathSensitive/GRExprEngine.h b/clang/include/clang/Analysis/PathSensitive/GRExprEngine.h
index 69a5c45a31a..7cd345d2338 100644
--- a/clang/include/clang/Analysis/PathSensitive/GRExprEngine.h
+++ b/clang/include/clang/Analysis/PathSensitive/GRExprEngine.h
@@ -494,9 +494,6 @@ protected:
/// VisitDeclStmt - Transfer function logic for DeclStmts.
void VisitDeclStmt(DeclStmt* DS, NodeTy* Pred, NodeSet& Dst);
- void VisitDeclStmtAux(DeclStmt* DS, ScopedDecl* D,
- NodeTy* Pred, NodeSet& Dst);
-
/// VisitGuardedExpr - Transfer function logic for ?, __builtin_choose
void VisitGuardedExpr(Expr* Ex, Expr* L, Expr* R, NodeTy* Pred, NodeSet& Dst);
diff --git a/clang/lib/Analysis/GRExprEngine.cpp b/clang/lib/Analysis/GRExprEngine.cpp
index c92093cf003..75ba46051ff 100644
--- a/clang/lib/Analysis/GRExprEngine.cpp
+++ b/clang/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);
}
}
OpenPOWER on IntegriCloud