From fad04899470294d98233cfc27c6c18f82990c7ac Mon Sep 17 00:00:00 2001 From: Jeremy Lainé Date: Mon, 8 Mar 2010 20:08:05 +0000 Subject: rework QXmppLogger yet again --- source/QXmppLogger.cpp | 68 +++++++++++++++++++++++--------------------------- 1 file changed, 31 insertions(+), 37 deletions(-) (limited to 'source/QXmppLogger.cpp') diff --git a/source/QXmppLogger.cpp b/source/QXmppLogger.cpp index e614cb86..d943bceb 100644 --- a/source/QXmppLogger.cpp +++ b/source/QXmppLogger.cpp @@ -21,58 +21,28 @@ * */ -#include -#include -#include #include "QXmppLogger.h" +#include +#include QXmppLogger* QXmppLogger::m_logger = 0; QXmppLogger::QXmppLogger() - : m_loggingType(QXmppLogger::NONE), m_device(0) -{ -} - -QXmppLogger::~QXmppLogger() + : m_file("QXmppClientLog.log"), m_loggingType(QXmppLogger::FILE) { - delete m_device; } QXmppLogger* QXmppLogger::getLogger() { if(!m_logger) - { m_logger = new QXmppLogger(); - m_logger->setLoggingType(QXmppLogger::FILE); - } return m_logger; } void QXmppLogger::setLoggingType(QXmppLogger::LoggingType log) { - if (m_device) - { - delete m_device; - m_device = 0; - } - - QFile *file = 0; - switch(log) - { - case QXmppLogger::FILE: - file = new QFile("QXmppClientLog.log"); - file->open(QIODevice::Append); - break; - case QXmppLogger::STDOUT: - file = new QFile(); - file->open(stdout, QIODevice::WriteOnly); - break; - case QXmppLogger::NONE: - break; - } - m_device = file; m_loggingType = log; } @@ -81,11 +51,35 @@ QXmppLogger::LoggingType QXmppLogger::loggingType() return m_loggingType; } -QDebug QXmppLogger::debug() +void QXmppLogger::debug(const QString &str) +{ + log(QtDebugMsg, str); +} + +void QXmppLogger::warning(const QString &str) { - if (m_device) - return QDebug(m_device) << QTime::currentTime().toString("hh:mm:ss.zzz") << ":"; - return QDebug(m_device); + log(QtWarningMsg, str); +} + +void QXmppLogger::log(QtMsgType type, const QString& str) +{ + switch(m_loggingType) + { + case QXmppLogger::FILE: + m_file.open(QIODevice::Append); + m_stream.setDevice(&m_file); + m_stream << QTime::currentTime().toString("hh:mm:ss.zzz") << " : "<< + str << "\n\n"; + m_file.close(); + break; + case QXmppLogger::STDOUT: + std::cout<