Version: 9.12.0
SALOMETraceCollector Class Reference

#include <SALOMETraceCollector.hxx>

Inheritance diagram for SALOMETraceCollector:

Public Member Functions

 ~SALOMETraceCollector ()
 Destructor: wait until printing thread ends (SALOMETraceCollector::run) More...
 

Static Public Member Functions

static BaseTraceCollectorinstance ()
 This class is for use with CORBA, inside SALOME. More...
 
static void * run (void *bid)
 In a separate thread, loop to print traces. More...
 

Protected Member Functions

 SALOMETraceCollector ()
 Constructor: no need of LocalTraceBufferPool object initialization here, thread safe singleton used in LocalTraceBufferPool::instance() More...
 

Static Protected Attributes

static int _threadToClose = 0
 
static BaseTraceCollector_singleton = 0
 
static pthread_mutex_t _singletonMutex
 
static pthread_t * _threadId = 0
 
static sem_t _sem
 

Constructor & Destructor Documentation

◆ ~SALOMETraceCollector()

◆ SALOMETraceCollector()

SALOMETraceCollector::SALOMETraceCollector ( )
protected

Constructor: no need of LocalTraceBufferPool object initialization here, thread safe singleton used in LocalTraceBufferPool::instance()

References BaseTraceCollector::_threadId, and BaseTraceCollector::_threadToClose.

Referenced by instance().

Member Function Documentation

◆ instance()

BaseTraceCollector * SALOMETraceCollector::instance ( )
static

This class is for use with CORBA, inside SALOME.

Type of trace (and corresponding class) is chosen in LocalTraceBufferPool.

Guarantees a unique object instance of the class (singleton thread safe) a separate thread for loop to print traces is launched.

References BaseTraceCollector::_sem, BaseTraceCollector::_singleton, BaseTraceCollector::_singletonMutex, run(), and SALOMETraceCollector().

Referenced by SingletonInstance(), and TestLauncherSimple.TestLauncher::tearDown().

◆ run()

void * SALOMETraceCollector::run ( void *  bid)
static

In a separate thread, loop to print traces.

Mutex guarantees initialisation on instance method is done and only one run allowed (double check ...) Loop until there is no more buffer to print, and no ask for end from destructor. Get a buffer. If type = ABORT then exit application with message.

References BaseTraceCollector::_sem, BaseTraceCollector::_threadId, BaseTraceCollector::_threadToClose, ABORT_MESS, DEVTRACE, LocalTraceBufferPool::instance(), KERNEL_PY.batchmode_salome::obj, LocalTraceBufferPool::retrieve(), LocalTrace_TraceInfo::threadId, LocalTraceBufferPool::toCollect(), LocalTrace_TraceInfo::trace, TraceCollector_WaitForServerReadiness(), and LocalTrace_TraceInfo::traceType.

Referenced by instance().

Field Documentation

◆ _sem

sem_t BaseTraceCollector::_sem
staticprotectedinherited

◆ _singleton

◆ _singletonMutex

◆ _threadId

◆ _threadToClose