making signalproxy direct connection thread safe
[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     template<typename T>
43     inline Logger &operator<<(const T &value) { _stream << value << " "; return *this; }
44     inline Logger &operator<<(const QStringList & t) { _stream << t.join(" ") << " "; return *this; }
45     inline Logger &operator<<(bool t) { _stream << (t ? "true" : "false") << " "; return *this; }
46
47   private:
48     void log();
49     QTextStream _stream;
50     QString _buffer;
51     LogLevel _logLevel;
52 };
53
54 class quDebug : public Logger {
55   public:
56     inline quDebug() : Logger(Logger::DebugLevel) {}
57 };
58
59 class quInfo : public Logger {
60   public:
61     inline quInfo() : Logger(Logger::InfoLevel) {}
62 };
63
64 class quWarning : public Logger {
65   public:
66     inline quWarning() : Logger(Logger::WarningLevel) {}
67 };
68
69 class quError : public Logger {
70   public:
71     inline quError() : Logger(Logger::ErrorLevel) {}
72 };
73 #endif