forked from github/verilator
Internals: C++11 style cleanups. No functional change.
This commit is contained in:
parent
5ad3c4e499
commit
8ecdc85cf7
@ -64,9 +64,9 @@ private:
|
||||
|
||||
public:
|
||||
LatchDetectGraphVertex(V3Graph* graphp, const string& name, VertexType type = VT_BLOCK)
|
||||
: V3GraphVertex(graphp)
|
||||
, m_name(name)
|
||||
, m_type(type) {}
|
||||
: V3GraphVertex{graphp}
|
||||
, m_name{name}
|
||||
, m_type{type} {}
|
||||
virtual string name() const { return m_name + " " + typestr(); }
|
||||
virtual string dotColor() const { return user() ? "green" : "black"; }
|
||||
virtual int type() const { return m_type; }
|
||||
@ -142,17 +142,17 @@ public:
|
||||
// Add a new control path and connect it to its parent
|
||||
LatchDetectGraphVertex* addPathVertex(LatchDetectGraphVertex* parent, const string& name,
|
||||
bool branch = false) {
|
||||
m_curVertexp = new LatchDetectGraphVertex(this, name,
|
||||
m_curVertexp = new LatchDetectGraphVertex{this, name,
|
||||
branch ? LatchDetectGraphVertex::VT_BRANCH
|
||||
: LatchDetectGraphVertex::VT_BLOCK);
|
||||
new V3GraphEdge(this, parent, m_curVertexp, 1);
|
||||
: LatchDetectGraphVertex::VT_BLOCK};
|
||||
new V3GraphEdge{this, parent, m_curVertexp, 1};
|
||||
return m_curVertexp;
|
||||
}
|
||||
// Add a new output variable vertex and store a pointer to it in the user1 field of the
|
||||
// variables AstNode
|
||||
LatchDetectGraphVertex* addOutputVertex(AstVarRef* nodep) {
|
||||
LatchDetectGraphVertex* outVertexp
|
||||
= new LatchDetectGraphVertex(this, nodep->name(), LatchDetectGraphVertex::VT_OUTPUT);
|
||||
= new LatchDetectGraphVertex{this, nodep->name(), LatchDetectGraphVertex::VT_OUTPUT};
|
||||
nodep->varp()->user1p(outVertexp);
|
||||
m_outputs.push_back(nodep);
|
||||
return outVertexp;
|
||||
@ -437,7 +437,7 @@ private:
|
||||
virtual void visit(AstInitial* nodep) override {
|
||||
// Relink to IACTIVE, unless already under it
|
||||
UINFO(4, " INITIAL " << nodep << endl);
|
||||
ActiveDlyVisitor dlyvisitor(nodep, ActiveDlyVisitor::CT_INITIAL);
|
||||
ActiveDlyVisitor dlyvisitor{nodep, ActiveDlyVisitor::CT_INITIAL};
|
||||
AstActive* wantactivep = m_namer.getIActive(nodep->fileline());
|
||||
nodep->unlinkFrBack();
|
||||
wantactivep->addStmtsp(nodep);
|
||||
@ -470,7 +470,7 @@ private:
|
||||
VL_DO_DANGLING(nodep->unlinkFrBack()->deleteTree(), nodep);
|
||||
return;
|
||||
}
|
||||
ActiveDlyVisitor dlyvisitor(nodep, ActiveDlyVisitor::CT_INITIAL);
|
||||
ActiveDlyVisitor dlyvisitor{nodep, ActiveDlyVisitor::CT_INITIAL};
|
||||
if (!m_scopeFinalp) {
|
||||
m_scopeFinalp = new AstCFunc(
|
||||
nodep->fileline(), "_final_" + m_namer.scopep()->nameDotless(), m_namer.scopep());
|
||||
@ -540,14 +540,14 @@ private:
|
||||
|
||||
// Warn and/or convert any delayed assignments
|
||||
if (combo && !sequent) {
|
||||
ActiveLatchCheckVisitor latchvisitor(nodep, kwd);
|
||||
ActiveLatchCheckVisitor latchvisitor{nodep, kwd};
|
||||
if (kwd == VAlwaysKwd::ALWAYS_LATCH) {
|
||||
ActiveDlyVisitor dlyvisitor(nodep, ActiveDlyVisitor::CT_LATCH);
|
||||
ActiveDlyVisitor dlyvisitor{nodep, ActiveDlyVisitor::CT_LATCH};
|
||||
} else {
|
||||
ActiveDlyVisitor dlyvisitor(nodep, ActiveDlyVisitor::CT_COMBO);
|
||||
ActiveDlyVisitor dlyvisitor{nodep, ActiveDlyVisitor::CT_COMBO};
|
||||
}
|
||||
} else if (!combo && sequent) {
|
||||
ActiveDlyVisitor dlyvisitor(nodep, ActiveDlyVisitor::CT_SEQ);
|
||||
ActiveDlyVisitor dlyvisitor{nodep, ActiveDlyVisitor::CT_SEQ};
|
||||
}
|
||||
}
|
||||
virtual void visit(AstAlways* nodep) override {
|
||||
@ -620,6 +620,6 @@ public:
|
||||
|
||||
void V3Active::activeAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ActiveVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ActiveVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("active", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -136,6 +136,6 @@ public:
|
||||
|
||||
void V3ActiveTop::activeTopAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ActiveTopVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ActiveTopVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("activetop", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -474,6 +474,6 @@ public:
|
||||
|
||||
void V3Assert::assertAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ AssertVisitor visitor(nodep); } // Destruct before checking
|
||||
{ AssertVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("assert", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -205,6 +205,6 @@ public:
|
||||
|
||||
void V3AssertPre::assertPreAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ AssertPreVisitor visitor(nodep); } // Destruct before checking
|
||||
{ AssertPreVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("assertpre", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -1124,7 +1124,7 @@ void AstNode::dumpTreeFile(const string& filename, bool append, bool doDump, boo
|
||||
if (doDump) {
|
||||
{ // Write log & close
|
||||
UINFO(2, "Dumping " << filename << endl);
|
||||
const std::unique_ptr<std::ofstream> logsp(V3File::new_ofstream(filename, append));
|
||||
const std::unique_ptr<std::ofstream> logsp{V3File::new_ofstream(filename, append)};
|
||||
if (logsp->fail()) v3fatal("Can't write " << filename);
|
||||
*logsp << "Verilator Tree Dump (format 0x3900) from <e" << std::dec << editCountLast();
|
||||
*logsp << "> to <e" << std::dec << editCountGbl() << ">\n";
|
||||
|
@ -8497,9 +8497,9 @@ private:
|
||||
public:
|
||||
AstNodeCoverOrAssert(AstType t, FileLine* fl, AstNode* propp, AstNode* passsp, bool immediate,
|
||||
const string& name = "")
|
||||
: AstNodeStmt(t, fl)
|
||||
, m_immediate(immediate)
|
||||
, m_name(name) {
|
||||
: AstNodeStmt{t, fl}
|
||||
, m_immediate{immediate}
|
||||
, m_name{name} {
|
||||
addOp1p(propp);
|
||||
addNOp4p(passsp);
|
||||
}
|
||||
|
@ -308,7 +308,7 @@ void V3Begin::debeginAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
BeginState state;
|
||||
{ BeginVisitor bvisitor(nodep, &state); }
|
||||
{ BeginVisitor bvisitor{nodep, &state}; }
|
||||
if (state.anyFuncInBegin()) { BeginRelinkVisitor brvisitor(nodep, &state); }
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("begin", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
|
@ -123,5 +123,5 @@ public:
|
||||
|
||||
void V3Branch::branchAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
BranchVisitor visitor(nodep);
|
||||
BranchVisitor visitor{nodep};
|
||||
}
|
||||
|
@ -342,8 +342,8 @@ void V3Broken::brokenAll(AstNetlist* nodep) {
|
||||
UINFO(1, "Broken called under broken, skipping recursion.\n"); // LCOV_EXCL_LINE
|
||||
} else {
|
||||
inBroken = true;
|
||||
BrokenMarkVisitor mvisitor(nodep);
|
||||
BrokenCheckVisitor cvisitor(nodep);
|
||||
BrokenMarkVisitor mvisitor{nodep};
|
||||
BrokenCheckVisitor cvisitor{nodep};
|
||||
s_allocTable.checkForLeaks();
|
||||
s_linkableTable.clear();
|
||||
s_brokenCntGlobal.inc();
|
||||
|
@ -60,7 +60,7 @@ private:
|
||||
AstCFunc* makeNewFunc() {
|
||||
const int funcNum = m_newFunctions.size();
|
||||
const string funcName = m_basename + "_" + cvtToStr(funcNum);
|
||||
AstCFunc* const funcp = new AstCFunc(m_modp->fileline(), funcName, nullptr, "void");
|
||||
AstCFunc* const funcp = new AstCFunc{m_modp->fileline(), funcName, nullptr, "void"};
|
||||
funcp->isStatic(false);
|
||||
funcp->isLoose(!m_type.isClass());
|
||||
funcp->declPrivate(true);
|
||||
@ -74,7 +74,7 @@ private:
|
||||
preventUnusedStmt = "if (false && first) {} // Prevent unused\n";
|
||||
}
|
||||
if (!preventUnusedStmt.empty()) {
|
||||
funcp->addStmtsp(new AstCStmt(m_modp->fileline(), preventUnusedStmt));
|
||||
funcp->addStmtsp(new AstCStmt{m_modp->fileline(), preventUnusedStmt});
|
||||
}
|
||||
m_modp->addStmtp(funcp);
|
||||
m_numStmts = 0;
|
||||
@ -91,9 +91,9 @@ public:
|
||||
}
|
||||
|
||||
V3CCtorsBuilder(AstNodeModule* nodep, const string& basename, VCtorType type)
|
||||
: m_modp(nodep)
|
||||
: m_modp{nodep}
|
||||
, m_basename{basename}
|
||||
, m_type(type) {
|
||||
, m_type{type} {
|
||||
// Note: The constructor is always called, even if empty, so we must always create at least
|
||||
// one.
|
||||
m_newFunctions.push_back(makeNewFunc());
|
||||
@ -108,7 +108,7 @@ public:
|
||||
AstCFunc* const rootFuncp = makeNewFunc();
|
||||
rootFuncp->name(m_basename);
|
||||
for (AstCFunc* const funcp : m_newFunctions) {
|
||||
AstCCall* const callp = new AstCCall(m_modp->fileline(), funcp);
|
||||
AstCCall* const callp = new AstCCall{m_modp->fileline(), funcp};
|
||||
if (m_type.isClass()) {
|
||||
callp->argTypes("vlSymsp");
|
||||
} else {
|
||||
@ -127,8 +127,9 @@ private:
|
||||
//######################################################################
|
||||
|
||||
void V3CCtors::evalAsserts() {
|
||||
AstNodeModule* modp = v3Global.rootp()->modulesp(); // Top module wrapper
|
||||
AstCFunc* funcp = new AstCFunc(modp->fileline(), "_eval_debug_assertions", nullptr, "void");
|
||||
AstNodeModule* const modp = v3Global.rootp()->modulesp(); // Top module wrapper
|
||||
AstCFunc* const funcp
|
||||
= new AstCFunc{modp->fileline(), "_eval_debug_assertions", nullptr, "void"};
|
||||
funcp->declPrivate(true);
|
||||
funcp->isStatic(false);
|
||||
funcp->isLoose(true);
|
||||
@ -136,7 +137,7 @@ void V3CCtors::evalAsserts() {
|
||||
funcp->ifdef("VL_DEBUG");
|
||||
modp->addStmtp(funcp);
|
||||
for (AstNode* np = modp->stmtsp(); np; np = np->nextp()) {
|
||||
if (AstVar* varp = VN_CAST(np, Var)) {
|
||||
if (AstVar* const varp = VN_CAST(np, Var)) {
|
||||
if (varp->isPrimaryInish() && !varp->isSc()) {
|
||||
if (AstBasicDType* basicp = VN_CAST(varp->dtypeSkipRefp(), BasicDType)) {
|
||||
const int storedWidth = basicp->widthAlignBytes() * 8;
|
||||
@ -144,22 +145,22 @@ void V3CCtors::evalAsserts() {
|
||||
if (lastWordWidth != 0) {
|
||||
// if (signal & CONST(upper_non_clean_mask)) { fail; }
|
||||
AstVarRef* const vrefp
|
||||
= new AstVarRef(varp->fileline(), varp, VAccess::READ);
|
||||
= new AstVarRef{varp->fileline(), varp, VAccess::READ};
|
||||
vrefp->selfPointer("this");
|
||||
AstNode* newp = vrefp;
|
||||
if (varp->isWide()) {
|
||||
newp = new AstWordSel(
|
||||
newp = new AstWordSel{
|
||||
varp->fileline(), newp,
|
||||
new AstConst(varp->fileline(), varp->widthWords() - 1));
|
||||
new AstConst(varp->fileline(), varp->widthWords() - 1)};
|
||||
}
|
||||
uint64_t value = VL_MASK_Q(storedWidth) & ~VL_MASK_Q(lastWordWidth);
|
||||
newp = new AstAnd(varp->fileline(), newp,
|
||||
const uint64_t value = VL_MASK_Q(storedWidth) & ~VL_MASK_Q(lastWordWidth);
|
||||
newp = new AstAnd{varp->fileline(), newp,
|
||||
new AstConst(varp->fileline(), AstConst::WidthedValue(),
|
||||
storedWidth, value));
|
||||
AstNodeIf* ifp = new AstIf(
|
||||
storedWidth, value)};
|
||||
AstNodeIf* const ifp = new AstIf{
|
||||
varp->fileline(), newp,
|
||||
new AstCStmt(varp->fileline(), "Verilated::overWidthError(\""
|
||||
+ varp->prettyName() + "\");"));
|
||||
new AstCStmt{varp->fileline(), "Verilated::overWidthError(\""
|
||||
+ varp->prettyName() + "\");"}};
|
||||
ifp->branchPred(VBranchPred::BP_UNLIKELY);
|
||||
newp = ifp;
|
||||
funcp->addStmtsp(newp);
|
||||
@ -177,20 +178,20 @@ void V3CCtors::cctorsAll() {
|
||||
modp = VN_CAST(modp->nextp(), NodeModule)) {
|
||||
// Process each module in turn
|
||||
{
|
||||
V3CCtorsBuilder var_reset(modp, "_ctor_var_reset",
|
||||
VN_IS(modp, Class) ? VCtorType::CLASS : VCtorType::MODULE);
|
||||
V3CCtorsBuilder var_reset{modp, "_ctor_var_reset",
|
||||
VN_IS(modp, Class) ? VCtorType::CLASS : VCtorType::MODULE};
|
||||
|
||||
for (AstNode* np = modp->stmtsp(); np; np = np->nextp()) {
|
||||
if (AstVar* const varp = VN_CAST(np, Var)) {
|
||||
if (!varp->isIfaceParent() && !varp->isIfaceRef() && !varp->noReset()) {
|
||||
const auto vrefp = new AstVarRef(varp->fileline(), varp, VAccess::WRITE);
|
||||
var_reset.add(new AstCReset(varp->fileline(), vrefp));
|
||||
const auto vrefp = new AstVarRef{varp->fileline(), varp, VAccess::WRITE};
|
||||
var_reset.add(new AstCReset{varp->fileline(), vrefp});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (v3Global.opt.coverage()) {
|
||||
V3CCtorsBuilder configure_coverage(modp, "_configure_coverage", VCtorType::COVERAGE);
|
||||
V3CCtorsBuilder configure_coverage{modp, "_configure_coverage", VCtorType::COVERAGE};
|
||||
for (AstNode* np = modp->stmtsp(); np; np = np->nextp()) {
|
||||
if (AstCoverDecl* const coverp = VN_CAST(np, CoverDecl)) {
|
||||
np = coverp->backp();
|
||||
@ -198,8 +199,8 @@ void V3CCtors::cctorsAll() {
|
||||
}
|
||||
}
|
||||
}
|
||||
if (AstClass* classp = VN_CAST(modp, Class)) {
|
||||
AstCFunc* funcp = new AstCFunc(modp->fileline(), "~", nullptr, "");
|
||||
if (AstClass* const classp = VN_CAST(modp, Class)) {
|
||||
AstCFunc* const funcp = new AstCFunc{modp->fileline(), "~", nullptr, ""};
|
||||
funcp->isDestructor(true);
|
||||
funcp->isStatic(false);
|
||||
// If can be referred to by base pointer, need virtual delete
|
||||
|
@ -55,9 +55,9 @@ private:
|
||||
|
||||
public:
|
||||
AstCUse* newUse(AstNode* nodep, VUseType useType, const string& name) {
|
||||
UseString key(useType, name);
|
||||
UseString key{useType, name};
|
||||
if (m_didUse.find(key) == m_didUse.end()) {
|
||||
AstCUse* newp = new AstCUse(nodep->fileline(), useType, name);
|
||||
AstCUse* const newp = new AstCUse{nodep->fileline(), useType, name};
|
||||
m_modInsertp->addStmtp(newp);
|
||||
UINFO(8, "Insert " << newp << endl);
|
||||
m_didUse[key] = newp;
|
||||
@ -123,46 +123,49 @@ class CUseVisitor final : public AstNVisitor {
|
||||
// Module use builders
|
||||
void makeUseCells(AstNodeModule* nodep) {
|
||||
for (AstNode* itemp = nodep->stmtsp(); itemp; itemp = itemp->nextp()) {
|
||||
if (AstCell* cellp = VN_CAST(itemp, Cell)) {
|
||||
if (AstCell* const cellp = VN_CAST(itemp, Cell)) {
|
||||
// Currently no include because we include __Syms which has them all
|
||||
m_state.newUse(nodep, VUseType::INT_FWD_CLASS, cellp->modp()->name());
|
||||
}
|
||||
}
|
||||
}
|
||||
void makeVlToString(AstClass* nodep) {
|
||||
AstCFunc* funcp = new AstCFunc(nodep->fileline(), "VL_TO_STRING", nullptr, "std::string");
|
||||
AstCFunc* const funcp
|
||||
= new AstCFunc{nodep->fileline(), "VL_TO_STRING", nullptr, "std::string"};
|
||||
funcp->argTypes("const VlClassRef<" + EmitCBaseVisitor::prefixNameProtect(nodep)
|
||||
+ ">& obj");
|
||||
funcp->isMethod(false);
|
||||
funcp->isConst(false);
|
||||
funcp->isStatic(false);
|
||||
funcp->protect(false);
|
||||
AstNode* exprp = new AstCMath(nodep->fileline(), "obj ? obj->to_string() : \"null\"", 0);
|
||||
AstNode* const exprp
|
||||
= new AstCMath{nodep->fileline(), "obj ? obj->to_string() : \"null\"", 0};
|
||||
exprp->dtypeSetString();
|
||||
funcp->addStmtsp(new AstCReturn(nodep->fileline(), exprp));
|
||||
funcp->addStmtsp(new AstCReturn{nodep->fileline(), exprp});
|
||||
nodep->addStmtp(funcp);
|
||||
}
|
||||
void makeToString(AstClass* nodep) {
|
||||
AstCFunc* funcp = new AstCFunc(nodep->fileline(), "to_string", nullptr, "std::string");
|
||||
AstCFunc* const funcp
|
||||
= new AstCFunc{nodep->fileline(), "to_string", nullptr, "std::string"};
|
||||
funcp->isConst(true);
|
||||
funcp->isStatic(false);
|
||||
funcp->protect(false);
|
||||
AstNode* exprp = new AstCMath(nodep->fileline(),
|
||||
R"(std::string("'{") + to_string_middle() + "}")", 0);
|
||||
AstNode* const exprp = new AstCMath{nodep->fileline(),
|
||||
R"(std::string("'{") + to_string_middle() + "}")", 0};
|
||||
exprp->dtypeSetString();
|
||||
funcp->addStmtsp(new AstCReturn(nodep->fileline(), exprp));
|
||||
funcp->addStmtsp(new AstCReturn{nodep->fileline(), exprp});
|
||||
nodep->addStmtp(funcp);
|
||||
}
|
||||
void makeToStringMiddle(AstClass* nodep) {
|
||||
AstCFunc* funcp
|
||||
= new AstCFunc(nodep->fileline(), "to_string_middle", nullptr, "std::string");
|
||||
AstCFunc* const funcp
|
||||
= new AstCFunc{nodep->fileline(), "to_string_middle", nullptr, "std::string"};
|
||||
funcp->isConst(true);
|
||||
funcp->isStatic(false);
|
||||
funcp->protect(false);
|
||||
funcp->addStmtsp(new AstCStmt(nodep->fileline(), "std::string out;\n"));
|
||||
funcp->addStmtsp(new AstCStmt{nodep->fileline(), "std::string out;\n"});
|
||||
std::string comma;
|
||||
for (AstNode* itemp = nodep->membersp(); itemp; itemp = itemp->nextp()) {
|
||||
if (auto* varp = VN_CAST(itemp, Var)) {
|
||||
if (auto* const varp = VN_CAST(itemp, Var)) {
|
||||
if (!varp->isParam()) {
|
||||
string stmt = "out += \"";
|
||||
stmt += comma;
|
||||
@ -179,7 +182,7 @@ class CUseVisitor final : public AstNVisitor {
|
||||
stmt += itemp->nameProtect();
|
||||
stmt += ");\n";
|
||||
nodep->user1(true); // So what we extend dumps this
|
||||
funcp->addStmtsp(new AstCStmt(nodep->fileline(), stmt));
|
||||
funcp->addStmtsp(new AstCStmt{nodep->fileline(), stmt});
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -190,22 +193,22 @@ class CUseVisitor final : public AstNVisitor {
|
||||
stmt += nodep->extendsp()->dtypep()->nameProtect();
|
||||
stmt += "::to_string_middle();\n";
|
||||
nodep->user1(true); // So what we extend dumps this
|
||||
funcp->addStmtsp(new AstCStmt(nodep->fileline(), stmt));
|
||||
funcp->addStmtsp(new AstCStmt{nodep->fileline(), stmt});
|
||||
}
|
||||
funcp->addStmtsp(new AstCStmt(nodep->fileline(), "return out;\n"));
|
||||
funcp->addStmtsp(new AstCStmt{nodep->fileline(), "return out;\n"});
|
||||
nodep->addStmtp(funcp);
|
||||
}
|
||||
|
||||
// VISITORS
|
||||
virtual void visit(AstNodeModule* nodep) override {
|
||||
if (v3Global.opt.trace()) {
|
||||
AstCUse* usep
|
||||
AstCUse* const usep
|
||||
= m_state.newUse(nodep, VUseType::INT_FWD_CLASS, v3Global.opt.traceClassBase());
|
||||
usep->protect(false);
|
||||
}
|
||||
makeUseCells(nodep);
|
||||
{ CUseDTypeVisitor dtypeVisitor(nodep, m_state); }
|
||||
if (AstClass* classp = VN_CAST(nodep, Class)) {
|
||||
{ CUseDTypeVisitor dtypeVisitor{nodep, m_state}; }
|
||||
if (AstClass* const classp = VN_CAST(nodep, Class)) {
|
||||
makeVlToString(classp);
|
||||
makeToString(classp);
|
||||
makeToStringMiddle(classp);
|
||||
@ -233,7 +236,7 @@ void V3CUse::cUseAll() {
|
||||
modp = VN_CAST(modp->nextp(), NodeModule)) {
|
||||
// Insert under this module; someday we should e.g. make Ast
|
||||
// for each output file and put under that
|
||||
CUseVisitor visitor(modp);
|
||||
CUseVisitor visitor{modp};
|
||||
}
|
||||
V3Global::dumpCheckGlobalTree("cuse", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -530,10 +530,10 @@ public:
|
||||
|
||||
void V3Case::caseAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ CaseVisitor visitor(nodep); } // Destruct before checking
|
||||
{ CaseVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("case", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
void V3Case::caseLint(AstNodeCase* nodep) {
|
||||
UINFO(4, __FUNCTION__ << ": " << endl);
|
||||
CaseLintVisitor visitor(nodep);
|
||||
CaseLintVisitor visitor{nodep};
|
||||
}
|
||||
|
@ -66,7 +66,8 @@ private:
|
||||
AstNRelinker relinkHandle;
|
||||
nodep->unlinkFrBack(&relinkHandle);
|
||||
//
|
||||
AstCCast* castp = new AstCCast(nodep->fileline(), nodep, needsize, nodep->widthMin());
|
||||
AstCCast* const castp
|
||||
= new AstCCast{nodep->fileline(), nodep, needsize, nodep->widthMin()};
|
||||
relinkHandle.relink(castp);
|
||||
// if (debug() > 8) castp->dumpTree(cout, "-castins: ");
|
||||
//
|
||||
@ -103,7 +104,7 @@ private:
|
||||
if (!VN_IS(nodep->backp(), NullCheck)) {
|
||||
AstNRelinker relinkHandle;
|
||||
nodep->unlinkFrBack(&relinkHandle);
|
||||
AstNode* newp = new AstNullCheck(nodep->fileline(), nodep);
|
||||
AstNode* const newp = new AstNullCheck{nodep->fileline(), nodep};
|
||||
relinkHandle.relink(newp);
|
||||
}
|
||||
}
|
||||
@ -201,6 +202,6 @@ public:
|
||||
|
||||
void V3Cast::castAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ CastVisitor visitor(nodep); } // Destruct before checking
|
||||
{ CastVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("cast", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -337,7 +337,7 @@ private:
|
||||
|
||||
int filelineWidth() {
|
||||
if (!m_filelineWidth) {
|
||||
CdcWidthVisitor visitor(v3Global.rootp());
|
||||
CdcWidthVisitor visitor{v3Global.rootp()};
|
||||
m_filelineWidth = visitor.maxWidth();
|
||||
}
|
||||
return m_filelineWidth;
|
||||
@ -508,7 +508,7 @@ private:
|
||||
|
||||
const string filename
|
||||
= v3Global.opt.makeDir() + "/" + v3Global.opt.prefix() + "__cdc_edges.txt";
|
||||
const std::unique_ptr<std::ofstream> ofp(V3File::new_ofstream(filename));
|
||||
const std::unique_ptr<std::ofstream> ofp{V3File::new_ofstream(filename)};
|
||||
if (ofp->fail()) v3fatal("Can't write " << filename);
|
||||
*ofp << "Edge Report for " << v3Global.opt.prefix() << '\n';
|
||||
|
||||
@ -758,5 +758,5 @@ public:
|
||||
|
||||
void V3Cdc::cdcAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
CdcVisitor visitor(nodep);
|
||||
CdcVisitor visitor{nodep};
|
||||
}
|
||||
|
@ -129,7 +129,7 @@ private:
|
||||
AstAssign* initp = new AstAssign(m_vscp->fileline(), m_newLvEqnp->cloneTree(true),
|
||||
m_varEqnp->cloneTree(true));
|
||||
m_statep->m_chgFuncp->addFinalsp(initp);
|
||||
EmitCBaseCounterVisitor visitor(initp);
|
||||
EmitCBaseCounterVisitor visitor{initp};
|
||||
m_statep->m_numStmts += visitor.count();
|
||||
}
|
||||
|
||||
@ -228,7 +228,7 @@ private:
|
||||
|
||||
void genChangeDet(AstVarScope* vscp) {
|
||||
vscp->v3warn(IMPERFECTSCH, "Imperfect scheduling of variable: " << vscp->prettyNameQ());
|
||||
ChangedInsertVisitor visitor(vscp, m_statep);
|
||||
ChangedInsertVisitor visitor{vscp, m_statep};
|
||||
}
|
||||
|
||||
// VISITORS
|
||||
@ -288,7 +288,7 @@ void V3Changed::changedAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
ChangedState state;
|
||||
ChangedVisitor visitor(nodep, &state);
|
||||
ChangedVisitor visitor{nodep, &state};
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("changed", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -153,6 +153,6 @@ public:
|
||||
|
||||
void V3Class::classAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ClassVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ClassVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("class", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -314,6 +314,6 @@ public:
|
||||
|
||||
void V3Clean::cleanAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ CleanVisitor visitor(nodep); } // Destruct before checking
|
||||
{ CleanVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("clean", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -435,6 +435,6 @@ public:
|
||||
|
||||
void V3Clock::clockAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ClockVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ClockVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("clock", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -223,6 +223,6 @@ public:
|
||||
|
||||
void V3Combine::combineAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ CombineVisitor visitor(nodep); } // Destruct before checking
|
||||
{ CombineVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("combine", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -95,9 +95,9 @@ class ConstBitOpTreeVisitor final : public AstNVisitor {
|
||||
bool m_polarity;
|
||||
int m_bit;
|
||||
BitPolarityEntry(const LeafInfo& info, bool pol, int bit)
|
||||
: m_info(info)
|
||||
, m_polarity(pol)
|
||||
, m_bit(bit) {}
|
||||
: m_info{info}
|
||||
, m_polarity{pol}
|
||||
, m_bit{bit} {}
|
||||
BitPolarityEntry() = default;
|
||||
};
|
||||
|
||||
@ -111,12 +111,12 @@ class ConstBitOpTreeVisitor final : public AstNVisitor {
|
||||
|
||||
public:
|
||||
explicit Restorer(ConstBitOpTreeVisitor& visitor)
|
||||
: m_visitor(visitor)
|
||||
, m_polaritiesSize(visitor.m_bitPolarities.size())
|
||||
, m_frozenSize(visitor.m_frozenNodes.size())
|
||||
, m_ops(visitor.m_ops)
|
||||
, m_polarity(visitor.m_polarity)
|
||||
, m_restore(true) {}
|
||||
: m_visitor{visitor}
|
||||
, m_polaritiesSize{visitor.m_bitPolarities.size()}
|
||||
, m_frozenSize{visitor.m_frozenNodes.size()}
|
||||
, m_ops{visitor.m_ops}
|
||||
, m_polarity{visitor.m_polarity}
|
||||
, m_restore{true} {}
|
||||
~Restorer() {
|
||||
UASSERT(m_visitor.m_bitPolarities.size() >= m_polaritiesSize,
|
||||
"m_bitPolarities must grow monotorilaclly");
|
||||
@ -222,9 +222,9 @@ class ConstBitOpTreeVisitor final : public AstNVisitor {
|
||||
|
||||
// CONSTRUCTORS
|
||||
VarInfo(ConstBitOpTreeVisitor* parent, AstVarRef* refp)
|
||||
: m_parentp(parent)
|
||||
, m_refp(refp)
|
||||
, m_bitPolarity(refp, refp->isWide() ? VL_EDATASIZE : refp->width()) {
|
||||
: m_parentp{parent}
|
||||
, m_refp{refp}
|
||||
, m_bitPolarity{refp, refp->isWide() ? VL_EDATASIZE : refp->width()} {
|
||||
m_bitPolarity.setAllBitsX();
|
||||
}
|
||||
};
|
||||
@ -482,8 +482,8 @@ class ConstBitOpTreeVisitor final : public AstNVisitor {
|
||||
|
||||
// CONSTRUCTORS
|
||||
ConstBitOpTreeVisitor(AstNode* nodep, int ops)
|
||||
: m_ops(ops)
|
||||
, m_rootp(nodep) {
|
||||
: m_ops{ops}
|
||||
, m_rootp{nodep} {
|
||||
// Fill nullptr at [0] because AstVarScope::user4 is 0 by default
|
||||
m_varInfos.push_back(nullptr);
|
||||
CONST_BITOP_RETURN_IF(!isAndTree() && !isOrTree() && !isXorTree(), nodep);
|
||||
@ -1495,9 +1495,10 @@ private:
|
||||
// -> EXTEND(nodep)
|
||||
// like a AstExtend{$rhsp}, but we need to set the width correctly from base node
|
||||
arg0p->unlinkFrBack();
|
||||
AstNode* newp = (VN_IS(nodep, ExtendS)
|
||||
? static_cast<AstNode*>(new AstExtendS(nodep->fileline(), arg0p))
|
||||
: static_cast<AstNode*>(new AstExtend(nodep->fileline(), arg0p)));
|
||||
AstNode* const newp
|
||||
= (VN_IS(nodep, ExtendS)
|
||||
? static_cast<AstNode*>(new AstExtendS{nodep->fileline(), arg0p})
|
||||
: static_cast<AstNode*>(new AstExtend{nodep->fileline(), arg0p}));
|
||||
newp->dtypeFrom(nodep);
|
||||
nodep->replaceWith(newp);
|
||||
VL_DO_DANGLING(nodep->deleteTree(), nodep);
|
||||
@ -1713,8 +1714,8 @@ private:
|
||||
// Note only do this (need user4) when m_warn, which is
|
||||
// done as unique visitor
|
||||
AstUser4InUse m_inuser4;
|
||||
ConstVarMarkVisitor mark(nodep->lhsp());
|
||||
ConstVarFindVisitor find(nodep->rhsp());
|
||||
ConstVarMarkVisitor mark{nodep->lhsp()};
|
||||
ConstVarFindVisitor find{nodep->rhsp()};
|
||||
if (find.found()) need_temp = true;
|
||||
}
|
||||
if (need_temp) {
|
||||
@ -3233,7 +3234,7 @@ AstNode* V3Const::constifyParamsEdit(AstNode* nodep) {
|
||||
|
||||
// Make sure we've sized everything first
|
||||
nodep = V3Width::widthParamsEdit(nodep);
|
||||
ConstVisitor visitor(ConstVisitor::PROC_PARAMS);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_PARAMS};
|
||||
if (AstVar* varp = VN_CAST(nodep, Var)) {
|
||||
// If a var wants to be constified, it's really a param, and
|
||||
// we want the value to be constant. We aren't passed just the
|
||||
@ -3263,7 +3264,7 @@ AstNode* V3Const::constifyGenerateParamsEdit(AstNode* nodep) {
|
||||
|
||||
// Make sure we've sized everything first
|
||||
nodep = V3Width::widthGenerateParamsEdit(nodep);
|
||||
ConstVisitor visitor(ConstVisitor::PROC_GENERATE);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_GENERATE};
|
||||
if (AstVar* varp = VN_CAST(nodep, Var)) {
|
||||
// If a var wants to be constified, it's really a param, and
|
||||
// we want the value to be constant. We aren't passed just the
|
||||
@ -3281,7 +3282,7 @@ void V3Const::constifyAllLint(AstNetlist* nodep) {
|
||||
// Only call from Verilator.cpp, as it uses user#'s
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
ConstVisitor visitor(ConstVisitor::PROC_V_WARN);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_V_WARN};
|
||||
(void)visitor.mainAcceptEdit(nodep);
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("const", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
@ -3290,14 +3291,14 @@ void V3Const::constifyAllLint(AstNetlist* nodep) {
|
||||
void V3Const::constifyCpp(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
ConstVisitor visitor(ConstVisitor::PROC_CPP);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_CPP};
|
||||
(void)visitor.mainAcceptEdit(nodep);
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("const_cpp", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
||||
AstNode* V3Const::constifyEdit(AstNode* nodep) {
|
||||
ConstVisitor visitor(ConstVisitor::PROC_V_NOWARN);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_V_NOWARN};
|
||||
nodep = visitor.mainAcceptEdit(nodep);
|
||||
return nodep;
|
||||
}
|
||||
@ -3308,7 +3309,7 @@ void V3Const::constifyAllLive(AstNetlist* nodep) {
|
||||
// IE doesn't prune dead statements, as we need to do some usability checks after this
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
ConstVisitor visitor(ConstVisitor::PROC_LIVE);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_LIVE};
|
||||
(void)visitor.mainAcceptEdit(nodep);
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("const", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
@ -3318,14 +3319,14 @@ void V3Const::constifyAll(AstNetlist* nodep) {
|
||||
// Only call from Verilator.cpp, as it uses user#'s
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
ConstVisitor visitor(ConstVisitor::PROC_V_EXPENSIVE);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_V_EXPENSIVE};
|
||||
(void)visitor.mainAcceptEdit(nodep);
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("const", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
||||
AstNode* V3Const::constifyExpensiveEdit(AstNode* nodep) {
|
||||
ConstVisitor visitor(ConstVisitor::PROC_V_EXPENSIVE);
|
||||
ConstVisitor visitor{ConstVisitor::PROC_V_EXPENSIVE};
|
||||
nodep = visitor.mainAcceptEdit(nodep);
|
||||
return nodep;
|
||||
}
|
||||
|
@ -543,6 +543,6 @@ public:
|
||||
|
||||
void V3Coverage::coverage(AstNetlist* rootp) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ CoverageVisitor visitor(rootp); } // Destruct before checking
|
||||
{ CoverageVisitor visitor{rootp}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("coverage", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -114,6 +114,6 @@ public:
|
||||
|
||||
void V3CoverageJoin::coverageJoin(AstNetlist* rootp) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ CoverageJoinVisitor visitor(rootp); } // Destruct before checking
|
||||
{ CoverageJoinVisitor visitor{rootp}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("coveragejoin", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -318,7 +318,7 @@ private:
|
||||
// And its children may now be killable too; correct counts
|
||||
// Recurse, as cells may not be directly under the module but in a generate
|
||||
if (!modp->dead()) { // If was dead didn't increment user1's
|
||||
DeadModVisitor visitor(modp);
|
||||
DeadModVisitor visitor{modp};
|
||||
}
|
||||
VL_DO_DANGLING(modp->unlinkFrBack()->deleteTree(), modp);
|
||||
retry = true;
|
||||
@ -463,31 +463,31 @@ public:
|
||||
|
||||
void V3Dead::deadifyModules(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DeadVisitor visitor(nodep, false, false, false, false); } // Destruct before checking
|
||||
{ DeadVisitor visitor{nodep, false, false, false, false}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("deadModules", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
||||
void V3Dead::deadifyDTypes(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DeadVisitor visitor(nodep, false, true, false, false); } // Destruct before checking
|
||||
{ DeadVisitor visitor{nodep, false, true, false, false}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("deadDtypes", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
||||
void V3Dead::deadifyDTypesScoped(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DeadVisitor visitor(nodep, false, true, true, false); } // Destruct before checking
|
||||
{ DeadVisitor visitor{nodep, false, true, true, false}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("deadDtypesScoped", 0,
|
||||
v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
||||
void V3Dead::deadifyAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DeadVisitor visitor(nodep, true, true, false, true); } // Destruct before checking
|
||||
{ DeadVisitor visitor{nodep, true, true, false, true}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("deadAll", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
||||
void V3Dead::deadifyAllScoped(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DeadVisitor visitor(nodep, true, true, true, true); } // Destruct before checking
|
||||
{ DeadVisitor visitor{nodep, true, true, true, true}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("deadAllScoped", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -510,6 +510,6 @@ public:
|
||||
|
||||
void V3Delayed::delayedAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DelayedVisitor visitor(nodep); } // Destruct before checking
|
||||
{ DelayedVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("delayed", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -53,16 +53,16 @@ private:
|
||||
// if (debug() >= 9) nodep->dumpTree(cout, "deep:");
|
||||
|
||||
const string newvarname = (string("__Vdeeptemp") + cvtToStr(m_modp->varNumGetInc()));
|
||||
AstVar* varp
|
||||
= new AstVar(nodep->fileline(), AstVarType::STMTTEMP, newvarname, nodep->dtypep());
|
||||
AstVar* const varp
|
||||
= new AstVar{nodep->fileline(), AstVarType::STMTTEMP, newvarname, nodep->dtypep()};
|
||||
UASSERT_OBJ(m_cfuncp, nodep, "Deep expression not under a function");
|
||||
m_cfuncp->addInitsp(varp);
|
||||
// Replace node tree with reference to var
|
||||
AstVarRef* newp = new AstVarRef(nodep->fileline(), varp, VAccess::READ);
|
||||
AstVarRef* const newp = new AstVarRef{nodep->fileline(), varp, VAccess::READ};
|
||||
nodep->replaceWith(newp);
|
||||
// Put assignment before the referencing statement
|
||||
AstAssign* assp = new AstAssign(
|
||||
nodep->fileline(), new AstVarRef(nodep->fileline(), varp, VAccess::WRITE), nodep);
|
||||
AstAssign* const assp = new AstAssign{
|
||||
nodep->fileline(), new AstVarRef{nodep->fileline(), varp, VAccess::WRITE}, nodep};
|
||||
AstNRelinker linker2;
|
||||
m_stmtp->unlinkFrBack(&linker2);
|
||||
assp->addNext(m_stmtp);
|
||||
@ -158,6 +158,6 @@ public:
|
||||
|
||||
void V3Depth::depthAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DepthVisitor visitor(nodep); } // Destruct before checking
|
||||
{ DepthVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("depth", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -129,6 +129,6 @@ public:
|
||||
|
||||
void V3DepthBlock::depthBlockAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DepthBlockVisitor visitor(nodep); } // Destruct before checking
|
||||
{ DepthBlockVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("deepblock", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -266,6 +266,6 @@ public:
|
||||
|
||||
void V3Descope::descopeAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ DescopeVisitor visitor(nodep); } // Destruct before checking
|
||||
{ DescopeVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("descope", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -44,7 +44,7 @@ V3DupFinder::iterator V3DupFinder::findDuplicate(AstNode* nodep, V3DupFinderUser
|
||||
}
|
||||
|
||||
void V3DupFinder::dumpFile(const string& filename, bool tree) {
|
||||
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);
|
||||
|
||||
std::unordered_map<int, int> dist;
|
||||
|
@ -35,14 +35,14 @@ class EmitCMain final : EmitCBaseVisitor {
|
||||
|
||||
public:
|
||||
// CONSTRUCTORS
|
||||
explicit EmitCMain(AstNetlist*) { emitInt(); }
|
||||
EmitCMain() { emitInt(); }
|
||||
|
||||
private:
|
||||
// MAIN METHOD
|
||||
void emitInt() {
|
||||
const string filename = v3Global.opt.makeDir() + "/" + topClassName() + "__main.cpp";
|
||||
newCFile(filename, false /*slow*/, true /*source*/);
|
||||
V3OutCFile cf(filename);
|
||||
V3OutCFile cf{filename};
|
||||
m_ofp = &cf;
|
||||
|
||||
// Not defining main_time/vl_time_stamp, so
|
||||
@ -101,5 +101,5 @@ private:
|
||||
|
||||
void V3EmitCMain::emit() {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
EmitCMain(v3Global.rootp());
|
||||
{ EmitCMain visitor; }
|
||||
}
|
||||
|
@ -78,8 +78,8 @@ class CMakeEmitter final {
|
||||
}
|
||||
|
||||
static void emitOverallCMake() {
|
||||
const std::unique_ptr<std::ofstream> of(
|
||||
V3File::new_ofstream(v3Global.opt.makeDir() + "/" + v3Global.opt.prefix() + ".cmake"));
|
||||
const std::unique_ptr<std::ofstream> of{
|
||||
V3File::new_ofstream(v3Global.opt.makeDir() + "/" + v3Global.opt.prefix() + ".cmake")};
|
||||
const string name = v3Global.opt.prefix();
|
||||
|
||||
*of << "# Verilated -*- CMake -*-\n";
|
||||
|
@ -588,8 +588,8 @@ class EmitCModel final : public EmitCFunc {
|
||||
+ "__Dpi_Export_" + cvtToStr(splitFilenumInc() - 1)
|
||||
+ ".cpp";
|
||||
newCFile(filename, /* slow: */ false, /* source: */ true);
|
||||
m_ofp = v3Global.opt.systemC() ? new V3OutScFile(filename)
|
||||
: new V3OutCFile(filename);
|
||||
m_ofp = v3Global.opt.systemC() ? new V3OutScFile{filename}
|
||||
: new V3OutCFile{filename};
|
||||
m_lazyDecls.reset();
|
||||
m_ofp->putsHeader();
|
||||
puts(
|
||||
|
@ -670,7 +670,7 @@ void EmitCSyms::emitSymImp() {
|
||||
+ topClassName() + "* modelp)\n");
|
||||
puts(" : VerilatedSyms{contextp}\n");
|
||||
puts(" // Setup internal state of the Syms class\n");
|
||||
puts(" , __Vm_modelp(modelp)\n");
|
||||
puts(" , __Vm_modelp{modelp}\n");
|
||||
|
||||
if (v3Global.opt.mtasks()) {
|
||||
// TODO -- For now each model creates its own ThreadPool here,
|
||||
@ -694,9 +694,9 @@ void EmitCSyms::emitSymImp() {
|
||||
// Note we create N-1 threads in the thread pool. The thread
|
||||
// that calls eval() becomes the final Nth thread for the
|
||||
// duration of the eval call.
|
||||
puts(" , __Vm_threadPoolp(new VlThreadPool(_vm_contextp__, "
|
||||
puts(" , __Vm_threadPoolp{new VlThreadPool{_vm_contextp__, "
|
||||
+ cvtToStr(v3Global.opt.threads() - 1) + ", " + cvtToStr(v3Global.opt.profThreads())
|
||||
+ "))\n");
|
||||
+ "}}\n");
|
||||
}
|
||||
|
||||
puts(" // Setup module instances\n");
|
||||
|
@ -831,7 +831,7 @@ void V3EmitV::verilogForTree(AstNode* nodep, std::ostream& os) { EmitVStreamVisi
|
||||
|
||||
void V3EmitV::verilogPrefixedTree(AstNode* nodep, std::ostream& os, const string& prefix,
|
||||
int flWidth, AstSenTree* domainp, bool user3mark) {
|
||||
EmitVPrefixedVisitor(nodep, os, prefix, flWidth, domainp, user3mark);
|
||||
EmitVPrefixedVisitor{nodep, os, prefix, flWidth, domainp, user3mark};
|
||||
}
|
||||
|
||||
void V3EmitV::emitvFiles() {
|
||||
@ -843,7 +843,7 @@ void V3EmitV::emitvFiles() {
|
||||
V3OutVFile of(vfilep->name());
|
||||
of.puts("// DESCR"
|
||||
"IPTION: Verilator generated Verilog\n");
|
||||
EmitVFileVisitor visitor(vfilep->tblockp(), &of, true, false);
|
||||
EmitVFileVisitor visitor{vfilep->tblockp(), &of, true, false};
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -853,5 +853,5 @@ void V3EmitV::debugEmitV(const string& stage) {
|
||||
const string filename
|
||||
= v3Global.opt.makeDir() + "/" + v3Global.opt.prefix() + "__" + stage + ".v";
|
||||
V3OutVFile of(filename);
|
||||
EmitVFileVisitor visitor(v3Global.rootp(), &of, true, true);
|
||||
EmitVFileVisitor visitor{v3Global.rootp(), &of, true, true};
|
||||
}
|
||||
|
@ -392,10 +392,10 @@ void V3EmitXml::emitxml() {
|
||||
}
|
||||
{
|
||||
std::stringstream sstr;
|
||||
ModuleFilesXmlVisitor moduleFilesVisitor(v3Global.rootp(), sstr);
|
||||
HierCellsXmlVisitor cellsVisitor(v3Global.rootp(), sstr);
|
||||
ModuleFilesXmlVisitor moduleFilesVisitor{v3Global.rootp(), sstr};
|
||||
HierCellsXmlVisitor cellsVisitor{v3Global.rootp(), sstr};
|
||||
of.puts(sstr.str());
|
||||
}
|
||||
EmitXmlFileVisitor visitor(v3Global.rootp(), &of);
|
||||
EmitXmlFileVisitor visitor{v3Global.rootp(), &of};
|
||||
of.puts("</verilator_xml>\n");
|
||||
}
|
||||
|
@ -945,6 +945,6 @@ public:
|
||||
|
||||
void V3Expand::expandAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ExpandVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ExpandVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("expand", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -145,7 +145,7 @@ V3FileDependImp dependImp; // Depend implementation class
|
||||
// V3FileDependImp
|
||||
|
||||
inline void V3FileDependImp::writeDepend(const string& filename) {
|
||||
const std::unique_ptr<std::ofstream> ofp(V3File::new_ofstream(filename));
|
||||
const std::unique_ptr<std::ofstream> ofp{V3File::new_ofstream(filename)};
|
||||
if (ofp->fail()) v3fatal("Can't write " << filename);
|
||||
|
||||
for (const DependFile& i : m_filenameList) {
|
||||
@ -178,7 +178,7 @@ inline std::vector<string> V3FileDependImp::getAllDeps() const {
|
||||
}
|
||||
|
||||
inline void V3FileDependImp::writeTimes(const string& filename, const string& cmdlineIn) {
|
||||
const std::unique_ptr<std::ofstream> ofp(V3File::new_ofstream(filename));
|
||||
const std::unique_ptr<std::ofstream> ofp{V3File::new_ofstream(filename)};
|
||||
if (ofp->fail()) v3fatal("Can't write " << filename);
|
||||
|
||||
const string cmdline = stripQuotes(cmdlineIn);
|
||||
@ -213,7 +213,7 @@ inline void V3FileDependImp::writeTimes(const string& filename, const string& cm
|
||||
}
|
||||
|
||||
inline bool V3FileDependImp::checkTimes(const string& filename, const string& cmdlineIn) {
|
||||
const std::unique_ptr<std::ifstream> ifp(V3File::new_ifstream_nodepend(filename));
|
||||
const std::unique_ptr<std::ifstream> ifp{V3File::new_ifstream_nodepend(filename)};
|
||||
if (ifp->fail()) {
|
||||
UINFO(2, " --check-times failed: no input " << filename << endl);
|
||||
return false;
|
||||
|
@ -38,7 +38,7 @@ public:
|
||||
return new_ifstream_nodepend(filename);
|
||||
}
|
||||
static std::ifstream* new_ifstream_nodepend(const string& filename) {
|
||||
return new std::ifstream(filename.c_str());
|
||||
return new std::ifstream{filename.c_str()};
|
||||
}
|
||||
static std::ofstream* new_ofstream(const string& filename, bool append = false) {
|
||||
addTgtDepend(filename);
|
||||
@ -47,9 +47,9 @@ public:
|
||||
static std::ofstream* new_ofstream_nodepend(const string& filename, bool append = false) {
|
||||
createMakeDirFor(filename);
|
||||
if (append) {
|
||||
return new std::ofstream(filename.c_str(), std::ios::app);
|
||||
return new std::ofstream{filename.c_str(), std::ios::app};
|
||||
} else {
|
||||
return new std::ofstream(filename.c_str());
|
||||
return new std::ofstream{filename.c_str()};
|
||||
}
|
||||
}
|
||||
static FILE* new_fopen_w(const string& filename) {
|
||||
|
@ -570,7 +570,7 @@ void GateVisitor::optimizeSignals(bool allowMultiIn) {
|
||||
AstNode* logicp = logicVertexp->nodep();
|
||||
if (logicVertexp->reducible()) {
|
||||
// Can we eliminate?
|
||||
GateOkVisitor okVisitor(logicp, vvertexp->isClock(), false);
|
||||
GateOkVisitor okVisitor{logicp, vvertexp->isClock(), false};
|
||||
const bool multiInputs = okVisitor.rhsVarRefs().size() > 1;
|
||||
// Was it ok?
|
||||
bool doit = okVisitor.isSimple();
|
||||
@ -884,7 +884,7 @@ public:
|
||||
|
||||
void GateVisitor::optimizeElimVar(AstVarScope* varscp, AstNode* substp, AstNode* consumerp) {
|
||||
if (debug() >= 5) consumerp->dumpTree(cout, " elimUsePre: ");
|
||||
GateElimVisitor elimVisitor(consumerp, varscp, substp, nullptr);
|
||||
GateElimVisitor elimVisitor{consumerp, varscp, substp, nullptr};
|
||||
if (elimVisitor.didReplace()) {
|
||||
if (debug() >= 9) consumerp->dumpTree(cout, " elimUseCns: ");
|
||||
// Caution: Can't let V3Const change our handle to consumerp, such as by
|
||||
@ -1148,7 +1148,7 @@ private:
|
||||
UASSERT_OBJ(vvertexp->dedupable(), vvertexp->varScp(),
|
||||
"GateLogicVertex* visit should have returned nullptr "
|
||||
"if consumer var vertex is not dedupable.");
|
||||
GateOkVisitor okVisitor(lvertexp->nodep(), false, true);
|
||||
GateOkVisitor okVisitor{lvertexp->nodep(), false, true};
|
||||
if (okVisitor.isSimple()) {
|
||||
AstVarScope* dupVarScopep = dupVarRefp->varScopep();
|
||||
GateVarVertex* dupVvertexp
|
||||
@ -1226,7 +1226,7 @@ public:
|
||||
|
||||
void GateVisitor::dedupe() {
|
||||
AstNode::user2ClearTree();
|
||||
GateDedupeGraphVisitor deduper(&m_graph);
|
||||
GateDedupeGraphVisitor deduper{&m_graph};
|
||||
// Traverse starting from each of the clocks
|
||||
UINFO(9, "Gate dedupe() clocks:\n");
|
||||
for (V3GraphVertex* itp = m_graph.verticesBeginp(); itp; itp = itp->verticesNextp()) {
|
||||
@ -1367,7 +1367,7 @@ public:
|
||||
|
||||
void GateVisitor::mergeAssigns() {
|
||||
UINFO(6, "mergeAssigns\n");
|
||||
GateMergeAssignsGraphVisitor merger(&m_graph);
|
||||
GateMergeAssignsGraphVisitor merger{&m_graph};
|
||||
for (V3GraphVertex* itp = m_graph.verticesBeginp(); itp; itp = itp->verticesNextp()) {
|
||||
if (GateVarVertex* vvertexp = dynamic_cast<GateVarVertex*>(itp)) {
|
||||
merger.mergeAssignsTree(vvertexp);
|
||||
@ -1553,7 +1553,7 @@ public:
|
||||
void GateVisitor::decomposeClkVectors() {
|
||||
UINFO(9, "Starting clock decomposition" << endl);
|
||||
AstNode::user2ClearTree();
|
||||
GateClkDecompGraphVisitor decomposer(&m_graph);
|
||||
GateClkDecompGraphVisitor decomposer{&m_graph};
|
||||
for (V3GraphVertex* itp = m_graph.verticesBeginp(); itp; itp = itp->verticesNextp()) {
|
||||
if (GateVarVertex* vertp = dynamic_cast<GateVarVertex*>(itp)) {
|
||||
AstVarScope* vsp = vertp->varScp();
|
||||
@ -1601,8 +1601,8 @@ public:
|
||||
void V3Gate::gateAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
GateVisitor visitor(nodep);
|
||||
GateDeassignVisitor deassign(nodep);
|
||||
GateVisitor visitor{nodep};
|
||||
GateDeassignVisitor deassign{nodep};
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("gate", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -147,7 +147,7 @@ private:
|
||||
{
|
||||
// Make the new clock signals and replace any activate references
|
||||
// See rename, it does some AstNode::userClearTree()'s
|
||||
GenClkRenameVisitor visitor(nodep, m_topModp);
|
||||
GenClkRenameVisitor visitor{nodep, m_topModp};
|
||||
}
|
||||
}
|
||||
virtual void visit(AstNodeModule* nodep) override {
|
||||
@ -222,6 +222,6 @@ public:
|
||||
|
||||
void V3GenClk::genClkAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ GenClkReadVisitor visitor(nodep); } // Destruct before checking
|
||||
{ GenClkReadVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("genclk", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -53,8 +53,8 @@ template <typename T> class VRestorer {
|
||||
|
||||
public:
|
||||
explicit VRestorer(T& permr)
|
||||
: m_ref(permr)
|
||||
, m_saved(permr) {}
|
||||
: m_ref{permr}
|
||||
, m_saved{permr} {}
|
||||
~VRestorer() { m_ref = m_saved; }
|
||||
VL_UNCOPYABLE(VRestorer);
|
||||
};
|
||||
|
@ -314,7 +314,7 @@ void V3Graph::dumpDotFilePrefixedAlways(const string& nameComment, bool colorAsS
|
||||
void V3Graph::dumpDotFile(const string& filename, bool colorAsSubgraph) const {
|
||||
// This generates a file used by graphviz, https://www.graphviz.org
|
||||
// "hardcoded" parameters:
|
||||
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);
|
||||
|
||||
// Header
|
||||
|
@ -122,8 +122,8 @@ public:
|
||||
// CONSTRUCTORS
|
||||
DfaEdge(DfaGraph* graphp, DfaVertex* fromp, DfaVertex* top, const DfaInput& input)
|
||||
: V3GraphEdge{graphp, fromp, top, 1}
|
||||
, m_input(input)
|
||||
, m_complement(false) {}
|
||||
, m_input{input}
|
||||
, m_complement{false} {}
|
||||
DfaEdge(DfaGraph* graphp, DfaVertex* fromp, DfaVertex* top, const DfaEdge* copyfrom)
|
||||
: V3GraphEdge{graphp, fromp, top, copyfrom->weight()}
|
||||
, m_input{copyfrom->input()}
|
||||
|
@ -488,11 +488,11 @@ public:
|
||||
// V3Hasher methods
|
||||
|
||||
V3Hash V3Hasher::operator()(AstNode* nodep) const {
|
||||
if (!nodep->user4()) { HasherVisitor visitor(nodep); }
|
||||
if (!nodep->user4()) { HasherVisitor visitor{nodep}; }
|
||||
return V3Hash(nodep->user4());
|
||||
}
|
||||
|
||||
V3Hash V3Hasher::uncachedHash(const AstNode* nodep) {
|
||||
HasherVisitor visitor(nodep);
|
||||
HasherVisitor visitor{nodep};
|
||||
return visitor.finalHash();
|
||||
}
|
||||
|
@ -208,7 +208,7 @@ string V3HierBlock::vFileIfNecessary() const {
|
||||
}
|
||||
|
||||
void V3HierBlock::writeCommandArgsFile(bool forCMake) const {
|
||||
std::unique_ptr<std::ofstream> of(V3File::new_ofstream(commandArgsFileName(forCMake)));
|
||||
std::unique_ptr<std::ofstream> of{V3File::new_ofstream(commandArgsFileName(forCMake))};
|
||||
*of << "--cc\n";
|
||||
|
||||
if (!forCMake) {
|
||||
@ -398,7 +398,7 @@ void V3HierBlockPlan::writeCommandArgsFiles(bool forCMake) const {
|
||||
it->second->writeCommandArgsFile(forCMake);
|
||||
}
|
||||
// For the top module
|
||||
std::unique_ptr<std::ofstream> of(V3File::new_ofstream(topCommandArgsFileName(forCMake)));
|
||||
std::unique_ptr<std::ofstream> of{V3File::new_ofstream(topCommandArgsFileName(forCMake))};
|
||||
if (!forCMake) {
|
||||
// Load wrappers first not to be overwritten by the original HDL
|
||||
for (const_iterator it = begin(); it != end(); ++it) {
|
||||
|
@ -548,7 +548,7 @@ private:
|
||||
// Clear var markings and find cell cross references
|
||||
AstNode::user2ClearTree();
|
||||
AstNode::user4ClearTree();
|
||||
{ InlineCollectVisitor(nodep->modp()); } // {} to destroy visitor immediately
|
||||
{ InlineCollectVisitor{nodep->modp()}; } // {} to destroy visitor immediately
|
||||
// Create data for dotted variable resolution
|
||||
AstCellInline* inlinep
|
||||
= new AstCellInline(nodep->fileline(), nodep->name(), nodep->modp()->origName(),
|
||||
@ -591,7 +591,7 @@ private:
|
||||
&& pinNewVarp->direction() == VDirection::OUTPUT);
|
||||
}
|
||||
// Cleanup var names, etc, to not conflict
|
||||
{ InlineRelinkVisitor(newmodp, m_modp, nodep); }
|
||||
{ InlineRelinkVisitor{newmodp, m_modp, nodep}; }
|
||||
// Move statements to top module
|
||||
if (debug() >= 9) newmodp->dumpTree(cout, "fixmod:");
|
||||
AstNode* stmtsp = newmodp->stmtsp();
|
||||
@ -713,8 +713,8 @@ void V3Inline::inlineAll(AstNetlist* nodep) {
|
||||
AstUser1InUse m_inuser1; // output of InlineMarkVisitor,
|
||||
// input to InlineVisitor.
|
||||
// Scoped to clean up temp userN's
|
||||
{ InlineMarkVisitor mvisitor(nodep); }
|
||||
{ InlineVisitor visitor(nodep); }
|
||||
{ InlineMarkVisitor mvisitor{nodep}; }
|
||||
{ InlineVisitor visitor{nodep}; }
|
||||
// Remove all modules that were inlined
|
||||
// V3Dead will also clean them up, but if we have debug on, it's a good
|
||||
// idea to avoid dumping the hugely exploded tree.
|
||||
@ -725,6 +725,6 @@ void V3Inline::inlineAll(AstNetlist* nodep) {
|
||||
VL_DO_DANGLING(modp->unlinkFrBack()->deleteTree(), modp);
|
||||
}
|
||||
}
|
||||
{ InlineIntfRefVisitor crvisitor(nodep); }
|
||||
{ InlineIntfRefVisitor crvisitor{nodep}; }
|
||||
V3Global::dumpCheckGlobalTree("inline", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -487,12 +487,12 @@ private:
|
||||
|
||||
static AstNode* extendOrSel(FileLine* fl, AstNode* rhsp, AstNode* cmpWidthp) {
|
||||
if (cmpWidthp->width() > rhsp->width()) {
|
||||
rhsp = (rhsp->isSigned() ? static_cast<AstNode*>(new AstExtendS(fl, rhsp))
|
||||
: static_cast<AstNode*>(new AstExtend(fl, rhsp)));
|
||||
rhsp = (rhsp->isSigned() ? static_cast<AstNode*>(new AstExtendS{fl, rhsp})
|
||||
: static_cast<AstNode*>(new AstExtend{fl, rhsp}));
|
||||
// Need proper widthMin, which may differ from AstSel created above
|
||||
rhsp->dtypeFrom(cmpWidthp);
|
||||
} else if (cmpWidthp->width() < rhsp->width()) {
|
||||
rhsp = new AstSel(fl, rhsp, 0, cmpWidthp->width());
|
||||
rhsp = new AstSel{fl, rhsp, 0, cmpWidthp->width()};
|
||||
// Need proper widthMin, which may differ from AstSel created above
|
||||
rhsp->dtypeFrom(cmpWidthp);
|
||||
}
|
||||
@ -610,12 +610,12 @@ void V3Inst::checkOutputShort(AstPin* nodep) {
|
||||
|
||||
void V3Inst::instAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ InstVisitor visitor(nodep); } // Destruct before checking
|
||||
{ InstVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("inst", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
||||
void V3Inst::dearrayAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ InstDeVisitor visitor(nodep); } // Destruct before checking
|
||||
{ InstDeVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("dearray", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -294,7 +294,7 @@ private:
|
||||
};
|
||||
|
||||
uint32_t V3InstrCount::count(AstNode* nodep, bool assertNoDups, std::ostream* osp) {
|
||||
InstrCountVisitor visitor(nodep, assertNoDups, osp);
|
||||
InstrCountVisitor visitor{nodep, assertNoDups, osp};
|
||||
if (osp) InstrCountDumpVisitor dumper(nodep, osp);
|
||||
return visitor.instrCount();
|
||||
}
|
||||
|
@ -461,12 +461,12 @@ private:
|
||||
virtual void visit(AstCFunc* nodep) override {
|
||||
if (nodep->entryPoint()) {
|
||||
// Usage model 1: Simulate all C code, doing lifetime analysis
|
||||
LifeVisitor visitor(nodep, m_statep);
|
||||
LifeVisitor visitor{nodep, m_statep};
|
||||
}
|
||||
}
|
||||
virtual void visit(AstNodeProcedure* nodep) override {
|
||||
// Usage model 2: Cleanup basic blocks
|
||||
LifeVisitor visitor(nodep, m_statep);
|
||||
LifeVisitor visitor{nodep, m_statep};
|
||||
}
|
||||
virtual void visit(AstVar*) override {} // Accelerate
|
||||
virtual void visit(AstNodeStmt*) override {} // Accelerate
|
||||
@ -489,7 +489,7 @@ void V3Life::lifeAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
LifeState state;
|
||||
LifeTopVisitor visitor(nodep, &state);
|
||||
LifeTopVisitor visitor{nodep, &state};
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("life", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -271,7 +271,7 @@ private:
|
||||
squashAssignposts();
|
||||
|
||||
// Replace any node4p varscopes with the new scope
|
||||
LifePostElimVisitor visitor(nodep);
|
||||
LifePostElimVisitor visitor{nodep};
|
||||
}
|
||||
virtual void visit(AstVarRef* nodep) override {
|
||||
// Consumption/generation of a variable,
|
||||
@ -348,6 +348,6 @@ public:
|
||||
void V3LifePost::lifepostAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
// Mark redundant AssignPost
|
||||
{ LifePostDlyVisitor visitor(nodep); } // Destruct before checking
|
||||
{ LifePostDlyVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("life_post", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -523,5 +523,5 @@ public:
|
||||
|
||||
void V3LinkCells::link(AstNetlist* nodep, VInFilter* filterp, V3ParseSym* parseSymp) {
|
||||
UINFO(4, __FUNCTION__ << ": " << endl);
|
||||
LinkCellsVisitor visitor(nodep, filterp, parseSymp);
|
||||
LinkCellsVisitor visitor{nodep, filterp, parseSymp};
|
||||
}
|
||||
|
@ -165,7 +165,7 @@ public:
|
||||
void dump(const string& nameComment = "linkdot", bool force = false) {
|
||||
if (debug() >= 6 || force) {
|
||||
const string filename = v3Global.debugFilename(nameComment) + ".txt";
|
||||
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);
|
||||
std::ostream& os = *logp;
|
||||
m_syms.dump(os);
|
||||
@ -1766,7 +1766,7 @@ void LinkDotState::computeIfaceModSyms() {
|
||||
for (const auto& itr : m_ifaceModSyms) {
|
||||
AstIface* nodep = itr.first;
|
||||
VSymEnt* symp = itr.second;
|
||||
LinkDotIfaceVisitor(nodep, symp, this);
|
||||
LinkDotIfaceVisitor{nodep, symp, this};
|
||||
}
|
||||
m_ifaceModSyms.clear();
|
||||
}
|
||||
@ -3042,13 +3042,13 @@ void V3LinkDot::linkDotGuts(AstNetlist* rootp, VLinkDotStep step) {
|
||||
v3Global.rootp()->dumpTreeFile(v3Global.debugFilename("prelinkdot.tree"));
|
||||
}
|
||||
LinkDotState state(rootp, step);
|
||||
LinkDotFindVisitor visitor(rootp, &state);
|
||||
LinkDotFindVisitor visitor{rootp, &state};
|
||||
if (LinkDotState::debug() >= 5 || v3Global.opt.dumpTree() >= 9) {
|
||||
v3Global.rootp()->dumpTreeFile(v3Global.debugFilename("prelinkdot-find.tree"));
|
||||
}
|
||||
if (step == LDS_PRIMARY || step == LDS_PARAMED) {
|
||||
// Initial link stage, resolve parameters
|
||||
LinkDotParamVisitor visitors(rootp, &state);
|
||||
LinkDotParamVisitor visitors{rootp, &state};
|
||||
if (LinkDotState::debug() >= 5 || v3Global.opt.dumpTree() >= 9) {
|
||||
v3Global.rootp()->dumpTreeFile(v3Global.debugFilename("prelinkdot-param.tree"));
|
||||
}
|
||||
@ -3056,7 +3056,7 @@ void V3LinkDot::linkDotGuts(AstNetlist* rootp, VLinkDotStep step) {
|
||||
} else if (step == LDS_SCOPED) {
|
||||
// Well after the initial link when we're ready to operate on the flat design,
|
||||
// process AstScope's. This needs to be separate pass after whole hierarchy graph created.
|
||||
LinkDotScopeVisitor visitors(rootp, &state);
|
||||
LinkDotScopeVisitor visitors{rootp, &state};
|
||||
v3Global.assertScoped(true);
|
||||
if (LinkDotState::debug() >= 5 || v3Global.opt.dumpTree() >= 9) {
|
||||
v3Global.rootp()->dumpTreeFile(v3Global.debugFilename("prelinkdot-scoped.tree"));
|
||||
@ -3069,5 +3069,5 @@ void V3LinkDot::linkDotGuts(AstNetlist* rootp, VLinkDotStep step) {
|
||||
state.computeIfaceVarSyms();
|
||||
state.computeScopeAliases();
|
||||
state.dump();
|
||||
LinkDotResolveVisitor visitorb(rootp, &state);
|
||||
LinkDotResolveVisitor visitorb{rootp, &state};
|
||||
}
|
||||
|
@ -246,6 +246,6 @@ public:
|
||||
|
||||
void V3LinkInc::linkIncrements(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ LinkIncVisitor bvisitor(nodep); } // Destruct before checking
|
||||
{ LinkIncVisitor bvisitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("linkInc", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -287,6 +287,6 @@ public:
|
||||
|
||||
void V3LinkJump::linkJump(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ LinkJumpVisitor bvisitor(nodep); } // Destruct before checking
|
||||
{ LinkJumpVisitor bvisitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("link", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -298,12 +298,12 @@ public:
|
||||
|
||||
void V3LinkLValue::linkLValue(AstNetlist* nodep) {
|
||||
UINFO(4, __FUNCTION__ << ": " << endl);
|
||||
{ LinkLValueVisitor visitor(nodep, VAccess::NOCHANGE); } // Destruct before checking
|
||||
{ LinkLValueVisitor visitor{nodep, VAccess::NOCHANGE}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("linklvalue", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
void V3LinkLValue::linkLValueSet(AstNode* nodep) {
|
||||
// Called by later link functions when it is known a node needs
|
||||
// to be converted to a lvalue.
|
||||
UINFO(9, __FUNCTION__ << ": " << endl);
|
||||
LinkLValueVisitor visitor(nodep, VAccess::WRITE);
|
||||
LinkLValueVisitor visitor{nodep, VAccess::WRITE};
|
||||
}
|
||||
|
@ -656,6 +656,6 @@ public:
|
||||
|
||||
void V3LinkParse::linkParse(AstNetlist* rootp) {
|
||||
UINFO(4, __FUNCTION__ << ": " << endl);
|
||||
{ LinkParseVisitor visitor(rootp); } // Destruct before checking
|
||||
{ LinkParseVisitor visitor{rootp}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("linkparse", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -573,8 +573,8 @@ public:
|
||||
void V3LinkResolve::linkResolve(AstNetlist* rootp) {
|
||||
UINFO(4, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
LinkResolveVisitor visitor(rootp);
|
||||
LinkBotupVisitor visitorb(rootp);
|
||||
LinkResolveVisitor visitor{rootp};
|
||||
LinkBotupVisitor visitorb{rootp};
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("linkresolve", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -201,6 +201,6 @@ public:
|
||||
|
||||
void V3Localize::localizeAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ LocalizeVisitor visitor(nodep); } // Destruct before checking
|
||||
{ LocalizeVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("localize", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -179,17 +179,17 @@ private:
|
||||
}
|
||||
if (AstAnd* const andp = VN_CAST(rhsp, And)) {
|
||||
UASSERT_OBJ(andp->rhsp() == condp, rhsp, "Should not try to fold this");
|
||||
return new AstAnd(andp->fileline(), andp->lhsp()->cloneTree(false), resp);
|
||||
return new AstAnd{andp->fileline(), andp->lhsp()->cloneTree(false), resp};
|
||||
}
|
||||
} else if (AstAnd* const andp = VN_CAST(rhsp, And)) {
|
||||
if (andp->lhsp()->sameTree(m_mgCondp)) {
|
||||
return condTrue ? maskLsb(andp->rhsp()->unlinkFrBack())
|
||||
: new AstConst(rhsp->fileline(), AstConst::BitFalse());
|
||||
: new AstConst{rhsp->fileline(), AstConst::BitFalse()};
|
||||
} else {
|
||||
UASSERT_OBJ(andp->rhsp()->sameTree(m_mgCondp), rhsp,
|
||||
"AstAnd doesn't hold condition expression");
|
||||
return condTrue ? maskLsb(andp->lhsp()->unlinkFrBack())
|
||||
: new AstConst(rhsp->fileline(), AstConst::BitFalse());
|
||||
: new AstConst{rhsp->fileline(), AstConst::BitFalse()};
|
||||
}
|
||||
}
|
||||
rhsp->v3fatalSrc("Don't know how to fold expression");
|
||||
@ -337,6 +337,6 @@ public:
|
||||
|
||||
void V3MergeCond::mergeAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ MergeCondVisitor visitor(nodep); }
|
||||
{ MergeCondVisitor visitor{nodep}; }
|
||||
V3Global::dumpCheckGlobalTree("merge_cond", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -142,6 +142,6 @@ public:
|
||||
|
||||
void V3Name::nameAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ NameVisitor visitor(nodep); } // Destruct before checking
|
||||
{ NameVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("name", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -1499,7 +1499,7 @@ void V3Options::parseOptsFile(FileLine* fl, const string& filename, bool rel) {
|
||||
// Read the specified -f filename and process as arguments
|
||||
UINFO(1, "Reading Options File " << filename << endl);
|
||||
|
||||
const std::unique_ptr<std::ifstream> ifp(V3File::new_ifstream(filename));
|
||||
const std::unique_ptr<std::ifstream> ifp{V3File::new_ifstream(filename)};
|
||||
if (ifp->fail()) {
|
||||
fl->v3error("Cannot open -f command file: " + filename);
|
||||
return;
|
||||
|
@ -1177,13 +1177,13 @@ private:
|
||||
virtual void visit(AstAlwaysPublic* nodep) override { iterateNewStmt(nodep); }
|
||||
virtual void visit(AstAssignAlias* nodep) override { iterateNewStmt(nodep); }
|
||||
virtual void visit(AstAssignW* nodep) override {
|
||||
OrderClkAssVisitor visitor(nodep);
|
||||
OrderClkAssVisitor visitor{nodep};
|
||||
m_inClkAss = visitor.isClkAss();
|
||||
iterateNewStmt(nodep);
|
||||
m_inClkAss = false;
|
||||
}
|
||||
virtual void visit(AstAssignPre* nodep) override {
|
||||
OrderClkAssVisitor visitor(nodep);
|
||||
OrderClkAssVisitor visitor{nodep};
|
||||
m_inClkAss = visitor.isClkAss();
|
||||
m_inPre = true;
|
||||
iterateNewStmt(nodep);
|
||||
@ -1191,7 +1191,7 @@ private:
|
||||
m_inClkAss = false;
|
||||
}
|
||||
virtual void visit(AstAssignPost* nodep) override {
|
||||
OrderClkAssVisitor visitor(nodep);
|
||||
OrderClkAssVisitor visitor{nodep};
|
||||
m_inClkAss = visitor.isClkAss();
|
||||
m_inPost = true;
|
||||
iterateNewStmt(nodep);
|
||||
@ -1545,7 +1545,7 @@ void OrderVisitor::processDomainsIterate(OrderEitherVertex* vertexp) {
|
||||
void OrderVisitor::processEdgeReport() {
|
||||
// Make report of all signal names and what clock edges they have
|
||||
const string filename = v3Global.debugFilename("order_edges.txt");
|
||||
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);
|
||||
// Testing emitter: V3EmitV::verilogForTree(v3Global.rootp(), *logp);
|
||||
|
||||
@ -1777,7 +1777,7 @@ AstActive* OrderVisitor::processMoveOneLogic(const OrderLogicVertex* lvertexp,
|
||||
newFuncpr->addStmtsp(nodep);
|
||||
if (v3Global.opt.outputSplitCFuncs()) {
|
||||
// Add in the number of nodes we're adding
|
||||
EmitCBaseCounterVisitor visitor(nodep);
|
||||
EmitCBaseCounterVisitor visitor{nodep};
|
||||
newStmtsr += visitor.count();
|
||||
}
|
||||
}
|
||||
@ -2005,7 +2005,7 @@ void OrderVisitor::process() {
|
||||
if (false && debug()) {
|
||||
const string dfilename
|
||||
= v3Global.opt.makeDir() + "/" + v3Global.opt.prefix() + "_INT_order";
|
||||
const std::unique_ptr<std::ofstream> logp(V3File::new_ofstream(dfilename));
|
||||
const std::unique_ptr<std::ofstream> logp{V3File::new_ofstream(dfilename)};
|
||||
if (logp->fail()) v3fatal("Can't write " << dfilename);
|
||||
m_graph.dump(*logp);
|
||||
}
|
||||
@ -2017,7 +2017,7 @@ void OrderVisitor::process() {
|
||||
void V3Order::orderAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
OrderClkMarkVisitor markVisitor(nodep);
|
||||
OrderClkMarkVisitor markVisitor{nodep};
|
||||
OrderVisitor visitor;
|
||||
visitor.main(nodep);
|
||||
} // Destruct before checking
|
||||
|
@ -236,8 +236,8 @@ void V3Os::createDir(const string& dirname) {
|
||||
}
|
||||
|
||||
void V3Os::unlinkRegexp(const string& dir, const string& regexp) {
|
||||
if (DIR* dirp = opendir(dir.c_str())) {
|
||||
while (struct dirent* direntp = readdir(dirp)) {
|
||||
if (DIR* const dirp = opendir(dir.c_str())) {
|
||||
while (struct dirent* const direntp = readdir(dirp)) {
|
||||
if (VString::wildmatch(direntp->d_name, regexp.c_str())) {
|
||||
const string fullname = dir + "/" + string(direntp->d_name);
|
||||
#if defined(_WIN32) || defined(__MINGW32__)
|
||||
@ -273,7 +273,7 @@ string V3Os::trueRandom(size_t size) {
|
||||
BCRYPT_USE_SYSTEM_PREFERRED_RNG);
|
||||
if (!BCRYPT_SUCCESS(hr)) v3fatal("Could not acquire random data.");
|
||||
#else
|
||||
std::ifstream is("/dev/urandom", std::ios::in | std::ios::binary);
|
||||
std::ifstream is{"/dev/urandom", std::ios::in | std::ios::binary};
|
||||
// This read uses the size of the buffer.
|
||||
// Flawfinder: ignore
|
||||
if (VL_UNCOVERABLE(!is.read(data, size))) {
|
||||
|
@ -1223,6 +1223,6 @@ public:
|
||||
|
||||
void V3Param::param(AstNetlist* rootp) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ParamVisitor visitor(rootp); } // Destruct before checking
|
||||
{ ParamVisitor visitor{rootp}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("param", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -624,8 +624,8 @@ public:
|
||||
static void dumpCpFilePrefixed(const V3Graph* graphp, const string& nameComment) {
|
||||
const string filename = v3Global.debugFilename(nameComment) + ".txt";
|
||||
UINFO(1, "Writing " << filename << endl);
|
||||
std::unique_ptr<std::ofstream> ofp(V3File::new_ofstream(filename));
|
||||
std::ostream* osp = &(*ofp); // &* needed to deref unique_ptr
|
||||
std::unique_ptr<std::ofstream> ofp{V3File::new_ofstream(filename)};
|
||||
std::ostream* const osp = &(*ofp); // &* needed to deref unique_ptr
|
||||
if (osp->fail()) v3fatalStatic("Can't write " << filename);
|
||||
|
||||
// Find start vertex with longest CP
|
||||
@ -2077,7 +2077,7 @@ void ThreadSchedule::dumpDotFilePrefixedAlways(const string& nameComment) const
|
||||
|
||||
void ThreadSchedule::dumpDotFile(const string& filename) const {
|
||||
// This generates a file used by graphviz, https://www.graphviz.org
|
||||
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);
|
||||
auto* depGraph = v3Global.rootp()->execGraphp()->depGraphp();
|
||||
|
||||
@ -2765,8 +2765,8 @@ static const std::vector<AstCFunc*> createThreadFunctions(const ThreadSchedule&
|
||||
funcp->argTypes("void* voidSelf, bool even_cycle");
|
||||
|
||||
// Setup vlSelf an vlSyms
|
||||
funcp->addStmtsp(new AstCStmt(fl, EmitCBaseVisitor::voidSelfAssign(modp)));
|
||||
funcp->addStmtsp(new AstCStmt(fl, EmitCBaseVisitor::symClassAssign()));
|
||||
funcp->addStmtsp(new AstCStmt{fl, EmitCBaseVisitor::voidSelfAssign(modp)});
|
||||
funcp->addStmtsp(new AstCStmt{fl, EmitCBaseVisitor::symClassAssign()});
|
||||
|
||||
// Invoke each mtask scheduled to this thread from the thread function
|
||||
for (const ExecMTask* const mtaskp : thread) {
|
||||
|
@ -427,6 +427,6 @@ public:
|
||||
|
||||
void V3Premit::premitAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ PremitVisitor visitor(nodep); } // Destruct before checking
|
||||
{ PremitVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("premit", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -246,8 +246,8 @@ public:
|
||||
void V3Randomize::randomizeNetlist(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
RandomizeMarkVisitor markVisitor(nodep);
|
||||
RandomizeVisitor visitor(nodep);
|
||||
RandomizeMarkVisitor markVisitor{nodep};
|
||||
RandomizeVisitor visitor{nodep};
|
||||
}
|
||||
V3Global::dumpCheckGlobalTree("randomize", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -267,6 +267,6 @@ public:
|
||||
|
||||
void V3Reloop::reloopAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ReloopVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ReloopVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("reloop", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -402,8 +402,8 @@ public:
|
||||
void V3Scope::scopeAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
ScopeVisitor visitor(nodep);
|
||||
ScopeCleanupVisitor cleanVisitor(nodep);
|
||||
ScopeVisitor visitor{nodep};
|
||||
ScopeCleanupVisitor cleanVisitor{nodep};
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("scope", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -236,6 +236,6 @@ public:
|
||||
|
||||
void V3Slice::sliceAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ SliceVisitor visitor(nodep); } // Destruct before checking
|
||||
{ SliceVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("slice", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -932,7 +932,7 @@ protected:
|
||||
|
||||
// Map each AstNodeIf to the set of colors (split always blocks)
|
||||
// it must participate in. Also find the whole set of colors.
|
||||
IfColorVisitor ifColor(nodep);
|
||||
IfColorVisitor ifColor{nodep};
|
||||
|
||||
if (ifColor.colors().size() > 1) {
|
||||
// Counting original always blocks rather than newly-split
|
||||
@ -942,7 +942,7 @@ protected:
|
||||
|
||||
// Visit through the original always block one more time,
|
||||
// and emit the split always blocks into m_replaceBlocks:
|
||||
EmitSplitVisitor emitSplit(nodep, &ifColor, &(m_replaceBlocks[nodep]));
|
||||
EmitSplitVisitor emitSplit{nodep, &ifColor, &(m_replaceBlocks[nodep])};
|
||||
emitSplit.go();
|
||||
}
|
||||
}
|
||||
@ -964,11 +964,11 @@ private:
|
||||
|
||||
void V3Split::splitReorderAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ ReorderVisitor visitor(nodep); } // Destruct before checking
|
||||
{ ReorderVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("reorder", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
void V3Split::splitAlwaysAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ SplitVisitor visitor(nodep); } // Destruct before checking
|
||||
{ SplitVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("split", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -144,11 +144,11 @@ private:
|
||||
newp->user1(true); // So we don't clone it again
|
||||
nodep->addNextHere(newp);
|
||||
{ // Delete stuff we don't want in old
|
||||
SplitAsCleanVisitor visitor(nodep, m_splitVscp, false);
|
||||
SplitAsCleanVisitor visitor{nodep, m_splitVscp, false};
|
||||
if (debug() >= 9) nodep->dumpTree(cout, "-out0: ");
|
||||
}
|
||||
{ // Delete stuff we don't want in new
|
||||
SplitAsCleanVisitor visitor(newp, m_splitVscp, true);
|
||||
SplitAsCleanVisitor visitor{newp, m_splitVscp, true};
|
||||
if (debug() >= 9) newp->dumpTree(cout, "-out1: ");
|
||||
}
|
||||
}
|
||||
@ -159,7 +159,7 @@ private:
|
||||
AstVarScope* lastSplitVscp = nullptr;
|
||||
while (!nodep->user1()) {
|
||||
// Find any splittable variables
|
||||
SplitAsFindVisitor visitor(nodep);
|
||||
SplitAsFindVisitor visitor{nodep};
|
||||
m_splitVscp = visitor.splitVscp();
|
||||
if (m_splitVscp && m_splitVscp == lastSplitVscp) {
|
||||
// We did this last time! Something's stuck!
|
||||
@ -194,6 +194,6 @@ public:
|
||||
|
||||
void V3SplitAs::splitAsAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ SplitAsVisitor visitor(nodep); } // Destruct before checking
|
||||
{ SplitAsVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("splitas", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -1250,11 +1250,11 @@ void V3SplitVar::splitVariable(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
SplitVarRefsMap refs;
|
||||
{
|
||||
SplitUnpackedVarVisitor visitor(nodep);
|
||||
SplitUnpackedVarVisitor visitor{nodep};
|
||||
refs = visitor.getPackedVarRefs();
|
||||
}
|
||||
V3Global::dumpCheckGlobalTree("split_var", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 9);
|
||||
{ SplitPackedVarVisitor visitor(nodep, refs); }
|
||||
{ SplitPackedVarVisitor visitor{nodep, refs}; }
|
||||
V3Global::dumpCheckGlobalTree("split_var", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 9);
|
||||
}
|
||||
|
||||
|
@ -279,7 +279,7 @@ public:
|
||||
// Top Stats class
|
||||
|
||||
void V3Stats::statsStageAll(AstNetlist* nodep, const string& stage, bool fast) {
|
||||
StatsVisitor visitor(nodep, stage, fast);
|
||||
StatsVisitor visitor{nodep, stage, fast};
|
||||
}
|
||||
|
||||
void V3Stats::statsFinalAll(AstNetlist* nodep) {
|
||||
|
@ -222,7 +222,7 @@ void V3Stats::statsReport() {
|
||||
// Open stats file
|
||||
const string filename
|
||||
= v3Global.opt.hierTopDataDir() + "/" + v3Global.opt.prefix() + "__stats.txt";
|
||||
std::ofstream* ofp(V3File::new_ofstream(filename));
|
||||
std::ofstream* ofp{V3File::new_ofstream(filename)};
|
||||
if (ofp->fail()) v3fatal("Can't write " << filename);
|
||||
|
||||
StatsReport reporter(ofp);
|
||||
|
@ -314,7 +314,7 @@ private:
|
||||
SubstVarEntry* entryp = getEntryp(varrefp);
|
||||
if (AstNode* substp = entryp->substWord(nodep, word)) {
|
||||
// Check that the RHS hasn't changed value since we recorded it.
|
||||
SubstUseVisitor visitor(substp, entryp->getWordStep(word));
|
||||
SubstUseVisitor visitor{substp, entryp->getWordStep(word)};
|
||||
if (visitor.ok()) {
|
||||
VL_DO_DANGLING(replaceSubstEtc(nodep, substp), nodep);
|
||||
} else {
|
||||
@ -341,7 +341,7 @@ private:
|
||||
entryp->assignComplex();
|
||||
} else if (AstNode* substp = entryp->substWhole(nodep)) {
|
||||
// Check that the RHS hasn't changed value since we recorded it.
|
||||
SubstUseVisitor visitor(substp, entryp->getWholeStep());
|
||||
SubstUseVisitor visitor{substp, entryp->getWholeStep()};
|
||||
if (visitor.ok()) {
|
||||
UINFO(8, " USEwhole " << nodep << endl);
|
||||
VL_DO_DANGLING(replaceSubstEtc(nodep, substp), nodep);
|
||||
@ -380,6 +380,6 @@ public:
|
||||
|
||||
void V3Subst::substituteAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ SubstVisitor visitor(nodep); } // Destruct before checking
|
||||
{ SubstVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("subst", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -317,7 +317,7 @@ public:
|
||||
if (v3Global.opt.dumpTree()) {
|
||||
const string filename = v3Global.debugFilename(nameComment) + ".txt";
|
||||
UINFO(2, "Dumping " << filename << endl);
|
||||
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);
|
||||
dump(*logp, "");
|
||||
}
|
||||
|
@ -355,7 +355,7 @@ public:
|
||||
void dumpGraphFilePrefixed(const string& nameComment) const {
|
||||
if (v3Global.opt.dumpTree()) {
|
||||
const string filename = v3Global.debugFilename(nameComment) + ".txt";
|
||||
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);
|
||||
dumpGraph(*logp, nameComment);
|
||||
}
|
||||
|
@ -97,9 +97,9 @@ public:
|
||||
v3Global.rootp()->typeTablep()->addTypesp(tableDTypep);
|
||||
// Create table initializer (with default value 0)
|
||||
AstConst* const defaultp = elemDType->isString()
|
||||
? new AstConst(m_fl, AstConst::String(), "")
|
||||
: new AstConst(m_fl, AstConst::WidthedValue(), width, 0);
|
||||
m_initp = new AstInitArray(m_fl, tableDTypep, defaultp);
|
||||
? new AstConst{m_fl, AstConst::String(), ""}
|
||||
: new AstConst{m_fl, AstConst::WidthedValue(), width, 0};
|
||||
m_initp = new AstInitArray{m_fl, tableDTypep, defaultp};
|
||||
}
|
||||
|
||||
void addValue(unsigned index, const V3Number& value) {
|
||||
@ -196,7 +196,7 @@ private:
|
||||
m_outVarps.clear();
|
||||
|
||||
// Collect stats
|
||||
TableSimulateVisitor chkvis(this);
|
||||
TableSimulateVisitor chkvis{this};
|
||||
chkvis.mainTableCheck(nodep);
|
||||
m_assignDly = chkvis.isAssignDly();
|
||||
// Also sets m_inWidthBits
|
||||
@ -280,7 +280,7 @@ private:
|
||||
// There may be a simulation path by which the output doesn't change value.
|
||||
// We could bail on these cases, or we can have a "change it" boolean.
|
||||
// We've chosen the latter route, since recirc is common in large FSMs.
|
||||
TableSimulateVisitor simvis(this);
|
||||
TableSimulateVisitor simvis{this};
|
||||
for (uint32_t i = 0; i <= VL_MASK_I(m_inWidthBits); ++i) {
|
||||
const uint32_t inValue = i;
|
||||
// Make a new simulation structure so we can set new input values
|
||||
@ -354,11 +354,11 @@ private:
|
||||
AstVarScope* outputAssignedTableVscp) {
|
||||
FileLine* const fl = nodep->fileline();
|
||||
for (TableOutputVar& tov : m_outVarps) {
|
||||
AstNode* const alhsp = new AstVarRef(fl, tov.varScopep(), VAccess::WRITE);
|
||||
AstNode* const alhsp = new AstVarRef{fl, tov.varScopep(), VAccess::WRITE};
|
||||
AstNode* const arhsp = select(fl, tov.tabeVarScopep(), indexVscp);
|
||||
AstNode* outsetp = m_assignDly
|
||||
? static_cast<AstNode*>(new AstAssignDly(fl, alhsp, arhsp))
|
||||
: static_cast<AstNode*>(new AstAssign(fl, alhsp, arhsp));
|
||||
? static_cast<AstNode*>(new AstAssignDly{fl, alhsp, arhsp})
|
||||
: static_cast<AstNode*>(new AstAssign{fl, alhsp, arhsp});
|
||||
|
||||
// If this output is unassigned on some code paths, wrap the assignment in an If
|
||||
if (tov.mayBeUnassigned()) {
|
||||
@ -425,6 +425,6 @@ void TableSimulateVisitor::varRefCb(AstVarRef* nodep) {
|
||||
|
||||
void V3Table::tableAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ TableVisitor visitor(nodep); } // Destruct before checking
|
||||
{ TableVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("table", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -545,7 +545,7 @@ private:
|
||||
// Iteration requires a back, so put under temporary node
|
||||
{
|
||||
AstBegin* tempp = new AstBegin(beginp->fileline(), "[EditWrapper]", beginp);
|
||||
TaskRelinkVisitor visitor(tempp);
|
||||
TaskRelinkVisitor visitor{tempp};
|
||||
tempp->stmtsp()->unlinkFrBackWithNext();
|
||||
VL_DO_DANGLING(tempp->deleteTree(), tempp);
|
||||
}
|
||||
@ -1230,7 +1230,7 @@ private:
|
||||
// Iteration requires a back, so put under temporary node
|
||||
{
|
||||
AstBegin* tempp = new AstBegin(cfuncp->fileline(), "[EditWrapper]", cfuncp);
|
||||
TaskRelinkVisitor visitor(tempp);
|
||||
TaskRelinkVisitor visitor{tempp};
|
||||
tempp->stmtsp()->unlinkFrBackWithNext();
|
||||
VL_DO_DANGLING(tempp->deleteTree(), tempp);
|
||||
}
|
||||
@ -1728,8 +1728,8 @@ const char* V3Task::dpiTemporaryVarSuffix() {
|
||||
void V3Task::taskAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
TaskStateVisitor visitors(nodep);
|
||||
TaskVisitor visitor(nodep, &visitors);
|
||||
TaskStateVisitor visitors{nodep};
|
||||
TaskVisitor visitor{nodep, &visitors};
|
||||
} // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("task", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -907,6 +907,6 @@ public:
|
||||
|
||||
void V3Trace::traceAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ TraceVisitor visitor(nodep); } // Destruct before checking
|
||||
{ TraceVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("trace", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -361,6 +361,6 @@ public:
|
||||
|
||||
void V3TraceDecl::traceDeclAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ TraceDeclVisitor visitor(nodep); } // Destruct before checking
|
||||
{ TraceDeclVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("tracedecl", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -1213,7 +1213,7 @@ class TristateVisitor final : public TristateBaseVisitor {
|
||||
// simple, it will flip ArraySel's and such, but if the
|
||||
// pin is an input the earlier reconnectSimple made it
|
||||
// a VarRef without any ArraySel, etc
|
||||
TristatePinVisitor visitor(outexprp, m_tgraph, true);
|
||||
TristatePinVisitor visitor{outexprp, m_tgraph, true};
|
||||
}
|
||||
if (debug() >= 9) outpinp->dumpTree(cout, "-pin-opr: ");
|
||||
outAssignp = V3Inst::pinReconnectSimple(outpinp, m_cellp,
|
||||
@ -1224,7 +1224,7 @@ class TristateVisitor final : public TristateBaseVisitor {
|
||||
}
|
||||
|
||||
// Existing pin becomes an input, and we mark each resulting signal as tristate
|
||||
TristatePinVisitor visitor(nodep->exprp(), m_tgraph, false);
|
||||
TristatePinVisitor visitor{nodep->exprp(), m_tgraph, false};
|
||||
AstNode* inAssignp = V3Inst::pinReconnectSimple(
|
||||
nodep, m_cellp, true); // Note may change nodep->exprp()
|
||||
if (debug() >= 9) nodep->dumpTree(cout, "-pin-in: ");
|
||||
@ -1424,6 +1424,6 @@ public:
|
||||
|
||||
void V3Tristate::tristateAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ TristateVisitor visitor(nodep); } // Destruct before checking
|
||||
{ TristateVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("tristate", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -461,5 +461,5 @@ public:
|
||||
|
||||
void V3Undriven::undrivenAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
UndrivenVisitor visitor(nodep);
|
||||
UndrivenVisitor visitor{nodep};
|
||||
}
|
||||
|
@ -487,6 +487,6 @@ public:
|
||||
|
||||
void V3Unknown::unknownAll(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ UnknownVisitor visitor(nodep); } // Destruct before checking
|
||||
{ UnknownVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("unknown", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 3);
|
||||
}
|
||||
|
@ -30,7 +30,7 @@ void V3Waiver::addEntry(V3ErrorCode errorCode, const std::string& filename,
|
||||
}
|
||||
|
||||
void V3Waiver::write(const std::string& filename) {
|
||||
const std::unique_ptr<std::ofstream> ofp(V3File::new_ofstream(filename));
|
||||
const std::unique_ptr<std::ofstream> ofp{V3File::new_ofstream(filename)};
|
||||
if (ofp->fail()) v3fatal("Can't write " << filename);
|
||||
|
||||
*ofp << "// DESCR"
|
||||
|
@ -5079,9 +5079,9 @@ private:
|
||||
case EXTEND_LHS: doSigned = nodep->isSigned(); break;
|
||||
default: nodep->v3fatalSrc("bad case");
|
||||
}
|
||||
AstNode* newp
|
||||
= (doSigned ? static_cast<AstNode*>(new AstExtendS(nodep->fileline(), nodep))
|
||||
: static_cast<AstNode*>(new AstExtend(nodep->fileline(), nodep)));
|
||||
AstNode* const newp
|
||||
= (doSigned ? static_cast<AstNode*>(new AstExtendS{nodep->fileline(), nodep})
|
||||
: static_cast<AstNode*>(new AstExtend{nodep->fileline(), nodep}));
|
||||
linker.relink(newp);
|
||||
nodep = newp;
|
||||
}
|
||||
@ -6158,8 +6158,8 @@ void V3Width::width(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{
|
||||
// We should do it in bottom-up module order, but it works in any order.
|
||||
WidthClearVisitor cvisitor(nodep);
|
||||
WidthVisitor visitor(false, false);
|
||||
WidthClearVisitor cvisitor{nodep};
|
||||
WidthVisitor visitor{false, false};
|
||||
(void)visitor.mainAcceptEdit(nodep);
|
||||
WidthRemoveVisitor rvisitor;
|
||||
(void)rvisitor.mainAcceptEdit(nodep);
|
||||
@ -6172,7 +6172,7 @@ void V3Width::width(AstNetlist* nodep) {
|
||||
AstNode* V3Width::widthParamsEdit(AstNode* nodep) {
|
||||
UINFO(4, __FUNCTION__ << ": " << nodep << endl);
|
||||
// We should do it in bottom-up module order, but it works in any order.
|
||||
WidthVisitor visitor(true, false);
|
||||
WidthVisitor visitor{true, false};
|
||||
nodep = visitor.mainAcceptEdit(nodep);
|
||||
// No WidthRemoveVisitor, as don't want to drop $signed etc inside gen blocks
|
||||
return nodep;
|
||||
@ -6191,7 +6191,7 @@ AstNode* V3Width::widthGenerateParamsEdit(
|
||||
AstNode* nodep) { //!< [in] AST whose parameters widths are to be analysed.
|
||||
UINFO(4, __FUNCTION__ << ": " << nodep << endl);
|
||||
// We should do it in bottom-up module order, but it works in any order.
|
||||
WidthVisitor visitor(true, true);
|
||||
WidthVisitor visitor{true, true};
|
||||
nodep = visitor.mainAcceptEdit(nodep);
|
||||
// No WidthRemoveVisitor, as don't want to drop $signed etc inside gen blocks
|
||||
return nodep;
|
||||
@ -6199,6 +6199,6 @@ AstNode* V3Width::widthGenerateParamsEdit(
|
||||
|
||||
void V3Width::widthCommit(AstNetlist* nodep) {
|
||||
UINFO(2, __FUNCTION__ << ": " << endl);
|
||||
{ WidthCommitVisitor visitor(nodep); } // Destruct before checking
|
||||
{ WidthCommitVisitor visitor{nodep}; } // Destruct before checking
|
||||
V3Global::dumpCheckGlobalTree("widthcommit", 0, v3Global.opt.dumpTreeLevel(__FILE__) >= 6);
|
||||
}
|
||||
|
@ -39,7 +39,7 @@ private:
|
||||
if (m_dataSize < point) m_dataSize = (point + 64) & ~63ULL; // Keep power of two
|
||||
m_dataSize *= 2;
|
||||
// UINFO(9, "Realloc "<<allocSize()<<" for "<<point<<" "<<cvtToHex(m_datap)<<endl);
|
||||
vluint64_t* newp = static_cast<vluint64_t*>(std::realloc(m_datap, allocSize()));
|
||||
vluint64_t* const newp = static_cast<vluint64_t*>(std::realloc(m_datap, allocSize()));
|
||||
if (VL_UNCOVERABLE(!newp)) {
|
||||
// cppcheck-suppress doubleFree // cppcheck 1.90 bug - realloc doesn't free on fail
|
||||
free(m_datap); // LCOV_EXCL_LINE
|
||||
|
@ -35,11 +35,11 @@ class VlcOptions final {
|
||||
// MEMBERS (general options)
|
||||
// clang-format off
|
||||
string m_annotateOut; // main switch: --annotate I<output_directory>
|
||||
bool m_annotateAll=false; // main switch: --annotate-all
|
||||
int m_annotateMin=10; // main switch: --annotate-min I<count>
|
||||
bool m_annotateAll = false; // main switch: --annotate-all
|
||||
int m_annotateMin = 10; // main switch: --annotate-min I<count>
|
||||
VlStringSet m_readFiles; // main switch: --read
|
||||
bool m_rank=false; // main switch: --rank
|
||||
bool m_unlink=false; // main switch: --unlink
|
||||
bool m_rank = false; // main switch: --rank
|
||||
bool m_unlink = false; // main switch: --unlink
|
||||
string m_writeFile; // main switch: --write
|
||||
string m_writeInfoFile; // main switch: --write-info
|
||||
// clang-format on
|
||||
|
@ -127,7 +127,7 @@ public:
|
||||
m_points[pointnum].countInc(count);
|
||||
} else {
|
||||
pointnum = m_numPoints++;
|
||||
VlcPoint point(name, pointnum);
|
||||
VlcPoint point{name, pointnum};
|
||||
point.countInc(count);
|
||||
m_points.push_back(point);
|
||||
m_nameMap.emplace(point.name(), point.pointNum());
|
||||
|
@ -112,7 +112,7 @@ public:
|
||||
for (const auto& testp : m_tests) testp->dump(bucketsToo);
|
||||
}
|
||||
VlcTest* newTest(const string& name, vluint64_t testrun, double comp) {
|
||||
VlcTest* testp = new VlcTest(name, testrun, comp);
|
||||
VlcTest* const testp = new VlcTest{name, testrun, comp};
|
||||
m_tests.push_back(testp);
|
||||
return testp;
|
||||
}
|
||||
|
@ -27,14 +27,14 @@
|
||||
void VlcTop::readCoverage(const string& filename, bool nonfatal) {
|
||||
UINFO(2, "readCoverage " << filename << endl);
|
||||
|
||||
std::ifstream is(filename.c_str());
|
||||
std::ifstream is{filename.c_str()};
|
||||
if (!is) {
|
||||
if (!nonfatal) v3fatal("Can't read " << filename);
|
||||
return;
|
||||
}
|
||||
|
||||
// Testrun and computrons argument unsupported as yet
|
||||
VlcTest* testp = tests().newTest(filename, 0, 0);
|
||||
VlcTest* const testp = tests().newTest(filename, 0, 0);
|
||||
|
||||
while (!is.eof()) {
|
||||
const string line = V3Os::getline(is);
|
||||
@ -63,7 +63,7 @@ void VlcTop::readCoverage(const string& filename, bool nonfatal) {
|
||||
void VlcTop::writeCoverage(const string& filename) {
|
||||
UINFO(2, "writeCoverage " << filename << endl);
|
||||
|
||||
std::ofstream os(filename.c_str());
|
||||
std::ofstream os{filename.c_str()};
|
||||
if (!os) {
|
||||
v3fatal("Can't write " << filename);
|
||||
return;
|
||||
@ -79,7 +79,7 @@ void VlcTop::writeCoverage(const string& filename) {
|
||||
void VlcTop::writeInfo(const string& filename) {
|
||||
UINFO(2, "writeInfo " << filename << endl);
|
||||
|
||||
std::ofstream os(filename.c_str());
|
||||
std::ofstream os{filename.c_str()};
|
||||
if (!os) {
|
||||
v3fatal("Can't write " << filename);
|
||||
return;
|
||||
@ -157,7 +157,7 @@ void VlcTop::rank() {
|
||||
|
||||
VlcBuckets remaining;
|
||||
for (const auto& i : m_points) {
|
||||
VlcPoint* pointp = &points().pointNumber(i.second);
|
||||
VlcPoint* const pointp = &points().pointNumber(i.second);
|
||||
// If any tests hit this point, then we'll need to cover it.
|
||||
if (pointp->testsCovering()) remaining.addData(pointp->pointNum(), 1);
|
||||
}
|
||||
@ -182,7 +182,7 @@ void VlcTop::rank() {
|
||||
}
|
||||
}
|
||||
}
|
||||
if (VlcTest* testp = bestTestp) {
|
||||
if (VlcTest* const testp = bestTestp) {
|
||||
testp->rank(nextrank++);
|
||||
testp->rankPoints(bestRemain);
|
||||
remaining.orData(bestTestp->buckets());
|
||||
@ -227,7 +227,7 @@ void VlcTop::annotateCalc() {
|
||||
} else if (*covp == '-') {
|
||||
range = true;
|
||||
} else if (std::isdigit(*covp)) {
|
||||
const char* digitsp = covp;
|
||||
const char* const digitsp = covp;
|
||||
while (std::isdigit(*covp)) ++covp;
|
||||
--covp; // Will inc in for loop
|
||||
if (!range) start = std::atoi(digitsp);
|
||||
@ -279,13 +279,13 @@ void VlcTop::annotateOutputFiles(const string& dirname) {
|
||||
|
||||
UINFO(1, "annotateOutputFile " << filename << " -> " << outfilename << endl);
|
||||
|
||||
std::ifstream is(filename.c_str());
|
||||
std::ifstream is{filename.c_str()};
|
||||
if (!is) {
|
||||
v3error("Can't read " << filename);
|
||||
return;
|
||||
}
|
||||
|
||||
std::ofstream os(outfilename.c_str());
|
||||
std::ofstream os{outfilename.c_str()};
|
||||
if (!os) {
|
||||
v3fatal("Can't write " << outfilename);
|
||||
return;
|
||||
|
Loading…
Reference in New Issue
Block a user