diff --git a/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.cxx b/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.cxx index b6e36ed491..3432ccedb1 100644 --- a/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.cxx +++ b/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.cxx @@ -37,6 +37,7 @@ #include #include #include +#include #include #include #include @@ -322,13 +323,22 @@ void BinLDrivers_DocumentRetrievalDriver::Read (Standard_IStream& myPAtt.SetIStream (theIStream); // for reading shapes data from the stream directly EnableQuickPartReading (myMsgDriver, aQuickPart); + myResolvedLinks.Clear(); + myUnresolvedLinks.Clear(); + // read sub-tree of the root label if (!theFilter.IsNull()) theFilter->StartIteration(); const auto aStreamStartPosition = theIStream.tellg(); Standard_Integer nbRead = ReadSubTree (theIStream, aData->Root(), theFilter, aQuickPart, Standard_False, aPS.Next()); - if (!myUnresolvedLinks.IsEmpty()) + while (!myUnresolvedLinks.IsEmpty()) { + if (!aPS.More()) + { + myReaderStatus = PCDM_RS_UserBreak; + return; + } + // In case we have skipped some linked TreeNodes before getting to // their children. theFilter->StartIteration(); @@ -497,10 +507,17 @@ Standard_Integer BinLDrivers_DocumentRetrievalDriver::ReadSubTree theLabel.AddAttribute(tAtt); } } - else + else if (theLabel != tAtt->Label()) + { + TCollection_AsciiString aLabelEntry1, aLabelEntry2; + TDF_Tool::Entry (tAtt->Label(), aLabelEntry1); + TDF_Tool::Entry (theLabel, aLabelEntry2); + myMsgDriver->Send(aMethStr + "warning: attempt to attach attribute " + - aDriver->TypeName() + " to a second label", Message_Warning); + aDriver->TypeName() + " to a second label " + "(" + + aLabelEntry1 + " => " + aLabelEntry2 + ")", Message_Warning); + } Standard_Boolean ok = aDriver->Paste(myPAtt, tAtt, myRelocTable); if (!ok) { @@ -511,12 +528,16 @@ Standard_Integer BinLDrivers_DocumentRetrievalDriver::ReadSubTree else if (!isBound) { myRelocTable.Bind(anID, tAtt); - Handle(TDataStd_TreeNode) aNode = Handle(TDataStd_TreeNode)::DownCast(tAtt); - if (!theFilter.IsNull() && !aNode.IsNull() && !aNode->Father().IsNull() && aNode->Father()->IsNew()) + } + + Handle(TDataStd_TreeNode) aNode = Handle(TDataStd_TreeNode)::DownCast(tAtt); + if (!theFilter.IsNull() && !aNode.IsNull() && !aNode->Father().IsNull() && aNode->Father()->IsNew()) + { + Standard_Integer anUnresolvedLink; + myPAtt.SetPosition(BP_HEADSIZE); + myPAtt >> anUnresolvedLink; + if (myResolvedLinks.Add (myPAtt.Id())) { - Standard_Integer anUnresolvedLink; - myPAtt.SetPosition(BP_HEADSIZE); - myPAtt >> anUnresolvedLink; myUnresolvedLinks.Add(anUnresolvedLink); } } @@ -650,6 +671,7 @@ void BinLDrivers_DocumentRetrievalDriver::Clear() myPAtt.Destroy(); // free buffer myRelocTable.Clear(); myMapUnsupported.Clear(); + myResolvedLinks.Clear(); } //======================================================================= diff --git a/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.hxx b/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.hxx index fc1652cd49..98f1d1dde0 100644 --- a/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.hxx +++ b/src/BinLDrivers/BinLDrivers_DocumentRetrievalDriver.hxx @@ -127,7 +127,7 @@ private: TColStd_MapOfInteger myMapUnsupported; BinLDrivers_VectorOfDocumentSection mySections; NCollection_Map myUnresolvedLinks; - + NCollection_Map myResolvedLinks; };