ware/PluggableObserver.hpp
Go to the documentation of this file.
00001 /*
00002 
00003   This file is part of OpenFLUID software
00004   Copyright(c) 2007, INRA - Montpellier SupAgro
00005 
00006 
00007  == GNU General Public License Usage ==
00008 
00009   OpenFLUID is free software: you can redistribute it and/or modify
00010   it under the terms of the GNU General Public License as published by
00011   the Free Software Foundation, either version 3 of the License, or
00012   (at your option) any later version.
00013 
00014   OpenFLUID is distributed in the hope that it will be useful,
00015   but WITHOUT ANY WARRANTY; without even the implied warranty of
00016   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00017   GNU General Public License for more details.
00018 
00019   You should have received a copy of the GNU General Public License
00020   along with OpenFLUID. If not, see <http://www.gnu.org/licenses/>.
00021 
00022 
00023  == Other Usage ==
00024 
00025   Other Usage means a use of OpenFLUID that is inconsistent with the GPL
00026   license, and requires a written agreement between You and INRA.
00027   Licensees for Other Usage of OpenFLUID may use this file in accordance
00028   with the terms contained in the written agreement between You and INRA.
00029   
00030 */
00031 
00032 
00033 /**
00034   \file PluggableObserver.hpp
00035   \brief Header of ...
00036 
00037   \author Jean-Christophe FABRE <fabrejc@supagro.inra.fr>
00038  */
00039 
00040 
00041 #ifndef __PLUGGABLEOBSERVER_HPP__
00042 #define __PLUGGABLEOBSERVER_HPP__
00043 
00044 #include <openfluid/dllexport.hpp>
00045 #include <openfluid/ware/SimulationInspectorWare.hpp>
00046 #include <openfluid/ware/ObserverSignature.hpp>
00047 #include <openfluid/base/LoopMacros.hpp>
00048 
00049 
00050 // =====================================================================
00051 // =====================================================================
00052 
00053 
00054 /**
00055   Macro for declaration of observer and signature hooks
00056 */
00057 #define DECLARE_OBSERVER_PLUGIN \
00058   extern "C" \
00059   { \
00060     DLLEXPORT std::string WAREABIVERSION_PROC_DECL(); \
00061     DLLEXPORT openfluid::ware::PluggableObserver* WAREBODY_PROC_DECL(); \
00062     DLLEXPORT openfluid::ware::ObserverSignature* WARESIGNATURE_PROC_DECL(); \
00063   }
00064 
00065 
00066 
00067 
00068 // =====================================================================
00069 // =====================================================================
00070 
00071 
00072 /**
00073   Macro for definition of observer class hook
00074   @param[in] pluginclassname The name of the class to instantiate
00075 */
00076 #define DEFINE_OBSERVER_CLASS(pluginclassname) \
00077   std::string WAREABIVERSION_PROC_DECL() \
00078   { \
00079     return std::string(openfluid::config::FULL_VERSION); \
00080   } \
00081   \
00082   openfluid::ware::PluggableObserver* WAREBODY_PROC_DECL() \
00083   { \
00084     return new pluginclassname(); \
00085   }
00086 
00087 
00088 // =====================================================================
00089 // =====================================================================
00090 
00091 
00092 namespace openfluid { namespace ware {
00093 
00094 
00095 class DLLEXPORT PluggableObserver : public SimulationInspectorWare
00096 {
00097 
00098   public:
00099 
00100     PluggableObserver();
00101 
00102     virtual ~PluggableObserver();
00103 
00104     /**
00105        Internally called by the framework.
00106      */
00107     void initializeWare(const WareID_t& SimID);
00108 
00109     /**
00110        Initializes simulator parameters of the simulator, given as a hash map. Internally called by the framework.
00111      */
00112     virtual void initParams(const openfluid::ware::WareParams_t& Params)=0;
00113 
00114     /**
00115        Prepares data. Internally called by the framework.
00116     */
00117     virtual void onPrepared()=0;
00118 
00119 
00120     /**
00121        Internally called by the framework.
00122     */
00123     virtual void onInitializedRun()=0;
00124 
00125     /**
00126        Internally called by the framework.
00127     */
00128     virtual void onStepCompleted()=0;
00129 
00130     /**
00131        Internally called by the framework.
00132     */
00133     virtual void onFinalizedRun()=0;
00134 
00135 };
00136 
00137 typedef PluggableObserver* (*GetPluggableObserverBodyProc)();
00138 
00139 typedef ObserverSignature* (*GetPluggableObserverSignatureProc)();
00140 
00141 } } // openfluid::ware
00142 
00143 
00144 
00145 
00146 
00147 #endif /* __PLUGGABLEOBSERVER_HPP__ */
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines