Salome HOME
Merge branch 'Dev_0.6.1' of newgeom:newgeom into Dev_0.6.1
[modules/shaper.git] / src / ModelAPI / ModelAPI_AttributeDouble.h
index 7dfb882c308d8adb883f71304d0efc3f8fb706d0..121af02a5c083985ebcf3bf46bb1c5f604b456d8 100644 (file)
@@ -1,9 +1,11 @@
+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
+
 // File:        ModelAPI_AttributeDouble.h
 // Created:     2 Apr 2014
 // Author:      Mikhail PONIKAROV
 
-#ifndef ModelAPI_AttributeDouble_HeaderFile
-#define ModelAPI_AttributeDouble_HeaderFile
+#ifndef ModelAPI_AttributeDouble_H_
+#define ModelAPI_AttributeDouble_H_
 
 #include "ModelAPI_Attribute.h"
 
  * \brief Attribute that contains real value with double precision.
  */
 
-class MODELAPI_EXPORT ModelAPI_AttributeDouble : public ModelAPI_Attribute
+class ModelAPI_AttributeDouble : public ModelAPI_Attribute
 {
-public:
+ public:
   /// Defines the double value
-  virtual void setValue(double theValue) = 0;
+  MODELAPI_EXPORT virtual void setValue(const double theValue) = 0;
 
   /// Returns the double value
-  virtual double value() = 0;
+  MODELAPI_EXPORT virtual double value() = 0;
 
   /// Returns the type of this class of attributes
-  static std::string type() {return "Double";}
+  MODELAPI_EXPORT static std::string type()
+  {
+    return "Double";
+  }
 
   /// Returns the type of this class of attributes, not static method
-  virtual std::string attributeType() {return type();}
+  MODELAPI_EXPORT virtual std::string attributeType()
+  {
+    return type();
+  }
+
+  /// To virtually destroy the fields of successors
+  MODELAPI_EXPORT virtual ~ModelAPI_AttributeDouble()
+  {
+  }
 
-protected:
+ protected:
   /// Objects are created for features automatically
-  ModelAPI_AttributeDouble()
-  {}
+  MODELAPI_EXPORT ModelAPI_AttributeDouble()
+  {
+  }
 };
 
+//! Pointer on double attribute
+typedef std::shared_ptr<ModelAPI_AttributeDouble> AttributeDoublePtr;
+
 #endif