qBittorrent/src/base/logger.h

78 lines
1.6 KiB
C
Raw Normal View History

2015-01-04 02:20:59 +02:00
#ifndef LOGGER_H
#define LOGGER_H
#include <QString>
#include <QVector>
#include <QReadWriteLock>
#include <QObject>
2016-01-25 01:08:32 +02:00
const int MAX_LOG_MESSAGES = 20000;
2015-01-04 02:20:59 +02:00
namespace Log
{
enum MsgType
{
ALL = -1,
NORMAL = 0x1,
INFO = 0x2,
WARNING = 0x4,
CRITICAL = 0x8 //ERROR is defined by libtorrent and results in compiler error
2015-01-04 02:20:59 +02:00
};
Q_DECLARE_FLAGS(MsgTypes, MsgType)
2015-01-04 02:20:59 +02:00
struct Msg
{
int id;
qint64 timestamp;
MsgType type;
QString message;
};
struct Peer
{
int id;
qint64 timestamp;
QString ip;
bool blocked;
QString reason;
};
}
Q_DECLARE_OPERATORS_FOR_FLAGS(Log::MsgTypes)
2015-01-04 02:20:59 +02:00
class Logger : public QObject
{
Q_OBJECT
Q_DISABLE_COPY(Logger)
public:
2015-04-19 18:17:47 +03:00
static void initInstance();
static void freeInstance();
static Logger *instance();
2015-01-04 02:20:59 +02:00
void addMessage(const QString &message, const Log::MsgType &type = Log::NORMAL);
void addPeer(const QString &ip, bool blocked, const QString &reason = QString());
QVector<Log::Msg> getMessages(int lastKnownId = -1) const;
QVector<Log::Peer> getPeers(int lastKnownId = -1) const;
signals:
void newLogMessage(const Log::Msg &message);
void newLogPeer(const Log::Peer &peer);
private:
Logger();
2015-04-19 18:17:47 +03:00
~Logger();
2015-01-04 02:20:59 +02:00
static Logger* m_instance;
QVector<Log::Msg> m_messages;
QVector<Log::Peer> m_peers;
mutable QReadWriteLock lock;
int msgCounter;
int peerCounter;
};
// Helper function
void LogMsg(const QString &message, const Log::MsgType &type = Log::NORMAL);
2015-01-04 02:20:59 +02:00
#endif // LOGGER_H