X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeDouble.cpp;h=05a25684182f51e35e24930e769d481639b317f3;hb=dfd8991c975a7493c1e7be200503a5c9456ad2da;hp=23e15f0e1ad9457e92570a83dec685aa67ed0314;hpb=de0f49686ec6655ddc5816c8fa5383964662aec4;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeDouble.cpp b/src/Model/Model_AttributeDouble.cpp index 23e15f0e1..05a256841 100644 --- a/src/Model/Model_AttributeDouble.cpp +++ b/src/Model/Model_AttributeDouble.cpp @@ -1,26 +1,81 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModelAPI_AttributeDouble.cxx // Created: 2 Apr 2014 // Author: Mikhail PONIKAROV #include "Model_AttributeDouble.h" -using namespace std; +#include +#include +#include +#include + +Model_AttributeDouble::Model_AttributeDouble() +{ + myIsInitialized = false; +} + +void Model_AttributeDouble::setCalculatedValue(const double theValue) +{ + if (!myIsInitialized || value() != theValue) { + myExpression->setValue(theValue); + owner()->data()->sendAttributeUpdated(this); + } +} void Model_AttributeDouble::setValue(const double theValue) { - myReal->Set(theValue); + setCalculatedValue(text().empty() ? theValue : value()); } double Model_AttributeDouble::value() { - return myReal->Get(); + return myExpression->value(); } -Model_AttributeDouble::Model_AttributeDouble(TDF_Label& theLabel) +void Model_AttributeDouble::setText(const std::string& theValue) { - // check the attribute could be already presented in this doc (after load document) - if (!theLabel.FindAttribute(TDataStd_Real::GetID(), myReal)) { - // create attribute: not initialized by value yet, just zero - myReal = TDataStd_Real::Set(theLabel, 0.); + if (text() != theValue) { + myExpression->setText(theValue); + // Send it to evaluator to convert text to double and store in the attribute + ModelAPI_AttributeEvalMessage::send(owner()->data()->attribute(id()), this); + owner()->data()->sendAttributeUpdated(this); } } + +std::string Model_AttributeDouble::text() +{ + return myExpression->text(); +} + +void Model_AttributeDouble::setExpressionInvalid(const bool theFlag) +{ + myExpression->setInvalid(theFlag); +} + +bool Model_AttributeDouble::expressionInvalid() +{ + return myExpression->isInvalid(); +} + +void Model_AttributeDouble::setExpressionError(const std::string& theError) +{ + if (expressionError() != theError) + myExpression->setError(theError); +} + +std::string Model_AttributeDouble::expressionError() +{ + return myExpression->error(); +} + +void Model_AttributeDouble::setUsedParameters(const std::set& theUsedParameters) +{ + myExpression->setUsedParameters(theUsedParameters); +} + +std::set Model_AttributeDouble::usedParameters() const +{ + return myExpression->usedParameters(); +}