Salome HOME
Creation of producedByFeature initial implementation neede for the issue #1306
[modules/shaper.git] / src / Model / Model_AttributeDouble.cpp
index 86cbc9e14bfbe5e7083d86a5f1a9b8b8ab5e70e0..05a25684182f51e35e24930e769d481639b317f3 100644 (file)
@@ -5,50 +5,77 @@
 // Author:      Mikhail PONIKAROV
 
 #include "Model_AttributeDouble.h"
-#include <ModelAPI_Feature.h>
-#include <ModelAPI_Data.h>
 
-#include <TCollection_AsciiString.hxx>
-#include <TCollection_ExtendedString.hxx>
+#include <ModelAPI_Data.h>
+#include <ModelAPI_Events.h>
+#include <ModelAPI_Expression.h>
+#include <ModelAPI_Object.h>
 
-using namespace std;
+Model_AttributeDouble::Model_AttributeDouble()
+{
+  myIsInitialized = false;
+}
 
-void Model_AttributeDouble::setValue(const double theValue)
+void Model_AttributeDouble::setCalculatedValue(const double theValue)
 {
-  if (!myIsInitialized || myReal->Get() != theValue) {
-    myReal->Set(theValue);
+  if (!myIsInitialized || value() != theValue) {
+    myExpression->setValue(theValue);
     owner()->data()->sendAttributeUpdated(this);
   }
 }
 
-double Model_AttributeDouble::value()
+void Model_AttributeDouble::setValue(const double theValue)
 {
-  return myReal->Get();
+  setCalculatedValue(text().empty() ? theValue : value());
 }
 
-Model_AttributeDouble::Model_AttributeDouble(TDF_Label& theLabel)
+double Model_AttributeDouble::value()
 {
-  // check the attribute could be already presented in this doc (after load document)
-  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());
-  }
+  return myExpression->value();
 }
 
 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); ?
+  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);
   }
 }
 
-string Model_AttributeDouble::text()
+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<std::string>& theUsedParameters)
+{
+  myExpression->setUsedParameters(theUsedParameters);
+}
+
+std::set<std::string> Model_AttributeDouble::usedParameters() const
 {
-  return TCollection_AsciiString(myText->Get()).ToCString();
+  return myExpression->usedParameters();
 }