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=86cbc9e14bfbe5e7083d86a5f1a9b8b8ab5e70e0;hpb=f1e148577aba644f684b10abc4928d30cc5357b5;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeDouble.cpp b/src/Model/Model_AttributeDouble.cpp index 86cbc9e14..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; @@ -44,7 +46,10 @@ 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); ? + 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; +}