mirror of
https://github.com/verilator/verilator.git
synced 2025-01-07 23:27:48 +00:00
Internals: Experimental cleanup; avoid :: on package symbol tables
This commit is contained in:
parent
5a6f2b661d
commit
774ec42be4
@ -167,6 +167,10 @@ public:
|
|||||||
const std::unique_ptr<std::ofstream> logp{V3File::new_ofstream(filename)};
|
const std::unique_ptr<std::ofstream> logp{V3File::new_ofstream(filename)};
|
||||||
if (logp->fail()) v3fatal("Can't write " << filename);
|
if (logp->fail()) v3fatal("Can't write " << filename);
|
||||||
std::ostream& os = *logp;
|
std::ostream& os = *logp;
|
||||||
|
// TODO the symbol table has node pointers which may be
|
||||||
|
// dangling, as we call deleteTree in these visitors without
|
||||||
|
// pushing for later deletion (or deleting from the symbol table)
|
||||||
|
// So, only completely safe to call this when under --debug or --debug-leak.
|
||||||
m_syms.dumpSelf(os);
|
m_syms.dumpSelf(os);
|
||||||
bool first = true;
|
bool first = true;
|
||||||
for (int samn = 0; samn < SAMN__MAX; ++samn) {
|
for (int samn = 0; samn < SAMN__MAX; ++samn) {
|
||||||
@ -907,8 +911,8 @@ class LinkDotFindVisitor final : public VNVisitor {
|
|||||||
} else {
|
} else {
|
||||||
VSymEnt* const upperSymp = m_statep->dunitEntp();
|
VSymEnt* const upperSymp = m_statep->dunitEntp();
|
||||||
m_scope = nodep->name();
|
m_scope = nodep->name();
|
||||||
m_curSymp = m_modSymp = m_statep->insertBlock(
|
m_curSymp = m_modSymp = m_statep->insertBlock(upperSymp, nodep->name(), nodep,
|
||||||
upperSymp, nodep->name() + "::", nodep, m_classOrPackagep);
|
m_classOrPackagep);
|
||||||
UINFO(9, "New module scope " << m_curSymp << endl);
|
UINFO(9, "New module scope " << m_curSymp << endl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,7 @@ public:
|
|||||||
os << " se" << cvtToHex(this) << std::setw(0);
|
os << " se" << cvtToHex(this) << std::setw(0);
|
||||||
os << " fallb=se" << cvtToHex(m_fallbackp);
|
os << " fallb=se" << cvtToHex(m_fallbackp);
|
||||||
if (m_symPrefix != "") os << " symPrefix=" << m_symPrefix;
|
if (m_symPrefix != "") os << " symPrefix=" << m_symPrefix;
|
||||||
os << " n=" << nodep();
|
if (nodep()) os << " n=" << nodep();
|
||||||
os << '\n';
|
os << '\n';
|
||||||
if (VL_UNCOVERABLE(!doneSymsr.insert(this).second)) {
|
if (VL_UNCOVERABLE(!doneSymsr.insert(this).second)) {
|
||||||
os << indent << "| ^ duplicate, so no children printed\n"; // LCOV_EXCL_LINE
|
os << indent << "| ^ duplicate, so no children printed\n"; // LCOV_EXCL_LINE
|
||||||
|
Loading…
Reference in New Issue
Block a user