NCBI C++ ToolKit
Public Member Functions | Private Member Functions | List of all members
CLogWriter Class Reference

Search Toolkit Book for CLogWriter

+ Inheritance diagram for CLogWriter:
+ Collaboration diagram for CLogWriter:

Public Member Functions

 CLogWriter (void)
 
virtual ~CLogWriter (void)
 
- Public Member Functions inherited from CSrvTask
 CSrvTask (void)
 
void SetRunnable (bool boost=false)
 Set this task "runnable", i.e. More...
 
void RunAfter (Uint4 delay_sec)
 This call is basically equivalent to SetRunnable() but with guarantee that task will be scheduled for execution no earlier than delay_sec later (approximately, can be up to a second less if measured in absolute wall time). More...
 
virtual void Terminate (void)
 Stops task's execution and deletes it. More...
 
void SetPriority (Uint4 prty)
 Set and retrieve task's priority. More...
 
Uint4 GetPriority (void)
 
void CreateNewDiagCtx (void)
 Create new diagnostic context for this task to work in. More...
 
void SetDiagCtx (CRequestContext *ctx)
 Set diagnostic context for this task to work in. More...
 
CRequestContextGetDiagCtx (void)
 Get current diagnostic context for the task. More...
 
void ReleaseDiagCtx (void)
 Releases current diagnostic context of the task. More...
 
virtual ~CSrvTask (void)
 
virtual void InternalRunSlice (TSrvThreadNum thr_num)
 This is the real time slice execution method called from TaskServer. More...
 

Private Member Functions

virtual void ExecuteSlice (TSrvThreadNum thr_num)
 This is the main method to do all work this task should do. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from CSrvTask
static void PrintState (CSrvSocketTask &task)
 
- Public Attributes inherited from CSrvTask
TSrvTaskListHook m_TaskListHook
 Hook to put this task into TSrvTaskList. More...
 
TSrvThreadNum m_LastThread
 Thread number where this task was executed last time. More...
 
TSrvTaskFlags m_TaskFlags
 Bit-OR of flags for this task. More...
 
int m_LastActive
 Time (in seconds) when the task was active last time, i.e. More...
 
Uint4 m_Priority
 Task's priority. More...
 
CRequestContextm_DiagCtx
 Current diagnostic context for this task. More...
 
CRequestContext ** m_DiagChain
 Nested diagnostic contexts of this task. More...
 
size_t m_DiagChainSize
 
STimerTicketm_Timer
 Timer ticket assigned to this task when it calls RunAfter(). More...
 
CSrvTaskTerminator m_Terminator
 Object that will delete this task after call to Terminate(). More...
 

Detailed Description

Definition at line 78 of file logging.cpp.

Constructor & Destructor Documentation

◆ CLogWriter()

CLogWriter::CLogWriter ( void  )

Definition at line 1418 of file logging.cpp.

◆ ~CLogWriter()

CLogWriter::~CLogWriter ( void  )
virtual

Definition at line 1425 of file logging.cpp.

Member Function Documentation

◆ ExecuteSlice()

void CLogWriter::ExecuteSlice ( TSrvThreadNum  thr_num)
privatevirtual

This is the main method to do all work this task should do.

This method will be called periodically while somebody calls SetRunnable() or RunAfter() on this task. But number of calls to this method won't match number of calls to SetRunnable() – if several calls to SetRunnable() are made before ExecuteSlice() had a chance to execute it will be called only once. Task's code inside ExecuteSlice() should understand itself how much work it needs to do and call SetRunnable() again if needed (or do all the work before returning from ExecuteSlice()). Parameter thr_num is number of thread on which ExecuteSlice() is called.

Implements CSrvTask.

Definition at line 1429 of file logging.cpp.

References close(), CSrvTime::CurSecs(), free(), CMiniMutex::Lock(), s_CheckFatalAbort(), s_FileReopenPeriod, s_LastReopenTime, s_LogFd, s_WriteLog(), s_WriteQueue, s_WriteQueueLock, CSrvTask::SetRunnable(), str(), and CMiniMutex::Unlock().


The documentation for this class was generated from the following file:
Modified on Wed Apr 17 13:09:08 2024 by modify_doxy.py rev. 669887