X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeReference.cpp;h=91de64eb567de9f94889a6274c98f8ae8c6dcebc;hb=241b57ba3887bc2d239df98405c4fc4d6979119b;hp=e2ff01ce7798975aa6e11d829c86281f6bfc99f5;hpb=712dfdf42f58bb738a0db2c051a405391151972f;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeReference.cpp b/src/Model/Model_AttributeReference.cpp index e2ff01ce7..91de64eb5 100644 --- a/src/Model/Model_AttributeReference.cpp +++ b/src/Model/Model_AttributeReference.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModelAPI_AttributeReference.cxx // Created: 2 Apr 2014 // Author: Mikhail PONIKAROV @@ -7,33 +9,76 @@ #include "Model_Events.h" #include "Model_Data.h" #include +#include + +#include +#include +#include using namespace std; -void Model_AttributeReference::setValue(FeaturePtr theFeature) +void Model_AttributeReference::setValue(ObjectPtr theObject) { - if (!myIsInitialized || value() != theFeature) { - boost::shared_ptr aData = - boost::dynamic_pointer_cast(theFeature->data()); - if (myRef.IsNull()) { - boost::shared_ptr aMyData = - boost::dynamic_pointer_cast(owner()->data()); - myRef = TDF_Reference::Set(aMyData->label(), aData->label()); - } else { - myRef->Set(aData->label()); + if(!theObject) + return; + if (!myIsInitialized || value() != theObject) { + std::shared_ptr aData = std::dynamic_pointer_cast( + theObject->data()); + TDF_Label anObjLab = aData->label().Father(); // object label + + if (owner()->document() == theObject->document()) { // same document, use reference attribute + + std::shared_ptr aDoc = + std::dynamic_pointer_cast(owner()->document()); + myRef->Set(anObjLab); // references to the object label + // remove external link attributes (if any) + myRef->Label().ForgetAttribute(TDataStd_Comment::GetID()); + myRef->Label().ForgetAttribute(TDataStd_AsciiString::GetID()); + } else { // different document: store the document name (comment) and entry (string): external + // if these attributes exist, the link is external: keep reference to access the label + TDataStd_Comment::Set(myRef->Label(), theObject->document()->id().c_str()); + TCollection_AsciiString anEntry; + TDF_Tool::Entry(anObjLab, anEntry); + TDataStd_AsciiString::Set(myRef->Label(), anEntry); } + // do it before the transaction finish to make just created/removed objects know dependencies + // and reference from composite feature is removed automatically + FeaturePtr anOwnerFeature = std::dynamic_pointer_cast(owner()); + if (anOwnerFeature.get()) { + aData->addBackReference(anOwnerFeature, id()); + } + owner()->data()->sendAttributeUpdated(this); } } -FeaturePtr Model_AttributeReference::value() +ObjectPtr Model_AttributeReference::value() { - if (!myRef.IsNull()) { - boost::shared_ptr aDoc = - boost::dynamic_pointer_cast(owner()->document()); - if (aDoc) { - TDF_Label aRefLab = myRef->Get(); - return aDoc->feature(aRefLab); + if (myIsInitialized) { + Handle(TDataStd_Comment) aDocID; + if (myRef->Label().FindAttribute(TDataStd_Comment::GetID(), aDocID)) { // external ref + DocumentPtr aRefDoc = + ModelAPI_Session::get()->document(TCollection_AsciiString(aDocID->Get()).ToCString()); + if (aRefDoc) { + Handle(TDataStd_AsciiString) anEntry; + if (myRef->Label().FindAttribute(TDataStd_AsciiString::GetID(), anEntry)) { + std::shared_ptr aDR = std::dynamic_pointer_cast(aRefDoc); + TDF_Label aRefLab; + TDF_Tool::Label(aDR->featuresLabel().Data(), anEntry->Get().ToCString(), aRefLab); + if (!aRefLab.IsNull()) { + return aDR->object(aRefLab); + } + } + } + } else { // internal ref + std::shared_ptr aDoc = std::dynamic_pointer_cast( + owner()->document()); + if (aDoc) { + TDF_Label aRefLab = myRef->Get(); + if (!aRefLab.IsNull()) { // it may happen with old document, issue #285 + return aDoc->object(aRefLab); + } + } } } // not initialized @@ -42,6 +87,29 @@ FeaturePtr Model_AttributeReference::value() Model_AttributeReference::Model_AttributeReference(TDF_Label& theLabel) { - // not initialized by value yet: attribute is not set to the label! myIsInitialized = theLabel.FindAttribute(TDF_Reference::GetID(), myRef) == Standard_True; + if (!myIsInitialized) { + myRef = TDF_Reference::Set(theLabel, theLabel); // not initialized references to itself + } else { + if (owner()) { + std::shared_ptr aDoc = + std::dynamic_pointer_cast(owner()->document()); + } + } +} + +void Model_AttributeReference::setObject(const std::shared_ptr& theObject) +{ + if (owner() != theObject) { + ModelAPI_AttributeReference::setObject(theObject); + std::shared_ptr aDoc = + std::dynamic_pointer_cast(owner()->document()); + } +} + +Model_AttributeReference::~Model_AttributeReference() +{ + std::shared_ptr aDoc = + std::dynamic_pointer_cast(owner()->document()); + TDF_Label aLab = myRef->Get(); }