]> SALOME platform Git repositories - modules/kernel.git/blob - src/SALOMELocalTrace/utilities.h
Salome HOME
PR: mergefrom_BR_CCRT_11Nov04
[modules/kernel.git] / src / SALOMELocalTrace / utilities.h
1 //  SALOME Utils : general SALOME's definitions and tools
2 //
3 //  Copyright (C) 2003  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 //  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS 
5 // 
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. 
10 // 
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. 
15 // 
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 
19 // 
20 //  See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org 
21 //
22 //
23 //
24 //  File   : utilities.h
25 //  Author : Antoine YESSAYAN, Paul RASCLE, EDF
26 //  Module : SALOME
27 //  $Header$
28
29 /* ---  Definition macros file to print informations if _DEBUG_ is defined --- */
30
31 #ifndef UTILITIES_H
32 #define UTILITIES_H
33
34 #include <strstream>
35 #include <iostream>
36 #include <sstream>
37 #include <cstdlib>
38
39
40 #include "LocalTraceBufferPool.hxx"
41
42 /*!
43  * For each message to put in the trace, a specific ostingstream object is
44  * created and destroyed automatically at the end of the message macro.
45  * The insert function of LocalTraceBufferPool class gets a buffer in a
46  * buffer pool (unique with the help of mutexes and semaphores) and copy the
47  * message in the buffer.
48  * This buffer is read later by a specific thread in charge of trace print.
49  * Order of trace entries is globally respected. Nevertheless, if there are
50  * several threads waiting for a free buffer to trace, the order of
51  * thread waken up is not garanteed (no fifo or priority rules in Linux Kernel)
52  */
53
54 #define MESS_INIT(deb) std::ostringstream os; os<<deb
55 #define MESS_BEGIN(deb) MESS_INIT(deb)<<__FILE__ <<" ["<<__LINE__<<"] : "
56 #define MESS_END endl; LocalTraceBufferPool::instance()->insert(NORMAL_MESS, os.str().c_str());
57 #define MESS_ABORT endl; LocalTraceBufferPool::instance()->insert(ABORT_MESS, os.str().c_str());
58
59 // --- Some macros are always defined (without _DEBUG_): for use with release version
60
61 #define INFOS(msg) {MESS_BEGIN("- Trace ") << msg << MESS_END}
62 #define PYSCRIPT(msg) {MESS_INIT("---PYSCRIPT--- ") << msg << MESS_END}
63 #define INTERRUPTION(msg) {MESS_BEGIN("- INTERRUPTION: ")<< msg << MESS_ABORT}
64 #define IMMEDIATE_ABORT(code) {cout <<std::flush; \
65                                cerr << "- ABORT " << __FILE__ << " [" <<__LINE__<< "] : " << flush; \
66                                cerr << "ABORT return code= "<< code << endl; \
67                                std::exit(code);}
68
69 /* --- To print date and time of compilation of current source --- */
70
71 #if defined ( __GNUC__ )
72 #define COMPILER                "g++" 
73 #elif defined ( __sun )
74 #define COMPILER                "CC" 
75 #elif defined ( __KCC )
76 #define COMPILER                "KCC" 
77 #elif defined ( __PGI )
78 #define COMPILER                "pgCC" 
79 #elif defined ( __alpha )
80 #define COMPILER                "cxx" 
81 #else
82 #define COMPILER                "undefined" 
83 #endif
84
85 #ifdef INFOS_COMPILATION
86 #error INFOS_COMPILATION already defined
87 #endif
88
89 #define INFOS_COMPILATION { MESS_BEGIN("COMPILED with ") << COMPILER \
90                                        << ", " << __DATE__ \
91                                        << " at " << __TIME__ << MESS_END }
92 #ifdef _DEBUG_
93
94 // --- the following MACROS are useful at debug time
95
96 #define MESSAGE(msg) {MESS_BEGIN("- Trace ") << msg << MESS_END}
97 #define SCRUTE(var)  {MESS_BEGIN("- Trace ") << #var << "=" << var <<MESS_END}
98
99 #define REPERE ("------- ")
100 #define BEGIN_OF(msg) {MESS_BEGIN(REPERE) << "Begin of: "      << msg << MESS_END} 
101 #define END_OF(msg)   {MESS_BEGIN(REPERE) << "Normal end of: " << msg << MESS_END} 
102
103 #ifndef ASSERT
104 #define ASSERT(condition) \
105         if (!(condition)){INTERRUPTION("CONDITION "<<#condition<<" NOT VERIFIED")}
106 #endif /* ASSERT */
107
108
109 #else /* ifdef _DEBUG_*/
110
111 #define MESSAGE(msg) {}
112 #define SCRUTE(var) {}
113 #define REPERE
114 #define BEGIN_OF(msg) {}
115 #define END_OF(msg) {}
116
117 #ifndef ASSERT
118 #define ASSERT(condition) {}
119 #endif /* ASSERT */
120
121 #endif /* ifdef _DEBUG_*/
122
123 #endif /* ifndef UTILITIES_H */