All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Generator.hpp
Go to the documentation of this file.
1 /*
2 
3  This file is part of OpenFLUID software
4  Copyright(c) 2007, INRA - Montpellier SupAgro
5 
6 
7  == GNU General Public License Usage ==
8 
9  OpenFLUID is free software: you can redistribute it and/or modify
10  it under the terms of the GNU General Public License as published by
11  the Free Software Foundation, either version 3 of the License, or
12  (at your option) any later version.
13 
14  OpenFLUID is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  GNU General Public License for more details.
18 
19  You should have received a copy of the GNU General Public License
20  along with OpenFLUID. If not, see <http://www.gnu.org/licenses/>.
21 
22 
23  == Other Usage ==
24 
25  Other Usage means a use of OpenFLUID that is inconsistent with the GPL
26  license, and requires a written agreement between You and INRA.
27  Licensees for Other Usage of OpenFLUID may use this file in accordance
28  with the terms contained in the written agreement between You and INRA.
29 
30 */
31 
32 
33 
34 /**
35  @file
36 
37  @author Jean-Christophe FABRE <fabrejc@supagro.inra.fr>
38  */
39 
40 
41 #ifndef __GENERATOR_HPP__
42 #define __GENERATOR_HPP__
43 
44 #include <openfluid/dllexport.hpp>
47 
48 namespace openfluid { namespace machine {
49 
51 {
52  protected:
53 
55 
57 
59 
60  unsigned int m_VarSize;
61 
62 
63  public:
64 
65  Generator();
66 
67  ~Generator();
68 
69 
71  openfluid::fluidx::GeneratorDescriptor::GeneratorMethod GenMethod, unsigned int VarSize=1)
72  { m_VarName = VarName; m_UnitClass = UnitClass; m_GenMethod = GenMethod; m_VarSize = VarSize; };
73 
74  openfluid::core::VariableName_t getVariableName() const { return m_VarName; };
75 
76  openfluid::core::UnitClass_t getUnitClass() const { return m_UnitClass; };
77 
79 
80  inline bool isVectorVariable() const { return (m_VarSize > 1); };
81 
82  inline bool isScalarVariable() const { return (!isVectorVariable()); };
83 
84  inline unsigned int getVariableSize() const { return m_VarSize; };
85 
86 
87  virtual void prepareData() {};
88 
89 };
90 
91 } } //namespaces
92 
93 
94 
95 #endif /* __GENERATOR_H___ */
openfluid::core::UnitClass_t getUnitClass() const
Definition: Generator.hpp:76
unsigned int getVariableSize() const
Definition: Generator.hpp:84
virtual void prepareData()
Definition: Generator.hpp:87
Abstract class for simulator plugin.
Definition: PluggableSimulator.hpp:113
std::string UnitClass_t
Definition: TypeDefs.hpp:69
void setInfos(openfluid::core::VariableName_t VarName, openfluid::core::UnitClass_t UnitClass, openfluid::fluidx::GeneratorDescriptor::GeneratorMethod GenMethod, unsigned int VarSize=1)
Definition: Generator.hpp:70
openfluid::core::VariableName_t getVariableName() const
Definition: Generator.hpp:74
openfluid::core::UnitClass_t m_UnitClass
Definition: Generator.hpp:56
bool isVectorVariable() const
Definition: Generator.hpp:80
Definition: Generator.hpp:50
std::string VariableName_t
Definition: TypeDefs.hpp:79
openfluid::fluidx::GeneratorDescriptor::GeneratorMethod getGeneratorMethod() const
Definition: Generator.hpp:78
openfluid::core::VariableName_t m_VarName
Definition: Generator.hpp:54
GeneratorMethod
Definition: GeneratorDescriptor.hpp:53
openfluid::fluidx::GeneratorDescriptor::GeneratorMethod m_GenMethod
Definition: Generator.hpp:58
bool isScalarVariable() const
Definition: Generator.hpp:82
unsigned int m_VarSize
Definition: Generator.hpp:60
#define DLLEXPORT
Definition: dllexport.hpp:51