- inline Logger(LogLevel level) : stream(new Stream(level)) {}
- ~Logger();
-
- inline Logger &operator<<(const char* t) { stream->internalStream << QString::fromAscii(t); return *this; }
- inline Logger &operator<<(QChar t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(bool t) { stream->internalStream << (t ? "true" : "false"); return *this; }
- inline Logger &operator<<(char t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(signed short t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(unsigned short t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(signed int t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(unsigned int t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(signed long t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(unsigned long t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(qint64 t) { stream->internalStream << QString::number(t); return *this; }
- inline Logger &operator<<(quint64 t) { stream->internalStream << QString::number(t); return *this; }
- inline Logger &operator<<(float t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(double t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(const QString & t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(const QLatin1String &t) { stream->internalStream << t.latin1(); return *this; }
- inline Logger &operator<<(const QByteArray & t) { stream->internalStream << t ; return *this; }
- inline Logger &operator<<(const void * t) { stream->internalStream << t; return *this; }
- inline Logger &operator<<(const QStringList & t) { stream->internalStream << t.join(" "); return *this; }
- inline Logger &operator<<(const BufferId & t) { stream->internalStream << QVariant::fromValue(t).toInt(); return *this; }
- inline Logger &operator<<(const NetworkId & t) { stream->internalStream << QVariant::fromValue(t).toInt(); return *this; }
- inline Logger &operator<<(const UserId & t) { stream->internalStream << QVariant::fromValue(t).toInt(); return *this; }
- inline Logger &operator<<(const MsgId & t) { stream->internalStream << QVariant::fromValue(t).toInt(); return *this; }
- inline Logger &operator<<(const IdentityId & t) { stream->internalStream << QVariant::fromValue(t).toInt(); return *this; }
- inline Logger &operator<<(const AccountId & t) { stream->internalStream << QVariant::fromValue(t).toInt(); return *this; }
-
- void log();
- private:
- struct Stream {
- Stream(LogLevel level)
- : internalStream(&buffer, QIODevice::WriteOnly),
- logLevel(level) {}
- QTextStream internalStream;
- QString buffer;
- LogLevel logLevel;
- } *stream;
-};
+ struct LogEntry {
+ QDateTime timeStamp;
+ LogLevel logLevel;
+ QString message;
+ };
+
+ /**
+ * Initial setup, to be called ones command line options are available.
+ *
+ * Sets up the log file if appropriate. Outputs the log messages already accumulated since
+ * construction. If @c keepMessages is false, deletes the accumulated messages afterwards,
+ * and won't store further ones.
+ *
+ * @param keepMessages Whether messages should be kept
+ * @returns true, if initialization was successful
+ */
+ bool setup(bool keepMessages);