X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Flogger.h;h=352b0ce37e2bd28d94f7f23411f59715e0ac67d2;hp=24a8bb16b6bd4d45d2749bc3f0bb5cf5694b83dc;hb=20b5edb626156df8c472df8250b5f2faaf37835e;hpb=0ac9ce4d7cf768d13993d6aa1d6b791c4149a843 diff --git a/src/common/logger.h b/src/common/logger.h index 24a8bb16..352b0ce3 100644 --- a/src/common/logger.h +++ b/src/common/logger.h @@ -1,11 +1,11 @@ /*************************************************************************** - * Copyright (C) 2005 by The Quassel Team * + * Copyright (C) 2005 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * + * (at your option) version 3. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * @@ -18,24 +18,54 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _LOGGER_H_ -#define _LOGGER_H_ +#ifndef LOGGER_H +#define LOGGER_H -#include +#include "types.h" -class Logger : public QObject { - Q_OBJECT +#include +#include +#include - public: - Logger(); - virtual ~Logger(); +class Logger { +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); - private: - //void messageHandler(QtMsgType type, const char *msg); + template + 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) {} +}; + +class quError : public Logger { +public: + inline quError() : Logger(Logger::ErrorLevel) {} +}; #endif