forked from OSchip/llvm-project
[analyzer] Remove AggExprVisitor, a dead class that assisted in visiting C++ expressions with a "base object", because the CFG is now linearized.
The only use of AggExprVisitor was in #if 0 code (the analyzer's incomplete C++ support), so there is no actual behavioral change anyway. llvm-svn: 152856
This commit is contained in:
parent
1918166de7
commit
01b59cd87a
|
@ -363,9 +363,6 @@ public:
|
|||
void VisitCXXDeleteExpr(const CXXDeleteExpr *CDE, ExplodedNode *Pred,
|
||||
ExplodedNodeSet &Dst);
|
||||
|
||||
void VisitAggExpr(const Expr *E, const MemRegion *Dest, ExplodedNode *Pred,
|
||||
ExplodedNodeSet &Dst);
|
||||
|
||||
/// Create a C++ temporary object for an rvalue.
|
||||
void CreateCXXTemporaryObject(const MaterializeTemporaryExpr *ME,
|
||||
ExplodedNode *Pred,
|
||||
|
|
|
@ -1,73 +0,0 @@
|
|||
//=-- AggExprVisitor.cpp - evaluating expressions of C++ class type -*- C++ -*-=
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// This file defines AggExprVisitor class, which contains lots of boiler
|
||||
// plate code for evaluating expressions of C++ class type.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "clang/StaticAnalyzer/Core/PathSensitive/ExprEngine.h"
|
||||
#include "clang/AST/StmtVisitor.h"
|
||||
|
||||
using namespace clang;
|
||||
using namespace ento;
|
||||
|
||||
namespace {
|
||||
/// AggExprVisitor is designed after AggExprEmitter of the CodeGen module. It
|
||||
/// is used for evaluating exprs of C++ object type. Evaluating such exprs
|
||||
/// requires a destination pointer pointing to the object being evaluated
|
||||
/// into. Passing such a pointer around would pollute the Visit* interface of
|
||||
/// ExprEngine. AggExprVisitor encapsulates code that goes through various
|
||||
/// cast and construct exprs (and others), and at the final point, dispatches
|
||||
/// back to the ExprEngine to let the real evaluation logic happen.
|
||||
class AggExprVisitor : public StmtVisitor<AggExprVisitor> {
|
||||
const MemRegion *Dest;
|
||||
ExplodedNode *Pred;
|
||||
ExplodedNodeSet &DstSet;
|
||||
ExprEngine &Eng;
|
||||
|
||||
public:
|
||||
AggExprVisitor(const MemRegion *dest, ExplodedNode *N, ExplodedNodeSet &dst,
|
||||
ExprEngine &eng)
|
||||
: Dest(dest), Pred(N), DstSet(dst), Eng(eng) {}
|
||||
|
||||
void VisitCastExpr(CastExpr *E);
|
||||
void VisitCXXConstructExpr(CXXConstructExpr *E);
|
||||
void VisitCXXMemberCallExpr(CXXMemberCallExpr *E);
|
||||
};
|
||||
}
|
||||
|
||||
void AggExprVisitor::VisitCastExpr(CastExpr *E) {
|
||||
switch (E->getCastKind()) {
|
||||
default:
|
||||
llvm_unreachable("Unhandled cast kind");
|
||||
case CK_NoOp:
|
||||
case CK_ConstructorConversion:
|
||||
case CK_UserDefinedConversion:
|
||||
// FIXME: The CFG is fully linearised, so a recursive visit is probably not
|
||||
// needed anymore.
|
||||
Visit(E->getSubExpr());
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void AggExprVisitor::VisitCXXConstructExpr(CXXConstructExpr *E) {
|
||||
Eng.VisitCXXConstructExpr(E, Dest, Pred, DstSet);
|
||||
}
|
||||
|
||||
void AggExprVisitor::VisitCXXMemberCallExpr(CXXMemberCallExpr *E) {
|
||||
// FIXME: The CFG is fully linearised, so a recursive visit is probably not
|
||||
// needed anymore.
|
||||
Eng.Visit(E, Pred, DstSet);
|
||||
}
|
||||
|
||||
void ExprEngine::VisitAggExpr(const Expr *E, const MemRegion *Dest,
|
||||
ExplodedNode *Pred, ExplodedNodeSet &Dst) {
|
||||
AggExprVisitor(Dest, Pred, Dst, *this).Visit(const_cast<Expr *>(E));
|
||||
}
|
|
@ -3,7 +3,6 @@ set(LLVM_LINK_COMPONENTS support)
|
|||
set(LLVM_USED_LIBS clangBasic clangLex clangAST clangFrontend clangRewrite)
|
||||
|
||||
add_clang_library(clangStaticAnalyzerCore
|
||||
AggExprVisitor.cpp
|
||||
AnalysisManager.cpp
|
||||
BasicConstraintManager.cpp
|
||||
BasicValueFactory.cpp
|
||||
|
|
|
@ -78,10 +78,7 @@ void ExprEngine::VisitCXXConstructExpr(const CXXConstructExpr *E,
|
|||
#if 0
|
||||
// Is the constructor elidable?
|
||||
if (E->isElidable()) {
|
||||
VisitAggExpr(E->getArg(0), destNodes, Pred, Dst);
|
||||
// FIXME: this is here to force propagation if VisitAggExpr doesn't
|
||||
if (destNodes.empty())
|
||||
destNodes.Add(Pred);
|
||||
destNodes.Add(Pred);
|
||||
return;
|
||||
}
|
||||
#endif
|
||||
|
|
Loading…
Reference in New Issue