Salome HOME
Update copyrights
[modules/shaper.git] / src / Config / Config_PropManager.h
index 4a6d43226a5f1ea9246847c130cfa6f60bff57ae..e0b2cd7e9891aa5688d812d681e6c34c3efcc9c8 100644 (file)
@@ -1,6 +1,21 @@
-// File:        Config_PropManager.h
-// Created:     13 Aug 2014
-// Author:      Vitaly SMETANNIKOV
+// Copyright (C) 2014-2019  CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
 
 #ifndef Config_PropManager_H
 #define Config_PropManager_H
 #include <string>
 #include <vector>
 
-//! Class wihich let to register properties
-class CONFIG_EXPORT Config_PropManager
+/**
+ * \class Config_PropManager
+ * \ingroup Config
+ * \brief Class which let to register properties
+ */
+class Config_PropManager
 {
-public:
+ public:
 
   /** 
-  * Registers property parameters
-  * \param theOwnerId - name of owner (name of plugin for example)
-  * \param theSection - name of section (domain of using) of the property.
-  * \param theName - name (title) of the value.
-  * \param theType - type of the value.
-  * \param theValue - initial value of the property
-  * Returns True if the property succesfully registered
-  */
-  static bool registerProp(const std::string& theOwnerId, 
-                           const std::string& theSection,
-                           const std::string& theName,
-                           const std::string& theTitle,
-                           Config_Prop::PropType theType,
-                           const std::string& theValue);
-
-  //! Returns list of registered owners.
-  static std::list<std::string> getOwners();
-
-  //! Returns list of properties by its owner.
-  static Config_Properties getProperties(const std::string& theOwnerId);
+   * Registers property parameters
+   * \param theSection - name of section (domain of using) of the property.
+   * \param theName - name (title) of the value.
+   * \param theTitle - title of the value.
+   * \param theType - type of the value.
+   * \param theDefValue - default and initial value of the property
+   * \param theMin - minimal value
+   * \param theMax - minimal value
+   * Returns True if the property succesfully registered
+   */
+  CONFIG_EXPORT static Config_Prop* registerProp(const std::string& theSection,
+    const std::string& theName,
+    const std::string& theTitle, Config_Prop::PropType theType,
+    const std::string& theDefValue = "",
+    const std::string& theMin = "",
+    const std::string& theMax = "");
+
+  //! Finds property in the given section by the given name, if property not found returns NULL
+  CONFIG_EXPORT static Config_Prop* findProp(
+    const std::string& theSection, const std::string& theName);
+
+  //! Returns std::list of all existing properies
+  CONFIG_EXPORT static Config_Properties getProperties();
 
   //! Returns list of registered section names.
-  static std::list<std::string> getSections(const std::string& theOwnerId);
+  CONFIG_EXPORT static std::list<std::string> getSections();
 
   //! Returns list of properties by its owner and section.
-  static Config_Properties getProperties(const std::string& theOwnerId, const std::string& theSection);
+  CONFIG_EXPORT static Config_Properties getProperties(const std::string& theSection);
 
   //! Returns value of the property by its owner, section, and name
-  static std::string value(const std::string& theOwnerId, 
-                           const std::string& theSection, 
-                           const std::string& theName,
-                           const std::string& theDefault);              
-
-private:
-
-  /** 
-  * Registers property parameters
-  * \param theOwnerId - name of owner (name of plugin for example)
-  * \param theProp - the Property object.
-  * Returns True if the property succesfully registered
-  */
-  static bool registerProp(const std::string& theOwnerId, 
-                           Config_Prop* theProp);
-
-  static std::map<std::string, Config_Properties> myPropMap;
+  CONFIG_EXPORT static std::string string(const std::string& theSection,
+                                          const std::string& theName);
+  //! Returns color by given section and name as 3-element vector {r,g,b}.
+  CONFIG_EXPORT static std::vector<int> color(const std::string& theSection,
+                                              const std::string& theName);
+  //! Returns integer by given section and name
+  CONFIG_EXPORT static int integer(const std::string& theSection,
+                                   const std::string& theName);
+  //! Returns real by given section and name
+  CONFIG_EXPORT static double real(const std::string& theSection,
+                                   const std::string& theName);
+  //! Returns boolean by given section and name
+  CONFIG_EXPORT static bool boolean(const std::string& theSection,
+                                    const std::string& theName);
+
+  //! Returns convertion of the string to double value. Temporary changes locale to process
+  //! values contained "," or "." separator.
+  //! \param theDouble a value to be converted
+  //! \return double result or zero
+  CONFIG_EXPORT static double stringToDouble(const std::string& theDouble);
+
+ private:
+  CONFIG_EXPORT static Config_Properties& props(); ///< List of all stored properties
 };
 
-
-CONFIG_EXPORT std::vector<int> stringToRGB(const std::string& theColor);
-
-#endif
\ No newline at end of file
+#endif