X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeDocRef.cpp;h=2284226c262cb09819572a5c52e370623f5a7950;hb=acfb7413a39dd03b70cd8d2847264e083eac2a25;hp=9df9c22190611371b1cd80357fc9de7b3de3fa14;hpb=6654a921211670c15a79a997ca666a174fe8a6f6;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeDocRef.cpp b/src/Model/Model_AttributeDocRef.cpp index 9df9c2219..2284226c2 100644 --- a/src/Model/Model_AttributeDocRef.cpp +++ b/src/Model/Model_AttributeDocRef.cpp @@ -1,31 +1,42 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModelAPI_AttributeDocRef.cxx // Created: 2 Apr 2014 // Author: Mikhail PONIKAROV #include "Model_AttributeDocRef.h" #include "Model_Application.h" +#include +#include using namespace std; -void Model_AttributeDocRef::setValue(boost::shared_ptr theDoc) +void Model_AttributeDocRef::setValue(std::shared_ptr theDoc) { - myComment->Set(TCollection_ExtendedString(theDoc->id().c_str())); + myDoc = theDoc; + TCollection_ExtendedString aNewID(theDoc->id().c_str()); + if (!myIsInitialized || myComment->Get() != aNewID) { + myComment->Set(TCollection_ExtendedString(theDoc->id().c_str())); + owner()->data()->sendAttributeUpdated(this); + } } -boost::shared_ptr Model_AttributeDocRef::value() +std::shared_ptr Model_AttributeDocRef::value() { - if (myComment->Get().Length()) - return Model_Application::getApplication()->getDocument( - TCollection_AsciiString(myComment->Get()).ToCString()); - // not initialized - return boost::shared_ptr(); + return myDoc; } Model_AttributeDocRef::Model_AttributeDocRef(TDF_Label& theLabel) { - // check the attribute could be already presented in this doc (after load document) - if (!theLabel.FindAttribute(TDataStd_Comment::GetID(), myComment)) { + myIsInitialized = theLabel.FindAttribute(TDataStd_Comment::GetID(), myComment) == Standard_True; + if (!myIsInitialized) { // create attribute: not initialized by value yet, just empty string myComment = TDataStd_Comment::Set(theLabel, ""); + } else { // document was already referenced: try to set it as loaded by demand + Handle(Model_Application) anApp = Model_Application::getApplication(); + string anID(TCollection_AsciiString(myComment->Get()).ToCString()); + if (!anApp->hasDocument(anID)) { + anApp->setLoadByDemand(anID); + } } }