forked from treefrogframework/treefrog-framework
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtbasiclogstream.cpp
More file actions
74 lines (58 loc) · 1.46 KB
/
Copy pathtbasiclogstream.cpp
File metadata and controls
74 lines (58 loc) · 1.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/* Copyright (c) 2010-2019, AOYAMA Kazuharu
* All rights reserved.
*
* This software may be used and distributed according to the terms of
* the New BSD License, which is incorporated herein by reference.
*/
#include "tbasiclogstream.h"
#include <QMutexLocker>
#include <QThread>
#include <TSystemGlobal>
/*!
\class TBasicLogStream
\brief The TBasicLogStream class provides a basic stream for logs.
*/
TBasicLogStream::TBasicLogStream(const QList<TLogger *> loggers, QObject *parent) :
TAbstractLogStream(loggers, parent)
{
loggerOpen();
}
TBasicLogStream::~TBasicLogStream()
{
flush();
}
void TBasicLogStream::writeLog(const TLog &log)
{
QMutexLocker locker(&mutex);
loggerWrite(log);
if (!isNonBufferingMode()) {
if (thread() == QThread::currentThread()) {
if (!timer.isActive()) {
timer.start(200, this);
}
} else {
// timers cannot be started from another thread
loggerFlush();
}
}
}
void TBasicLogStream::flush()
{
QMutexLocker locker(&mutex);
loggerFlush();
}
void TBasicLogStream::setNonBufferingMode()
{
QMutexLocker locker(&mutex);
TAbstractLogStream::setNonBufferingMode();
}
void TBasicLogStream::timerEvent(QTimerEvent *event)
{
QMutexLocker locker(&mutex);
if (event->timerId() != timer.timerId()) {
QObject::timerEvent(event);
return;
}
timer.stop();
loggerFlush(); // Flush logger
}