X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeDouble.cpp;h=3ef3e3c41c1510d217a9efdb6aed4621f4bc4b61;hb=2c5d9762904d572995855e2ce2239ea0c3463eb5;hp=88b4352a56d288dd8b3b0c81a7acfdc28e5ce82f;hpb=65350bc1b9ac17e42959fb98d650a7791b3cdf06;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeDouble.cpp b/src/Model/Model_AttributeDouble.cpp index 88b4352a5..3ef3e3c41 100644 --- a/src/Model/Model_AttributeDouble.cpp +++ b/src/Model/Model_AttributeDouble.cpp @@ -1,20 +1,25 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModelAPI_AttributeDouble.cxx // Created: 2 Apr 2014 // Author: Mikhail PONIKAROV #include "Model_AttributeDouble.h" -#include "Model_Events.h" -#include +#include +#include +#include + +#include +#include +#include using namespace std; void Model_AttributeDouble::setValue(const double theValue) { - if (myReal->Get() != theValue) { + if (!myIsInitialized || myReal->Get() != theValue) { myReal->Set(theValue); - static Events_ID anEvent = Events_Loop::eventByName(EVENT_FEATURE_UPDATED); - Model_FeatureUpdatedMessage aMsg(owner(), anEvent); - Events_Loop::loop()->send(aMsg); + owner()->data()->sendAttributeUpdated(this); } } @@ -26,8 +31,48 @@ double Model_AttributeDouble::value() Model_AttributeDouble::Model_AttributeDouble(TDF_Label& theLabel) { // check the attribute could be already presented in this doc (after load document) - if (!theLabel.FindAttribute(TDataStd_Real::GetID(), myReal)) { + myIsInitialized = theLabel.FindAttribute(TDataStd_Real::GetID(), myReal) == Standard_True; + if (!myIsInitialized) { // create attribute: not initialized by value yet, just zero myReal = TDataStd_Real::Set(theLabel, 0.); } + if (!theLabel.FindAttribute(TDataStd_Name::GetID(), myText)) { + myText = TDataStd_Name::Set(theLabel, TCollection_ExtendedString()); + } +} + +void Model_AttributeDouble::setText(const std::string& theValue) +{ + TCollection_ExtendedString aValue(theValue.c_str()); + if (myText->Get() != aValue) { + myText->Set(aValue); + owner()->data()->sendAttributeUpdated(this); + // Send it to evaluator to convert into the double and store in the attribute + static Events_ID anId = ModelAPI_AttributeEvalMessage::eventId(); + std::shared_ptr aMessage = + std::shared_ptr(new ModelAPI_AttributeEvalMessage(anId, this)); + aMessage->setAttribute(owner()->data()->attribute(id())); // to get shared pointer to this + Events_Loop::loop()->send(aMessage); + } +} + +string Model_AttributeDouble::text() +{ + return TCollection_AsciiString(myText->Get()).ToCString(); +} + +Standard_GUID kInvalidGUID("caee5ce4-34b1-4b29-abcb-685287d18096"); + +void Model_AttributeDouble::setExpressionInvalid(const bool theFlag) +{ + if (theFlag) { + TDataStd_UAttribute::Set(myReal->Label(), kInvalidGUID); + } else { + myReal->Label().ForgetAttribute(kInvalidGUID); + } +} + +bool Model_AttributeDouble::expressionInvalid() +{ + return myReal->Label().IsAttribute(kInvalidGUID) == Standard_True; }