Fix an issue with the event loop
[quassel.git] / src / common / logger.h
1 /***************************************************************************
2  *   Copyright (C) 2005 by the Quassel Project                             *
3  *   devel@quassel-irc.org                                                 *
4  *                                                                         *
5  *   This program is free software; you can redistribute it and/or modify  *
6  *   it under the terms of the GNU General Public License as published by  *
7  *   the Free Software Foundation; either version 2 of the License, or     *
8  *   (at your option) version 3.                                           *
9  *                                                                         *
10  *   This program is distributed in the hope that it will be useful,       *
11  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
12  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
13  *   GNU General Public License for more details.                          *
14  *                                                                         *
15  *   You should have received a copy of the GNU General Public License     *
16  *   along with this program; if not, write to the                         *
17  *   Free Software Foundation, Inc.,                                       *
18  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
19  ***************************************************************************/
20
21 #ifndef LOGGER_H
22 #define LOGGER_H
23
24 #include "types.h"
25
26 #include <QString>
27 #include <QStringList>
28 #include <QTextStream>
29
30 class Logger {
31 public:
32   enum LogLevel {
33     DebugLevel,
34     InfoLevel,
35     WarningLevel,
36     ErrorLevel
37   };
38
39   inline Logger(LogLevel level) : _stream(&_buffer, QIODevice::WriteOnly), _logLevel(level) {}
40   ~Logger();
41
42   static void logMessage(QtMsgType type, const char *msg);
43
44   template<typename T>
45   inline Logger &operator<<(const T &value) { _stream << value << " "; return *this; }
46   inline Logger &operator<<(const QStringList & t) { _stream << t.join(" ") << " "; return *this; }
47   inline Logger &operator<<(bool t) { _stream << (t ? "true" : "false") << " "; return *this; }
48
49 private:
50   void log();
51   QTextStream _stream;
52   QString _buffer;
53   LogLevel _logLevel;
54 };
55
56 class quInfo : public Logger {
57 public:
58   inline quInfo() : Logger(Logger::InfoLevel) {}
59 };
60
61 class quWarning : public Logger {
62 public:
63   inline quWarning() : Logger(Logger::WarningLevel) {}
64 };
65
66 class quError : public Logger {
67 public:
68   inline quError() : Logger(Logger::ErrorLevel) {}
69 };
70
71 #endif