core/InputData.hpp

Go to the documentation of this file.
00001 /*
00002  This file is part of OpenFLUID software
00003  Copyright (c) 2007-2010 INRA-Montpellier SupAgro
00004 
00005 
00006  == GNU General Public License Usage ==
00007 
00008  OpenFLUID is free software: you can redistribute it and/or modify
00009  it under the terms of the GNU General Public License as published by
00010  the Free Software Foundation, either version 3 of the License, or
00011  (at your option) any later version.
00012 
00013  OpenFLUID is distributed in the hope that it will be useful,
00014  but WITHOUT ANY WARRANTY; without even the implied warranty of
00015  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00016  GNU General Public License for more details.
00017 
00018  You should have received a copy of the GNU General Public License
00019  along with OpenFLUID.  If not, see <http://www.gnu.org/licenses/>.
00020 
00021  In addition, as a special exception, INRA gives You the additional right
00022  to dynamically link the code of OpenFLUID with code not covered
00023  under the GNU General Public License ("Non-GPL Code") and to distribute
00024  linked combinations including the two, subject to the limitations in this
00025  paragraph. Non-GPL Code permitted under this exception must only link to
00026  the code of OpenFLUID dynamically through the OpenFLUID libraries
00027  interfaces, and only for building OpenFLUID plugins. The files of
00028  Non-GPL Code may be link to the OpenFLUID libraries without causing the
00029  resulting work to be covered by the GNU General Public License. You must
00030  obey the GNU General Public License in all respects for all of the
00031  OpenFLUID code and other code used in conjunction with OpenFLUID
00032  except the Non-GPL Code covered by this exception. If you modify
00033  this OpenFLUID, you may extend this exception to your version of the file,
00034  but you are not obligated to do so. If you do not wish to provide this
00035  exception without modification, you must delete this exception statement
00036  from your version and license this OpenFLUID solely under the GPL without
00037  exception.
00038 
00039 
00040  == Other Usage ==
00041 
00042  Other Usage means a use of OpenFLUID that is inconsistent with the GPL
00043  license, and requires a written agreement between You and INRA.
00044  Licensees for Other Usage of OpenFLUID may use this file in accordance
00045  with the terms contained in the written agreement between You and INRA.
00046  */
00047 
00048 #ifndef __INPUTDATA_H__
00049 #define __INPUTDATA_H__
00050 
00051 #include <openfluid/core/TypeDefs.hpp>
00052 #include <openfluid/dllexport.hpp>
00053 
00054 namespace openfluid {
00055 namespace core {
00056 
00057 template<class T>
00058 class DLLEXPORT InputData
00059 {
00060   private:
00061 
00062     typedef std::map<InputDataName_t, T> InputDataMap_t;
00063     InputDataMap_t m_Data;
00064 
00065   public:
00066 
00067     InputData();
00068 
00069     ~InputData();
00070 
00071     bool setValue(const InputDataName_t aName, const T aValue);
00072 
00073     bool getValue(const InputDataName_t aName, T *aValue);
00074 
00075     bool getValueAsDouble(const InputDataName_t aName, double *aValue);
00076 
00077     bool getValueAsLong(const InputDataName_t aName, long *aValue);
00078 
00079     bool isDataExist(const InputDataName_t aName) const;
00080 
00081     std::vector<InputDataName_t> getInputDataNames() const;
00082 
00083     void replaceValue(const InputDataName_t aName, const T aValue);
00084 
00085     void removeData(const InputDataName_t aName);
00086 
00087     void clear();
00088 
00089 };
00090 
00091 // =====================================================================
00092 // =====================================================================
00093 
00094 
00095 template<class T>
00096 InputData<T>::InputData()
00097 {
00098 
00099 }
00100 
00101 // =====================================================================
00102 // =====================================================================
00103 
00104 
00105 template<class T>
00106 InputData<T>::~InputData()
00107 {
00108 
00109 }
00110 
00111 // =====================================================================
00112 // =====================================================================
00113 
00114 template<class T>
00115 bool InputData<T>::setValue(const InputDataName_t aName, const T aValue)
00116 {
00117 
00118   if (isDataExist(aName))
00119     return false;
00120   else
00121   {
00122     m_Data[aName] = aValue;
00123   }
00124   return true;
00125 }
00126 
00127 // =====================================================================
00128 // =====================================================================
00129 
00130 
00131 template<class T>
00132 bool InputData<T>::getValue(const InputDataName_t aName, T *aValue)
00133 {
00134   typename InputDataMap_t::iterator it = m_Data.find(aName);
00135 
00136   if (it != m_Data.end())
00137   {
00138     *aValue = it->second;
00139     return true;
00140   } else
00141     return false;
00142 }
00143 
00144 // =====================================================================
00145 // =====================================================================
00146 
00147 
00148 template<class T>
00149 bool InputData<T>::getValueAsDouble(const InputDataName_t aName, double *aValue)
00150 {
00151   T TValue;
00152   typename InputDataMap_t::iterator it = m_Data.find(aName);
00153 
00154   if (it != m_Data.end())
00155   {
00156     TValue = it->second;
00157 
00158     std::istringstream iss(TValue);
00159     return !(iss >> (*aValue)).fail();
00160   } else
00161     return false;
00162 }
00163 
00164 // =====================================================================
00165 // =====================================================================
00166 
00167 
00168 template<class T>
00169 bool InputData<T>::getValueAsLong(const InputDataName_t aName, long *aValue)
00170 {
00171   T TValue;
00172   typename InputDataMap_t::iterator it = m_Data.find(aName);
00173 
00174   if (it != m_Data.end())
00175   {
00176     TValue = it->second;
00177 
00178     std::istringstream iss(TValue);
00179     return !(iss >> (*aValue)).fail();
00180   } else
00181     return false;
00182 }
00183 
00184 // =====================================================================
00185 // =====================================================================
00186 
00187 
00188 template<class T>
00189 bool InputData<T>::isDataExist(const InputDataName_t aName) const
00190 {
00191   return m_Data.find(aName) != m_Data.end();
00192 }
00193 
00194 // =====================================================================
00195 // =====================================================================
00196 
00197 template<class T>
00198 std::vector<InputDataName_t> InputData<T>::getInputDataNames() const
00199 {
00200   std::vector<InputDataName_t> TheNames;
00201 
00202   typename InputDataMap_t::const_iterator it;
00203 
00204   for (it = m_Data.begin(); it != m_Data.end(); ++it)
00205   {
00206     TheNames.push_back(it->first);
00207   }
00208 
00209   return TheNames;
00210 
00211 }
00212 
00213 // =====================================================================
00214 // =====================================================================
00215 
00216 template<class T>
00217 void InputData<T>::replaceValue(const InputDataName_t aName, const T aValue)
00218 {
00219   m_Data[aName] = aValue;
00220 }
00221 
00222 // =====================================================================
00223 // =====================================================================
00224 
00225 template<class T>
00226 void InputData<T>::removeData(const InputDataName_t aName)
00227 {
00228   typename InputDataMap_t::iterator it = m_Data.find(aName);
00229   if (it != m_Data.end())
00230     m_Data.erase(it);
00231 }
00232 
00233 
00234 // =====================================================================
00235 // =====================================================================
00236 
00237 
00238 template <class T>
00239 void InputData<T>::clear()
00240 {
00241     m_Data.clear();
00242 }
00243 
00244 
00245 } } // namespaces
00246 
00247 
00248 #endif /* __INPUTDATA_H__ */

Generated using Doxygen 1.7.3
Creative Commons License Creative Commons By-NC-ND license