OSCAR-code/sleepyhead/logger.h
2014-07-22 02:14:07 +10:00

47 lines
967 B
C++

#ifndef LOGGER_H
#define LOGGER_H
#include <QDebug>
#include <QRunnable>
#include <QThreadPool>
#include <QMutex>
#include <QTime>
void initializeLogger();
void shutdownLogger();
#if QT_VERSION < QT_VERSION_CHECK(5,0,0)
void MyOutputHandler(QtMsgType type, const char *msgtxt);
#else
void MyOutputHandler(QtMsgType type, const QMessageLogContext &context, const QString &msgtxt);
#endif
class LogThread:public QObject, public QRunnable
{
Q_OBJECT
public:
explicit LogThread() : QRunnable() { running = false; logtime.start(); }
virtual ~LogThread() {}
void run();
void append(QString msg);
void appendClean(QString msg);
bool isRunning() { return running; }
void quit();
QStringList buffer;
QMutex strlock;
QThreadPool *threadpool;
signals:
void outputLog(QString);
protected:
volatile bool running;
QTime logtime;
};
extern LogThread * logger;
extern QThreadPool * otherThreadPool;
#endif // LOGGER_H