core/Unit.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 
00057 #ifndef __UNIT_H__
00058 #define __UNIT_H__
00059 
00060 
00061 #include <map>
00062 #include <string>
00063 
00064 #include <openfluid/core/UnitsColl.hpp>
00065 #include <openfluid/core/InputData.hpp>
00066 #include <openfluid/core/Variables.hpp>
00067 #include <openfluid/core/EventsColl.hpp>
00068 #include <openfluid/core/InstantiationInfo.hpp>
00069 #include <openfluid/dllexport.hpp>
00070 
00071 #include <boost/noncopyable.hpp>
00072 
00073 
00074 namespace openfluid { namespace core {
00075 
00076 class DLLEXPORT UnitsCollection;
00077 
00078 
00079 
00083 typedef std::map<UnitClass_t,UnitsCollection> UnitsListByClassMap_t;
00084 
00085 class DLLEXPORT Unit;
00086 
00090 typedef std::list<Unit*> UnitsPtrList_t;
00091 
00095 typedef std::map<UnitClass_t,UnitsPtrList_t> LinkedUnitsListByClassMap_t;
00096 
00125 class DLLEXPORT Unit : public InstantiationInfo
00126 {
00127   private:
00128     UnitID_t m_ID;
00129     UnitClass_t m_Class;
00130     unsigned int m_PcsOrder;
00131 
00132     LinkedUnitsListByClassMap_t m_FromUnits;
00133     LinkedUnitsListByClassMap_t m_ToUnits;
00134     LinkedUnitsListByClassMap_t m_ParentUnits;
00135     LinkedUnitsListByClassMap_t m_ChildrenUnits;
00136 
00137     InputData<InputDataValue> m_InputData;
00138 
00139     Variables<ScalarValue> m_ScalarVariables;
00140     Variables<VectorValue> m_VectorVariables;
00141 
00142     EventsCollection m_Events;
00143 
00144   public:
00145 
00146     /*
00147           Constructor
00148       @param[in] aClass the class of the unit
00149       @param[in] anID the ID of the unit
00150       @param[in] aPcsOrder the process order of the unit
00151         */
00152     Unit(const UnitClass_t aClass, const UnitID_t anID,
00153          const PcsOrd_t aPcsOrder, const InstantiationInfo::Type InstType);
00154 
00155     /*
00156           Destructor
00157         */
00158     ~Unit();
00159 
00163     inline unsigned int getProcessOrder() const { return m_PcsOrder; };
00164 
00168     inline UnitID_t getID() const { return m_ID; };
00169 
00170 
00174     inline UnitClass_t getClass() const { return m_Class; };
00175 
00176     bool addToUnit(Unit* aUnit);
00177 
00178     bool addFromUnit(Unit* aUnit);
00179 
00180     bool addParentUnit(Unit* aUnit);
00181 
00182     bool addChildUnit(Unit* aUnit);
00183 
00189     UnitsPtrList_t* getToUnits(const UnitClass_t aClass);
00190 
00191     const UnitsPtrList_t* getToUnits(const UnitClass_t aClass) const;
00192 
00198     UnitsPtrList_t* getFromUnits(const UnitClass_t aClass);
00199 
00200     const UnitsPtrList_t* getFromUnits(const UnitClass_t aClass) const;
00201 
00207     UnitsPtrList_t* getParentUnits(const UnitClass_t aClass);
00208 
00209     const UnitsPtrList_t* getParentUnits(const UnitClass_t aClass) const;
00210 
00216     UnitsPtrList_t* getChildrenUnits(const UnitClass_t aClass);
00217 
00218     const UnitsPtrList_t* getChildrenUnits(const UnitClass_t aClass) const;
00219 
00220 
00221 
00222 
00223     inline InputData<InputDataValue>* getInputData()  { return &m_InputData; };
00224 
00225     inline const InputData<InputDataValue>* getInputData() const { return &m_InputData; };
00226 
00227     inline Variables<ScalarValue>* getScalarVariables() { return &m_ScalarVariables; };
00228 
00229     inline const Variables<ScalarValue>* getScalarVariables() const { return &m_ScalarVariables; };
00230 
00231     inline Variables<VectorValue>* getVectorVariables() { return &m_VectorVariables; };
00232 
00233     inline const Variables<VectorValue>* getVectorVariables() const { return &m_VectorVariables; };
00234 
00235     inline EventsCollection* getEvents() { return &m_Events; };
00236 
00237     inline const EventsCollection* getEvents() const { return &m_Events; };
00238 
00239     void streamContents(std::ostream& OStream);
00240 
00241     void setProcessOrder(unsigned int PcsOrder) { m_PcsOrder = PcsOrder; };
00242 
00243 };
00244 
00245 
00246 } } // namespace openfluid::core
00247 
00248 
00249 #endif /* __UNIT_H__ */
00250 

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