#include <QTextStream>
class Logger {
- public:
- enum LogLevel {
- DebugLevel,
- InfoLevel,
- WarningLevel,
- ErrorLevel
- };
-
- inline Logger(LogLevel level) : _stream(&_buffer, QIODevice::WriteOnly), _logLevel(level) {}
- ~Logger();
-
- template<typename T>
- inline Logger &operator<<(const T &value) { _stream << value; return *this; }
- inline Logger &operator<<(const QStringList & t) { _stream << t.join(" "); return *this; }
- inline Logger &operator<<(const char* t) { _stream << QString::fromLocal8Bit(t); return *this; }
- inline Logger &operator<<(bool t) { _stream << (t ? "true" : "false"); return *this; }
-
- private:
- void log();
- QTextStream _stream;
- QString _buffer;
- LogLevel _logLevel;
-};
-
-class quDebug : public Logger {
- public:
- inline quDebug() : Logger(Logger::DebugLevel) {}
+public:
+ enum LogLevel {
+ DebugLevel,
+ InfoLevel,
+ WarningLevel,
+ ErrorLevel
+ };
+
+ inline Logger(LogLevel level) : _stream(&_buffer, QIODevice::WriteOnly), _logLevel(level) {}
+ ~Logger();
+
+ static void logMessage(QtMsgType type, const char *msg);
+
+ template<typename T>
+ inline Logger &operator<<(const T &value) { _stream << value << " "; return *this; }
+ inline Logger &operator<<(const QStringList & t) { _stream << t.join(" ") << " "; return *this; }
+ inline Logger &operator<<(bool t) { _stream << (t ? "true" : "false") << " "; return *this; }
+
+private:
+ void log();
+ QTextStream _stream;
+ QString _buffer;
+ LogLevel _logLevel;
};
class quInfo : public Logger {
- public:
- inline quInfo() : Logger(Logger::InfoLevel) {}
-};
-
-class quWarning : public Logger {
- public:
- inline quWarning() : Logger(Logger::WarningLevel) {}
+public:
+ inline quInfo() : Logger(Logger::InfoLevel) {}
};
-class quError : public Logger {
- public:
- inline quError() : Logger(Logger::ErrorLevel) {}
-};
#endif