Don't log to stdout if --syslog and/or --logfile are specified
[quassel.git] / src / common / logger.h
index c372a11..744c980 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005 by the Quassel Project                             *
+ *   Copyright (C) 2005-2012 by the Quassel Project                        *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 #ifndef LOGGER_H
 #define LOGGER_H
 
-#include "types.h"
-
-#include <QString>
 #include <QStringList>
 #include <QTextStream>
 
-class Logger {
-  public:
-    enum LogLevel {
-      DebugLevel,
-      InfoLevel,
-      WarningLevel,
-      ErrorLevel
-    };
+#include "quassel.h"
+#include "types.h"
 
-    inline Logger(LogLevel level) : _stream(&_buffer, QIODevice::WriteOnly), _logLevel(level) {}
-    ~Logger();
+class Logger {
+public:
+  inline Logger(Quassel::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; }
+  static void logMessage(QtMsgType type, const char *msg);
 
-  private:
-    void log();
-    QTextStream _stream;
-    QString _buffer;
-    LogLevel _logLevel;
-};
+  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; }
 
-class quDebug : public Logger {
-  public:
-    inline quDebug() : Logger(Logger::DebugLevel) {}
+private:
+  void log();
+  QTextStream _stream;
+  QString _buffer;
+  Quassel::LogLevel _logLevel;
 };
 
 class quInfo : public Logger {
-  public:
-    inline quInfo() : Logger(Logger::InfoLevel) {}
+public:
+  inline quInfo() : Logger(Quassel::InfoLevel) {}
 };
 
 class quWarning : public Logger {
-  public:
-    inline quWarning() : Logger(Logger::WarningLevel) {}
+public:
+  inline quWarning() : Logger(Quassel::WarningLevel) {}
 };
 
 class quError : public Logger {
-  public:
-    inline quError() : Logger(Logger::ErrorLevel) {}
+public:
+  inline quError() : Logger(Quassel::ErrorLevel) {}
 };
+
 #endif