Some work about adaptive color scheme for Web UI (PR #19901)
http://[316:c51a:62a3:8b9::4]/d4708/qBittorrent/src/branch/adaptive-webui
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
2.2 KiB
116 lines
2.2 KiB
#include "logger.h" |
|
|
|
#include <QDateTime> |
|
|
|
namespace Log |
|
{ |
|
Msg::Msg() {} |
|
|
|
Msg::Msg(int id, MsgType type, const QString &message) |
|
: id(id) |
|
, timestamp(QDateTime::currentMSecsSinceEpoch()) |
|
, type(type) |
|
, message(message) |
|
{ |
|
} |
|
|
|
Peer::Peer() {} |
|
|
|
Peer::Peer(int id, const QString &ip, bool blocked, const QString &reason) |
|
: id(id) |
|
, timestamp(QDateTime::currentMSecsSinceEpoch()) |
|
, ip(ip) |
|
, blocked(blocked) |
|
, reason(reason) |
|
{ |
|
} |
|
|
|
} |
|
|
|
Logger* Logger::m_instance = 0; |
|
|
|
Logger::Logger() |
|
: lock(QReadWriteLock::Recursive) |
|
, msgCounter(0) |
|
, peerCounter(0) |
|
{ |
|
} |
|
|
|
Logger::~Logger() {} |
|
|
|
Logger *Logger::instance() |
|
{ |
|
return m_instance; |
|
} |
|
|
|
void Logger::initInstance() |
|
{ |
|
if (!m_instance) |
|
m_instance = new Logger; |
|
} |
|
|
|
void Logger::freeInstance() |
|
{ |
|
if (m_instance) { |
|
delete m_instance; |
|
m_instance = 0; |
|
} |
|
} |
|
|
|
void Logger::addMessage(const QString &message, const Log::MsgType &type) |
|
{ |
|
QWriteLocker locker(&lock); |
|
|
|
Log::Msg temp(msgCounter++, type, message); |
|
m_messages.push_back(temp); |
|
|
|
if (m_messages.size() >= MAX_LOG_MESSAGES) |
|
m_messages.pop_front(); |
|
|
|
emit newLogMessage(temp); |
|
} |
|
|
|
void Logger::addPeer(const QString &ip, bool blocked, const QString &reason) |
|
{ |
|
QWriteLocker locker(&lock); |
|
|
|
Log::Peer temp(peerCounter++, ip, blocked, reason); |
|
m_peers.push_back(temp); |
|
|
|
if (m_peers.size() >= MAX_LOG_MESSAGES) |
|
m_peers.pop_front(); |
|
|
|
emit newLogPeer(temp); |
|
} |
|
|
|
QVector<Log::Msg> Logger::getMessages(int lastKnownId) const |
|
{ |
|
QReadLocker locker(&lock); |
|
|
|
int diff = msgCounter - lastKnownId - 1; |
|
int size = m_messages.size(); |
|
|
|
if ((lastKnownId == -1) || (diff >= size)) |
|
return m_messages; |
|
|
|
if (diff <= 0) |
|
return QVector<Log::Msg>(); |
|
|
|
return m_messages.mid(size - diff); |
|
} |
|
|
|
QVector<Log::Peer> Logger::getPeers(int lastKnownId) const |
|
{ |
|
QReadLocker locker(&lock); |
|
|
|
int diff = peerCounter - lastKnownId - 1; |
|
int size = m_peers.size(); |
|
|
|
if ((lastKnownId == -1) || (diff >= size)) |
|
return m_peers; |
|
|
|
if (diff <= 0) |
|
return QVector<Log::Peer>(); |
|
|
|
return m_peers.mid(size - diff); |
|
}
|
|
|