mirror of
https://bitbucket.org/smil3y/kde-playground.git
synced 2025-02-23 18:32:51 +00:00
172 lines
4.3 KiB
C++
172 lines
4.3 KiB
C++
/*
|
|
This file is part of the kcal library.
|
|
|
|
Copyright (c) 1998 Preston Brown <pbrown@kde.org>
|
|
Copyright (c) 2001-2003 Cornelius Schumacher <schumacher@kde.org>
|
|
|
|
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; either
|
|
version 2 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
|
|
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.
|
|
*/
|
|
/**
|
|
@file
|
|
This file is part of the API for handling calendar data and
|
|
defines the VCalFormat base class.
|
|
|
|
This class implements the vCalendar format. It provides methods for
|
|
loading/saving/converting vCalendar format data into the internal
|
|
representation as Calendar and Incidences.
|
|
|
|
@brief
|
|
vCalendar format implementation.
|
|
|
|
@author Preston Brown \<pbrown@kde.org\>
|
|
@author Cornelius Schumacher \<schumacher@kde.org\>
|
|
*/
|
|
|
|
#ifndef KCAL_VCALFORMAT_H
|
|
#define KCAL_VCALFORMAT_H
|
|
|
|
#include "calformat.h"
|
|
#include "todo.h"
|
|
#include "event.h"
|
|
#include "kcal_export.h"
|
|
|
|
#include <kdatetime.h>
|
|
|
|
#include <QtCore/QByteArray>
|
|
|
|
#define _VCAL_VERSION "1.0"
|
|
|
|
struct VObject;
|
|
|
|
namespace KCal {
|
|
|
|
class KCAL_DEPRECATED_EXPORT VCalFormat : public CalFormat
|
|
{
|
|
public:
|
|
VCalFormat();
|
|
virtual ~VCalFormat();
|
|
|
|
/**
|
|
@copydoc
|
|
CalFormat::load()
|
|
*/
|
|
bool load( Calendar *calendar, const QString &fileName );
|
|
|
|
/**
|
|
@copydoc
|
|
CalFormat::save()
|
|
*/
|
|
bool save( Calendar *calendar, const QString &fileName );
|
|
|
|
/**
|
|
@copydoc
|
|
CalFormat::fromString()
|
|
*/
|
|
bool fromString( Calendar *calendar, const QString &string );
|
|
|
|
/**
|
|
@copydoc
|
|
CalFormat::toString()
|
|
*/
|
|
QString toString( Calendar *calendar );
|
|
|
|
/**
|
|
@copydoc
|
|
CalFormat::fromRawString()
|
|
*/
|
|
bool fromRawString( Calendar *calendar, const QByteArray &string );
|
|
|
|
protected:
|
|
/**
|
|
Translates a VObject of the TODO type into an Event.
|
|
*/
|
|
Todo *VTodoToEvent( VObject *vtodo );
|
|
|
|
/**
|
|
Translates a VObject into a Event and returns a pointer to it.
|
|
*/
|
|
Event *VEventToEvent( VObject *vevent );
|
|
|
|
/**
|
|
Translates an Event into a VTodo-type VObject and return pointer.
|
|
*/
|
|
VObject *eventToVTodo( const Todo *anEvent );
|
|
|
|
/**
|
|
Translates an Event into a VObject and returns a pointer to it.
|
|
*/
|
|
VObject *eventToVEvent( const Event *anEvent );
|
|
|
|
/**
|
|
Takes a QDate and returns a string in the format YYYYMMDDTHHMMSS.
|
|
*/
|
|
QString qDateToISO( const QDate &date );
|
|
|
|
/**
|
|
Takes a QDateTime and returns a string in format YYYYMMDDTHHMMSS.
|
|
*/
|
|
QString kDateTimeToISO( const KDateTime &date, bool zulu=true );
|
|
|
|
/**
|
|
Takes a string in YYYYMMDDTHHMMSS format and returns a valid QDateTime.
|
|
*/
|
|
KDateTime ISOToKDateTime( const QString &dtStr );
|
|
|
|
/**
|
|
Takes a string in the YYYYMMDD format and returns a valid QDate.
|
|
*/
|
|
QDate ISOToQDate( const QString &dtStr );
|
|
|
|
/**
|
|
Takes a vCalendar tree of VObjects, and puts all of them that have the
|
|
"event" property into the dictionary, todos in the todo-list, etc.
|
|
*/
|
|
void populate( VObject *vcal );
|
|
|
|
/**
|
|
Takes a number 0 - 6 and returns the two letter string of that day,
|
|
i.e. MO, TU, WE, etc.
|
|
|
|
@param day number of the day to get a two letter name for. Range @c 0 - @c 6
|
|
*/
|
|
const char *dayFromNum( int day );
|
|
|
|
/** the reverse of the above function. */
|
|
int numFromDay( const QString &day );
|
|
|
|
Attendee::PartStat readStatus( const char *s ) const;
|
|
QByteArray writeStatus( Attendee::PartStat status ) const;
|
|
|
|
private:
|
|
/**
|
|
The Pilot synchronization states.
|
|
*/
|
|
enum PilotState {
|
|
SYNCNONE = 0,
|
|
SYNCMOD = 1,
|
|
SYNCDEL = 3
|
|
};
|
|
|
|
//@cond PRIVATE
|
|
Q_DISABLE_COPY( VCalFormat )
|
|
class Private;
|
|
Private *const d;
|
|
//@endcond
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|