From: Ted Kremenek Date: Fri, 18 Jan 2008 00:40:21 +0000 (+0000) Subject: Fixed bug in 'LiveVariables' analysis where we incorrectly marked a variable X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2a9da9c85fbe559299a3d123180ed07a53b533c6;p=clang Fixed bug in 'LiveVariables' analysis where we incorrectly marked a variable dead at an assignment without taking into account if the variable was used in the RHS of the assignment. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@46153 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Analysis/LiveVariables.cpp b/Analysis/LiveVariables.cpp index 5bd72b42af..b96f7fc4bb 100644 --- a/Analysis/LiveVariables.cpp +++ b/Analysis/LiveVariables.cpp @@ -77,10 +77,9 @@ void TransferFuncs::Visit(Stmt *S) { if (AD.Observer) AD.Observer->ObserveStmt(S,AD,LiveState); - if (S == getCurrentBlkStmt()) { - StmtVisitor::Visit(S); if (getCFG().isBlkExpr(S)) LiveState(S,AD) = Dead; + StmtVisitor::Visit(S); } else if (!getCFG().isBlkExpr(S)) StmtVisitor::Visit(S); @@ -199,6 +198,10 @@ bool LiveVariables::isLive(const Stmt* Loc, const Stmt* StmtVal) const { return getStmtData(Loc)(StmtVal,getAnalysisData()); } +bool LiveVariables::isLive(const Stmt* Loc, const VarDecl* D) const { + return getStmtData(Loc)(D,getAnalysisData()); +} + //===----------------------------------------------------------------------===// // printing liveness state for debugging //