diff options
author | tpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-01-20 01:29:50 +0000 |
---|---|---|
committer | tpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-01-20 01:29:50 +0000 |
commit | 8362bf63dea22bbf6736609b0f49c152f975eb63 (patch) | |
tree | 0eea3928e39e50fae91d4e68b21b1e6cbae25604 /kplato/kptxmlloaderobject.h | |
download | koffice-8362bf63dea22bbf6736609b0f49c152f975eb63.tar.gz koffice-8362bf63dea22bbf6736609b0f49c152f975eb63.zip |
Added old abandoned KDE3 version of koffice
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/koffice@1077364 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kplato/kptxmlloaderobject.h')
-rw-r--r-- | kplato/kptxmlloaderobject.h | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/kplato/kptxmlloaderobject.h b/kplato/kptxmlloaderobject.h new file mode 100644 index 00000000..d049d6b0 --- /dev/null +++ b/kplato/kptxmlloaderobject.h @@ -0,0 +1,100 @@ +/* This file is part of the KDE project + Copyright (C) 2006 Dag Andersen <danders@get2net.dk> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; + version 2 of the License. + + 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 + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + Boston, MA 02110-1301, USA. +*/ + +#ifndef XMLLOADEROBJECT_H +#define XMLLOADEROBJECT_H + +#include "kptproject.h" + +#include <qdatetime.h> +#include <qstring.h> +#include <qstringlist.h> + +namespace KPlato +{ + +class XMLLoaderObject { +public: + enum Severity { None=0, Errors=1, Warnings=2, Diagnostics=3, Debug=4 }; + XMLLoaderObject() + : m_project(0), + m_errors(0), + m_warnings(0), + m_logLevel(Diagnostics), + m_log() { + } + ~XMLLoaderObject() {} + + void setProject(Project *proj) { m_project = proj; } + Project &project() const { return *m_project; } + + void startLoad() { + m_timer.start(); + m_starttime = QDateTime::currentDateTime(); + m_errors = m_warnings = 0; + m_log.clear(); + addMsg(QString("Loading started at %1").arg(m_starttime.toString())); + } + void stopLoad() { + m_elapsed = m_timer.elapsed(); + addMsg(QString("Loading finished at %1, took %2").arg(QDateTime::currentDateTime().toString()).arg(formatElapsed())); + } + QDateTime lastLoaded() const { return m_starttime; } + int elapsed() const { return m_elapsed; } + QString formatElapsed() { return QString("%1 seconds").arg((double)m_elapsed/1000); } + + void setLogLevel(Severity sev) { m_logLevel = sev; } + const QStringList &log() const { return m_log; } + void addMsg(int sev, QString msg) { + increment(sev); + if (m_logLevel < sev) return; + QString s; + if (sev == Errors) s = "ERROR"; + else if (sev == Warnings) s = "WARNING"; + else if (sev == Diagnostics) s = "Diagnostic"; + else if (sev == Debug) s = "Debug"; + else s = "Message"; + m_log<<QString("%1: %2").arg(s, 13).arg(msg); + } + void addMsg(QString msg) { m_log<<msg; } + void increment(int sev) { + if (sev == Errors) { incErrors(); return; } + if (sev == Warnings) { incWarnings(); return; } + } + void incErrors() { ++m_errors; } + int errors() const { return m_errors; } + bool error() const { return m_errors > 0; } + void incWarnings() { ++m_warnings; } + int warnings() const { return m_warnings; } + bool warning() const { return m_warnings > 0; } + +protected: + Project *m_project; + int m_errors; + int m_warnings; + int m_logLevel; + QStringList m_log; + QDateTime m_starttime; + QTime m_timer; + int m_elapsed; +}; + +} //namespace KPlato + +#endif |