More explicit error messages in Plug::setNet() to help diagnosis.

This commit is contained in:
Jean-Paul Chaput 2016-07-27 11:04:14 +02:00
parent 8893779edf
commit 09004b3a75
1 changed files with 17 additions and 11 deletions

View File

@ -134,20 +134,26 @@ PlugFilter Plug::getIsUnconnectedFilter()
void Plug::setNet(Net* net) void Plug::setNet(Net* net)
// ************************ // ************************
{ {
if (net != getNet()) { if (net != getNet()) {
if (net and (getCell() != net->getCell()))
throw Error( "Plug::setNet(): Can't set Net of plug %s to %s\n"
"Net belong to %s instead of %s."
, getString(this).c_str()
, getString(net).c_str()
, getString(net->getCell()).c_str()
, getString(getCell()).c_str()
);
if (net && (getCell() != net->getCell())) if (not getBodyHook()->getSlaveHooks().isEmpty())
throw Error("Can't change net of plug: " + getString(net) + " does not belong to " + getString(getCell())); throw Error( "Plug::setNet(): Can't change net of %s: Component(s) are still attached upon it."
, getString(this).c_str()
);
if (!getBodyHook()->getSlaveHooks().isEmpty()) if (not net)
throw Error("Can't change net of plug: not empty slave hooks"); cdebug_log(18,0) << "Plug::setNet(): About to disconnect " << this << endl;
if (net == NULL) { _setNet( net );
cerr << "About to disconnect " << this << endl; }
}
_setNet(net);
}
} }
Plug* Plug::_create(Instance* instance, Net* masterNet) Plug* Plug::_create(Instance* instance, Net* masterNet)