kde-playground/kdepim/ktimetracker/plannerparser.h
2015-04-14 21:49:29 +00:00

73 lines
2.5 KiB
C++

/*
* Copyright (C) 2004 by Thorsten Staerk <dev@staerk.de>
* 2007 the ktimetracker developers
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA.
*
*/
#ifndef PLANNERPARSER_H
#define PLANNERPARSER_H
/**
this class is here to import tasks from a planner project file to ktimetracker.
the import shall not be limited to ktimetracker (kPlaTo sends greetings)
it imports planner's top-level-tasks on the same level-depth as currentItem.
if there is no currentItem, planner's top-level-tasks will become top-level-tasks in ktimetracker.
it imports as well the level-depth of each task, as its name, as its percent-complete.
test cases:
- deleting all tasks away, then import!
- having started with an empty ics, import!
- with currentItem being a top-level-task, import!
- with currentItem being a subtask, import!
@author Thorsten Staerk
*/
#include <QtXml/QtXml>
#include "timetrackerstorage.h"
class Task;
class TaskView;
class PlannerParser : public QXmlDefaultHandler
{
public:
/** Stores the active TaskView in this parser. Returns error code (not always, hopefully) */
explicit PlannerParser(TaskView * tv);
/** given by the framework from qxml. Called when parsing the xml-document starts. */
bool startDocument();
/** given by the framework from qxml. Called when the reader occurs an open tag (e.g. \<b\> ) */
bool startElement( const QString&, const QString&, const QString& qName, const QXmlAttributes& att );
/** given by the framework from qxml. Called when the reader occurs a closed tag (e.g. \</b\> )*/
bool endElement( const QString&, const QString&, const QString& qName);
private:
bool withInTasks; // within <tasks> ?
TaskView *_taskView;
Task *task;
Task *parentTask;
int level; // level=1: task is top-level-task
};
#endif