Salome HOME
merge from branch BR_V5_DEV
[modules/yacs.git] / src / SALOMELocalTrace / BaseTraceCollector.cxx
1 //  Copyright (C) 2007-2008  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 //  Copyright (C) 2003-2007  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.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 //  File   : BaseTraceCollector.cxx
23 //  Author : Paul RASCLE (EDF)
24 //  Module : KERNEL
25 //  $Header$
26 //
27 #include <iostream>
28 #include <sstream>
29 #include <fstream>
30 #include <cstdlib>
31
32 #include "BaseTraceCollector.hxx"
33 #include "LocalTraceBufferPool.hxx"
34
35 using namespace std;
36
37 // Class attributes initialisation, for class method BaseTraceCollector::run
38
39 BaseTraceCollector* BaseTraceCollector::_singleton = 0;
40 #ifndef WIN32
41 pthread_mutex_t BaseTraceCollector::_singletonMutex;
42 #else
43 pthread_mutex_t BaseTraceCollector::_singletonMutex =
44   PTHREAD_MUTEX_INITIALIZER;
45 #endif
46 sem_t BaseTraceCollector::_sem;
47 int BaseTraceCollector::_threadToClose = 0;
48 pthread_t* BaseTraceCollector::_threadId = 0; // used to control single run
49
50 // ============================================================================
51 /*!
52  *  Destructor: virtual, implemented in derived classes.
53  *  Wait until printing thread ends (BaseTraceCollector::run)
54  */
55 // ============================================================================
56
57 BaseTraceCollector:: ~BaseTraceCollector()
58 {
59 }
60
61 // ============================================================================
62 /*!
63  * Constructor: no need of LocalTraceBufferPool object initialization here,
64  * thread safe singleton used in LocalTraceBufferPool::instance()
65  * See derived classes.
66  */
67 // ============================================================================
68
69 BaseTraceCollector::BaseTraceCollector()
70 {
71 }
72
73