diff options
| author | Jeremy Lainé <jeremy.laine@m4x.org> | 2010-08-11 07:31:23 +0000 |
|---|---|---|
| committer | Jeremy Lainé <jeremy.laine@m4x.org> | 2010-08-11 07:31:23 +0000 |
| commit | 40c39853816cfab113d79682c34bc76a2c79c357 (patch) | |
| tree | e4d6a184cf565cb87477339ce738299ff9787bc3 /src/QXmppLogger.cpp | |
| parent | 551c284e35280b7b91a939fe7352e496ffea402a (diff) | |
| download | qxmpp-40c39853816cfab113d79682c34bc76a2c79c357.tar.gz | |
rename "source" directory to "src"
Diffstat (limited to 'src/QXmppLogger.cpp')
| -rw-r--r-- | src/QXmppLogger.cpp | 144 |
1 files changed, 144 insertions, 0 deletions
diff --git a/src/QXmppLogger.cpp b/src/QXmppLogger.cpp new file mode 100644 index 00000000..ccff3fb5 --- /dev/null +++ b/src/QXmppLogger.cpp @@ -0,0 +1,144 @@ +/* + * Copyright (C) 2008-2010 The QXmpp developers + * + * Authors: + * Manjeet Dahiya + * Jeremy Lainé + * + * Source: + * http://code.google.com/p/qxmpp + * + * This file is a part of QXmpp library. + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + */ + +#include <iostream> + +#include <QTextStream> +#include <QFile> +#include <QTime> + +#include "QXmppLogger.h" + +QXmppLogger* QXmppLogger::m_logger = 0; + +static const char *typeName(QXmppLogger::MessageType type) +{ + switch (type) + { + case QXmppLogger::DebugMessage: + return "DEBUG"; + case QXmppLogger::InformationMessage: + return "INFO"; + case QXmppLogger::WarningMessage: + return "WARNING"; + case QXmppLogger::ReceivedMessage: + return "SERVER"; + case QXmppLogger::SentMessage: + return "CLIENT"; + default: + return ""; + } +} + +/// Constructs a new QXmppLogger. +/// +/// \param parent + +QXmppLogger::QXmppLogger(QObject *parent) + : QObject(parent), m_loggingType(QXmppLogger::NoLogging), + m_logFilePath("QXmppClientLog.log") +{ +} + +/// Returns the default logger. +/// + +QXmppLogger* QXmppLogger::getLogger() +{ + if(!m_logger) + { + m_logger = new QXmppLogger(); + m_logger->setLoggingType(FileLogging); + } + + return m_logger; +} + +/// Returns the handler for logging messages. +/// + +QXmppLogger::LoggingType QXmppLogger::loggingType() +{ + return m_loggingType; +} + +/// Sets the handler for logging messages. +/// +/// \param type + +void QXmppLogger::setLoggingType(QXmppLogger::LoggingType type) +{ + m_loggingType = type; +} + +/// Add a logging message. +/// +/// \param type +/// \param text + +void QXmppLogger::log(QXmppLogger::MessageType type, const QString& text) +{ + switch(m_loggingType) + { + case QXmppLogger::FileLogging: + { + QFile file(m_logFilePath); + file.open(QIODevice::Append); + QTextStream stream(&file); + stream << QTime::currentTime().toString("hh:mm:ss.zzz") << + " " << typeName(type) << " " << + text << "\n\n"; + } + break; + case QXmppLogger::StdoutLogging: + std::cout << typeName(type) << " " << qPrintable(text) << std::endl; + break; + case QXmppLogger::SignalLogging: + emit message(type, text); + break; + default: + break; + } +} + +/// Returns the path to which logging messages should be written. +/// +/// \sa loggingType() + +QString QXmppLogger::logFilePath() +{ + return m_logFilePath; +} + +/// Sets the path to which logging messages should be written. +/// +/// \param path +/// +/// \sa setLoggingType() + +void QXmppLogger::setLogFilePath(const QString &path) +{ + m_logFilePath = path; +} + |
