mirror of
https://github.com/debauchee/barrier.git
synced 2024-12-02 08:19:57 +03:00
d1ca5295d1
to those levels. Default log level is now DEBUG for debug builds and INFO for release builds.
37 lines
791 B
C++
37 lines
791 B
C++
#include "CTimerThread.h"
|
|
#include "CThread.h"
|
|
#include "TMethodJob.h"
|
|
#include "CLog.h"
|
|
#include <assert.h>
|
|
|
|
//
|
|
// CTimerThread
|
|
//
|
|
|
|
CTimerThread::CTimerThread(double timeout) : m_timeout(timeout)
|
|
{
|
|
assert(m_timeout > 0.0);
|
|
m_callingThread = new CThread(CThread::getCurrentThread());
|
|
m_timingThread = new CThread(new TMethodJob<CTimerThread>(
|
|
this, &CTimerThread::timer));
|
|
}
|
|
|
|
CTimerThread::~CTimerThread()
|
|
{
|
|
log((CLOG_DEBUG1 "cancelling timeout"));
|
|
m_timingThread->cancel();
|
|
m_timingThread->wait();
|
|
log((CLOG_DEBUG1 "cancelled timeout"));
|
|
delete m_timingThread;
|
|
delete m_callingThread;
|
|
}
|
|
|
|
void CTimerThread::timer(void*)
|
|
{
|
|
log((CLOG_DEBUG1 "timeout in %f seconds", m_timeout));
|
|
CThread::sleep(m_timeout);
|
|
log((CLOG_DEBUG1 "timeout"));
|
|
m_callingThread->cancel();
|
|
}
|
|
|