]> SALOME platform Git repositories - modules/shaper.git/commitdiff
Salome HOME
Fix by MPV
authorazv <azv@opencascade.com>
Wed, 18 Mar 2015 12:14:40 +0000 (15:14 +0300)
committerazv <azv@opencascade.com>
Wed, 18 Mar 2015 12:24:37 +0000 (15:24 +0300)
src/Model/Model_Data.cpp

index 477bf0e83c71dc514bf4472e97512d3d4d3372fd..82cc259187f241baf8d61af17ecd4be53b79251a 100644 (file)
@@ -31,6 +31,7 @@
 #include <TDataStd_Name.hxx>
 #include <TDF_AttributeIterator.hxx>
 #include <TDF_ChildIterator.hxx>
+#include <TDF_RelocationTable.hxx>
 
 #include <string>
 
@@ -317,7 +318,7 @@ static void copyAttrs(TDF_Label theSource, TDF_Label theDestination) {
            aTargetAttr = anAttrIter.Value()->NewEmpty();
       theDestination.AddAttribute(aTargetAttr);
     }
-    Handle(TDF_RelocationTable) aRelocTable; // no relocation, empty map
+    Handle(TDF_RelocationTable) aRelocTable = new TDF_RelocationTable(); // no relocation, empty map
     anAttrIter.Value()->Paste(aTargetAttr, aRelocTable);
   }
   // copy the sub-labels content
@@ -331,4 +332,11 @@ void Model_Data::copyTo(std::shared_ptr<ModelAPI_Data> theTarget)
 {
   TDF_Label aTargetRoot = std::dynamic_pointer_cast<Model_Data>(theTarget)->label();
   copyAttrs(myLab, aTargetRoot);
+  // make initialized the initialized attributes
+  std::map<std::string, std::shared_ptr<ModelAPI_Attribute> >::iterator aMyIter = myAttrs.begin();
+  for(; aMyIter != myAttrs.end(); aMyIter++) {
+    if (aMyIter->second->isInitialized()) {
+      theTarget->attribute(aMyIter->first)->setInitialized();
+    }
+  }
 }