[analyzer] Further printing improvements: use declarations,

skip pointers whenever redundant, use unique prefixes.

Differential Revision: https://reviews.llvm.org/D52114

llvm-svn: 342316
This commit is contained in:
George Karpenkov 2018-09-15 02:34:45 +00:00
parent e3c99427f0
commit 64c431c900
5 changed files with 15 additions and 15 deletions

View File

@ -307,7 +307,6 @@ int64_t Stmt::getID(const ASTContext &Context) const {
assert(Out && "Wrong allocator used");
assert(*Out % alignof(Stmt) == 0 && "Wrong alignment information");
return *Out / alignof(Stmt);
}
CompoundStmt::CompoundStmt(ArrayRef<Stmt *> Stmts, SourceLocation LB,

View File

@ -235,8 +235,7 @@ void Environment::print(raw_ostream &Out, const char *NL,
const Stmt *S = I.first.getStmt();
assert(S != nullptr && "Expected non-null Stmt");
Out << "(LC " << LC->getID() << " <" << (const void *)LC << ">, S "
<< S->getID(Context) << " <" << (const void *)S << ">) ";
Out << "(LC" << LC->getID() << ", S" << S->getID(Context) << ") ";
S->printPretty(Out, /*Helper=*/nullptr, PP);
Out << " : " << I.second << NL;
}

View File

@ -3108,16 +3108,16 @@ struct DOTGraphTraits<ExplodedNode*> : public DefaultDOTGraphTraits {
const Stmt *S = Loc.castAs<StmtPoint>().getStmt();
assert(S != nullptr && "Expecting non-null Stmt");
Out << S->getStmtClassName() << ' '
Out << S->getStmtClassName() << " S"
<< S->getID(Context) << " <" << (const void *)S << "> ";
S->printPretty(Out, /*helper=*/nullptr, Context.getPrintingPolicy(),
/*Indentation=*/2, /*NewlineSymbol=*/"\\l");
printLocation(Out, S->getBeginLoc());
if (Loc.getAs<PreStmt>())
Out << "\\lPreStmt\\l;";
Out << "\\lPreStmt\\l";
else if (Loc.getAs<PostLoad>())
Out << "\\lPostLoad\\l;";
Out << "\\lPostLoad\\l";
else if (Loc.getAs<PostStore>())
Out << "\\lPostStore\\l";
else if (Loc.getAs<PostLValue>())
@ -3171,9 +3171,8 @@ struct DOTGraphTraits<ExplodedNode*> : public DefaultDOTGraphTraits {
static_cast<ExprEngine *>(State->getStateManager().getOwningEngine())
->getGraph();
Out << "StateID: " << State->getID() << " <" << (const void *)State.get()
<< ">"
<< " NodeID: " << N->getID(&Graph) << " <" << (const void *)N << ">\\|";
Out << "StateID: ST" << State->getID() << ", NodeID: N" << N->getID(&Graph)
<< " <" << (const void *)N << ">\\|";
bool SameAsAllPredecessors =
std::all_of(N->pred_begin(), N->pred_end(), [&](const ExplodedNode *P) {

View File

@ -457,7 +457,7 @@ void MemRegion::dumpToStream(raw_ostream &os) const {
}
void AllocaRegion::dumpToStream(raw_ostream &os) const {
os << "alloca{" << static_cast<const void *>(Ex) << ',' << Cnt << '}';
os << "alloca{S" << Ex->getID(getContext()) << ',' << Cnt << '}';
}
void FunctionCodeRegion::dumpToStream(raw_ostream &os) const {
@ -481,12 +481,12 @@ void BlockDataRegion::dumpToStream(raw_ostream &os) const {
void CompoundLiteralRegion::dumpToStream(raw_ostream &os) const {
// FIXME: More elaborate pretty-printing.
os << "{ " << static_cast<const void *>(CL) << " }";
os << "{ S" << CL->getID(getContext()) << " }";
}
void CXXTempObjectRegion::dumpToStream(raw_ostream &os) const {
os << "temp_object{" << getValueType().getAsString() << ','
<< static_cast<const void *>(Ex) << '}';
os << "temp_object{" << getValueType().getAsString() << ", "
<< "S" << Ex->getID(getContext()) << '}';
}
void CXXBaseObjectRegion::dumpToStream(raw_ostream &os) const {
@ -535,7 +535,7 @@ void VarRegion::dumpToStream(raw_ostream &os) const {
if (const IdentifierInfo *ID = VD->getIdentifier())
os << ID->getName();
else
os << "VarRegion{" << static_cast<const void *>(this) << '}';
os << "VarRegion{D" << VD->getID() << '}';
}
LLVM_DUMP_METHOD void RegionRawOffset::dump() const {

View File

@ -83,7 +83,10 @@ void SymbolCast::dumpToStream(raw_ostream &os) const {
}
void SymbolConjured::dumpToStream(raw_ostream &os) const {
os << "conj_$" << getSymbolID() << '{' << T.getAsString() << '}';
os << "conj_$" << getSymbolID() << '{' << T.getAsString()
<< ", LC" << LCtx->getID() << ", S" << S->getID(
LCtx->getDecl()->getASTContext()) << ", #" << Count
<< '}';
}
void SymbolDerived::dumpToStream(raw_ostream &os) const {