1 // SALOME Utils : general SALOME's definitions and tools
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
25 // Author : Antoine YESSAYAN, Paul RASCLE, EDF
29 /* --- Definition macros file to print informations if _DEBUG_ is defined --- */
39 #include "LocalTraceBufferPool.hxx"
42 * For each message to put in the trace, a specific ostingstream object is
43 * created and destroyed automatically at the end of the message macro.
44 * The insert function of LocalTraceBufferPool class gets a buffer in a
45 * buffer pool (unique with the help of mutexes and semaphores) and copy the
46 * message in the buffer.
47 * This buffer is read later by a specific thread in charge of trace print.
48 * Order of trace entries is globally respected. Nevertheless, if there are
49 * several threads waiting for a free buffer to trace, the order of
50 * thread waken up is not garanteed (no fifo or priority rules in Linux Kernel)
53 #define MESS_INIT(deb) std::ostringstream os; os<<deb
54 #define MESS_BEGIN(deb) MESS_INIT(deb)<<__FILE__ <<" ["<<__LINE__<<"] : "
55 #define MESS_END endl; LocalTraceBufferPool::instance()->insert(NORMAL_MESS, os.str().c_str());
56 #define MESS_ABORT endl; LocalTraceBufferPool::instance()->insert(ABORT_MESS, os.str().c_str());
58 // --- Some macros are always defined (without _DEBUG_): for use with release version
60 #define INFOS(msg) {MESS_BEGIN("- Trace ") << msg << MESS_END}
61 #define PYSCRIPT(msg) {MESS_INIT("---PYSCRIPT--- ") << msg << MESS_END}
62 #define INTERRUPTION(msg) {MESS_BEGIN("- INTERRUPTION: ")<< msg << MESS_ABORT}
63 #define IMMEDIATE_ABORT(code) {cout <<std::flush; \
64 cerr << "- ABORT " << __FILE__ << " [" <<__LINE__<< "] : " << flush; \
65 cerr << "ABORT return code= "<< code << endl; \
68 /* --- To print date and time of compilation of current source --- */
70 #if defined ( __GNUC__ )
71 #define COMPILER "g++"
72 #elif defined ( __sun )
74 #elif defined ( __KCC )
75 #define COMPILER "KCC"
76 #elif defined ( __PGI )
77 #define COMPILER "pgCC"
78 #elif defined ( __alpha )
79 #define COMPILER "cxx"
81 #define COMPILER "undefined"
84 #ifdef INFOS_COMPILATION
85 #error INFOS_COMPILATION already defined
88 #define INFOS_COMPILATION { MESS_BEGIN("COMPILED with ") << COMPILER \
90 << " at " << __TIME__ << MESS_END }
93 // --- the following MACROS are useful at debug time
95 #define MESSAGE(msg) {MESS_BEGIN("- Trace ") << msg << MESS_END}
96 #define SCRUTE(var) {MESS_BEGIN("- Trace ") << #var << "=" << var <<MESS_END}
98 #define REPERE ("------- ")
99 #define BEGIN_OF(msg) {MESS_BEGIN(REPERE) << "Begin of: " << msg << MESS_END}
100 #define END_OF(msg) {MESS_BEGIN(REPERE) << "Normal end of: " << msg << MESS_END}
103 #define ASSERT(condition) \
104 if (!(condition)){INTERRUPTION("CONDITION "<<#condition<<" NOT VERIFIED")}
108 #else /* ifdef _DEBUG_*/
110 #define MESSAGE(msg) {}
111 #define SCRUTE(var) {}
113 #define BEGIN_OF(msg) {}
114 #define END_OF(msg) {}
117 #define ASSERT(condition) {}
120 #endif /* ifdef _DEBUG_*/
122 #endif /* ifndef UTILITIES_H */