X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Object.cpp;h=b3f2671c92592aa359da6a0ebd1c4d756742f803;hb=35d4b199e4d3581615470404d47e3bfae4def046;hp=e1b490b42e37dc47154fd85ecaaf045b216c62a3;hpb=bcc91b0593370bf3ab30bae7ba7f510be965587e;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Object.cpp b/src/ModelAPI/ModelAPI_Object.cpp index e1b490b42..b3f2671c9 100644 --- a/src/ModelAPI/ModelAPI_Object.cpp +++ b/src/ModelAPI/ModelAPI_Object.cpp @@ -6,10 +6,13 @@ #include "ModelAPI_Object.h" #include "ModelAPI_Document.h" +#include "ModelAPI_Data.h" +#include "ModelAPI_Events.h" +#include bool ModelAPI_Object::isInHistory() { - if (myData.get() && myData->isValid()) { + if (myData->isValid()) { return myData->isInHistory(); } return true; // default value @@ -19,7 +22,7 @@ void ModelAPI_Object::setInHistory( const std::shared_ptr theObject, const bool theFlag) { if (isInHistory() != theFlag) { - if (myData.get() && myData->isValid()) { + if (myData->isValid()) { myData->setIsInHistory(theFlag); } myDoc->updateHistory(theObject); @@ -65,6 +68,17 @@ void ModelAPI_Object::setDoc(std::shared_ptr theDoc) void ModelAPI_Object::erase() { - if (myData) myData->erase(); - setData(DataPtr()); + if (myData->isValid() && myData != myData->invalidPtr()) + myData->erase(); + setData(myData->invalidPtr()); +} + +bool ModelAPI_Object::isDisplayed() +{ + return myData->isDisplayed(); +} + +void ModelAPI_Object::setDisplayed(const bool theDisplay) +{ + myData->setDisplayed(theDisplay); }