X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeDouble.cpp;h=0736eddc0570d7a4611121da979160655e65819f;hb=refs%2Ftags%2FV_1.2.1;hp=29ca7be4e70d4b9bfcc6dae4a98dd792b91be369;hpb=a56db4993bab53bc45a338337142fe59a755f95b;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeDouble.cpp b/src/Model/Model_AttributeDouble.cpp index 29ca7be4e..0736eddc0 100644 --- a/src/Model/Model_AttributeDouble.cpp +++ b/src/Model/Model_AttributeDouble.cpp @@ -7,9 +7,11 @@ #include "Model_AttributeDouble.h" #include #include +#include #include #include +#include using namespace std; @@ -45,6 +47,9 @@ void Model_AttributeDouble::setText(const std::string& theValue) 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 + ModelAPI_AttributeEvalMessage::send(owner()->data()->attribute(id()), this); } } @@ -52,3 +57,19 @@ 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; +}