summaryrefslogtreecommitdiffstats
path: root/konsolekalendar/konsolekalendar.h
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch)
tree67208f7c145782a7e90b123b982ca78d88cc2c87 /konsolekalendar/konsolekalendar.h
downloadtdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.tar.gz
tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.zip
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'konsolekalendar/konsolekalendar.h')
-rw-r--r--konsolekalendar/konsolekalendar.h144
1 files changed, 144 insertions, 0 deletions
diff --git a/konsolekalendar/konsolekalendar.h b/konsolekalendar/konsolekalendar.h
new file mode 100644
index 00000000..f41ed4cc
--- /dev/null
+++ b/konsolekalendar/konsolekalendar.h
@@ -0,0 +1,144 @@
+/*******************************************************************************
+ * konsolekalendar.h *
+ * *
+ * KonsoleKalendar is a command line interface to KDE calendars *
+ * Copyright (C) 2002-2004 Tuukka Pasanen <illuusio@mailcity.com> *
+ * Copyright (C) 2003-2005 Allen Winter <winter@kde.org> *
+ * *
+ * 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. *
+ * *
+ * As a special exception, permission is given to link this program *
+ * with any edition of Qt, and distribute the resulting executable, *
+ * without including the source code for Qt in the source distribution. *
+ * *
+ ******************************************************************************/
+
+#ifndef _KONSOLEKALENDAR_H
+#define _KONSOLEKALENDAR_H
+
+#include <qdatetime.h>
+
+#include <kapplication.h>
+
+#include <libkcal/calendarlocal.h>
+#include <libkcal/resourcecalendar.h>
+#include <libkcal/event.h>
+
+#include "konsolekalendarvariables.h"
+
+/**
+ * @file konsolekalendar.h
+ * Provides the KonsoleKalendar class definition.
+ */
+
+namespace KCal
+{
+/**
+ * The base class of the project.
+ * @author Tuukka Pasanen
+ */
+ class KonsoleKalendar
+ {
+ public:
+ /**
+ * Constructs a KonsoleKalendar object from command line arguments.
+ */
+ KonsoleKalendar( KonsoleKalendarVariables *variables );
+ /**
+ * Destructor
+ */
+ ~KonsoleKalendar();
+
+ /**
+ * Visualize what we need.
+ */
+ bool showInstance();
+
+ /**
+ * Imports calendar file
+ */
+ bool importCalendar();
+
+ /**
+ * Add event to calendar
+ */
+ bool addEvent();
+
+ /**
+ * Change event
+ */
+ bool changeEvent();
+
+ /**
+ * Delete event
+ */
+ bool deleteEvent();
+
+ /**
+ * Detect if event already exists
+ *
+ * @param startdate Starting date
+ * @param enddate Ending date
+ * @param summary Which summary event should have have
+ */
+ bool isEvent( QDateTime startdate, QDateTime enddate, QString summary );
+
+ /**
+ * Creates calendar file (If it doesn't exists)
+ */
+ bool createCalendar();
+
+ private:
+
+ /**
+ * Print event specs for dryrun and verbose options
+ */
+ void printSpecs();
+
+ /**
+ * Prints event list in many formats
+ *
+ * @param eventlist which event we should print
+ * @param dt is the date to use when printing the event for recurring events
+ */
+ bool printEventList( QTextStream *ts, Event::List *eventList, QDate dt );
+
+ /**
+ * Prints a single event in many formats
+ *
+ * @param event which we should print
+ * @param dt is the date to use when printing the event for recurring events
+ */
+ bool printEvent( QTextStream *ts, Event *event, QDate dt );
+
+ /**
+ * Variables that changes stuff in programm
+ */
+ KonsoleKalendarVariables *m_variables;
+
+ /**
+ * Calendar file itself
+ */
+ ResourceCalendar *m_Calendar;
+
+ /**
+ * This is usefull if we like to have same day events to same system
+ */
+ QDate m_saveDate;
+
+ };
+
+}
+#endif