debug.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 
00056 #ifndef __DEBUG_HPP__
00057 #define __DEBUG_HPP__
00058 
00059 // =====================================================================
00060 // =====================================================================
00061 
00062 
00063 #ifndef NDEBUG
00064 
00065 #include <iostream>
00066 #include <openfluid/config.hpp>
00067 
00068 #define OFDBG_ENABLED 1
00069 #define OFDBG_OUTSTREAM std::cout
00070 
00071 #else
00072 
00073 #define OFDBG_ENABLED 0
00074 #define OFDBG_OUTSTREAM
00075 
00076 #endif
00077 
00078 
00079 // =====================================================================
00080 // =====================================================================
00081 
00082 
00083 #ifndef NDEBUG
00084 
00085 #define OFDBG_LOCATE { OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << " File " << __FILE__ << ", Line " << __LINE__ << std::endl; }
00086 
00087 #else
00088 
00089 #define OFDBG_LOCATE ;
00090 
00091 #endif
00092 
00093 
00094 // =====================================================================
00095 // =====================================================================
00096 
00097 
00098 #ifndef NDEBUG
00099 
00100 #define OFDBG_BANNER \
00101   { \
00102     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << std::endl; \
00103     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << "   OpenFLUID debugging mode is enabled" << std::endl; \
00104     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << std::endl; \
00105   }
00106 
00107 #else
00108 
00109 #define OFDBG_BANNER
00110 
00111 #endif
00112 
00113 
00114 // =====================================================================
00115 // =====================================================================
00116 
00117 
00118 #ifndef NDEBUG
00119 
00120 #define OFDBG_MESSAGE(stream) \
00121   { OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << " " << stream << std::endl; }
00122 
00123 #else
00124 
00125 #define OFDBG_MESSAGE(stream)
00126 
00127 #endif
00128 
00129 
00130 // =====================================================================
00131 // =====================================================================
00132 
00133 
00134 #ifndef NDEBUG
00135 
00136 #define OFDBG_UNIT(unitptr) \
00137   { OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << " Unit class " << (unitptr)->getClass() << ", ID " << (unitptr)->getID() << std::endl; }
00138 
00139 #else
00140 
00141 #define OFDBG_UNIT(unitptr)
00142 
00143 #endif
00144 
00145 
00146 // =====================================================================
00147 // =====================================================================
00148 
00149 
00150 #ifndef NDEBUG
00151 
00152 #define OFDBG_UNIT_EXTENDED(unitptr) \
00153   { \
00154     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << " Unit class " << (unitptr)->getClass() << ", ID " << (unitptr)->getID() << std::endl; \
00155     std::vector<openfluid::core::InputDataName_t> _M_DBG_IDataNames = (unitptr)->getInputData()->getInputDataNames(); \
00156     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << "   - Input data: "; \
00157     for (unsigned int i=0; i<_M_DBG_IDataNames.size();i++) OFDBG_OUTSTREAM << _M_DBG_IDataNames[i] << " , "; \
00158     OFDBG_OUTSTREAM << std::endl; \
00159     std::vector<openfluid::core::VariableName_t> _M_DBG_VarNames = (unitptr)->getVariables()->getVariablesNames(); \
00160     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << "   - Variables: "; \
00161     for (unsigned int i=0; i<_M_DBG_VarNames.size();i++) OFDBG_OUTSTREAM << _M_DBG_VarNames[i] << " , "; \
00162     OFDBG_OUTSTREAM << std::endl; \
00163   }
00164 
00165 #else
00166 
00167 #define OFDBG_UNIT_EXTENDED(unitptr)
00168 
00169 #endif
00170 
00171 
00172 // =====================================================================
00173 // =====================================================================
00174 
00175 
00176 #ifndef NDEBUG
00177 
00178 #define OFDBG_EVENT(eventptr) \
00179   { \
00180     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << " Event at " << (eventptr)->getDateTime().getAsISOString() << std::endl; \
00181     openfluid::core::Event::EventInfosMap_t::iterator _M_DBG_EvInfoiter; \
00182     for (_M_DBG_EvInfoiter = (eventptr)->getInfos().begin();_M_DBG_EvInfoiter != (eventptr)->getInfos().end();++_M_DBG_EvInfoiter) \
00183     { \
00184       OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << "   - " << (*_M_DBG_EvInfoiter).first << " = " << (*_M_DBG_EvInfoiter).second.get() << std::endl; \
00185     } \
00186   }
00187 
00188 #else
00189 
00190 #define OFDBG_EVENT(eventptr)
00191 
00192 #endif
00193 
00194 
00195 // =====================================================================
00196 // =====================================================================
00197 
00198 
00199 #ifndef NDEBUG
00200 
00201 #define OFDBG_EVENTCOLLECTION(eventcoll) \
00202   { \
00203     OFDBG_OUTSTREAM << openfluid::config::DEBUG_PREFIX << " Event collection size : " << eventcoll.getEventsList()->size() << std::endl; \
00204     openfluid::core::EventsList_t::iterator _M_DBG_EvListiter; \
00205     for (_M_DBG_EvListiter=(EvColl.getEventsList())->begin(); _M_DBG_EvListiter != (EvColl.getEventsList())->end(); _M_DBG_EvListiter++) \
00206     { \
00207       OFDBG_EVENT(&(*_M_DBG_EvListiter)); \
00208     } \
00209   }
00210 
00211 #else
00212 
00213 #define OFDBG_EVENTCOLLECTION(eventcoll)
00214 
00215 #endif
00216 
00217 
00218 #endif /* __DEBUG_HPP__ */

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