* ./metis:

- Change: In MetisGraph CTOR, clearer error message when there is duplicated
        instances. Show the full occurrence path of each conflicting instance.
This commit is contained in:
Jean-Paul Chaput 2013-02-10 11:53:30 +00:00
parent 725cf8b2e6
commit a3dd3f6d4f
1 changed files with 19 additions and 13 deletions

View File

@ -157,21 +157,27 @@ MetisGraph::MetisGraph ( MetisEngine* metis, GCell* gcell )
, _partResultVector() , _partResultVector()
, _edgeCut(INT_MAX) , _edgeCut(INT_MAX)
{ {
typedef set<Instance*> InstanceSet; typedef map<Instance*,Occurrence> OccurrencesLUT;
InstanceSet instanceSet; OccurrencesLUT occurrencesLUT;
for_each_occurrence(occurrence, _cell->getLeafInstanceOccurrences()) for_each_occurrence(occurrence, _cell->getLeafInstanceOccurrences())
{ {
Instance* instance = static_cast<Instance*>(occurrence.getEntity()); Instance* instance = static_cast<Instance*>(occurrence.getEntity());
if (!instance->isFixed()) if (!instance->isFixed()) {
{ OccurrencesLUT::iterator duplicated = occurrencesLUT.find(instance);
if (instanceSet.find(instance) != instanceSet.end()) if (duplicated != occurrencesLUT.end()) {
throw Error("MetisEngine limitation : only one occurrence of unplaced instance"); throw Error("MetisEngine limitation: Each unplaced instance must have one occurrence only.\n"
instanceSet.insert(instance); "Model %s is intanciated as:<b>\n. %s\n. %s</b>\n (at least)."
_toPlaceInstanceOccurrencesSet.insert(occurrence); //treat this later ,getString(instance->getMasterCell()->getName()).c_str()
} ,occurrence.getCompactString().c_str()
end_for; ,(*duplicated).second.getCompactString().c_str()
);
}
occurrencesLUT.insert(make_pair(instance,occurrence));
_toPlaceInstanceOccurrencesSet.insert(occurrence); //treat this later
} }
end_for;
}
for_each_occurrence(occurrence, _cell->getHyperNetRootNetOccurrences()) for_each_occurrence(occurrence, _cell->getHyperNetRootNetOccurrences())
{ {