|
|
|
/*
|
|
|
|
This file is part of libkabc.
|
|
|
|
Copyright (c) 2002 Tobias Koenig <tokoe@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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef KABC_VCARDCONVERTER_H
|
|
|
|
#define KABC_VCARDCONVERTER_H
|
|
|
|
|
|
|
|
#include <tqstring.h>
|
|
|
|
|
|
|
|
#include "addressee.h"
|
|
|
|
|
|
|
|
namespace KABC {
|
|
|
|
|
|
|
|
/**
|
|
|
|
@short Class to converting contact objects into vCard format and vice versa.
|
|
|
|
|
|
|
|
This class implements reading and writing of contact using from/to the
|
|
|
|
vCard format. Currently vCard version 2.1 and 3.0 is supported.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
\code
|
|
|
|
|
|
|
|
TQFile file( "myfile.vcf" );
|
|
|
|
file.open( IO_ReadOnly );
|
|
|
|
|
|
|
|
TQString data = file.readAll();
|
|
|
|
|
|
|
|
VCardConverter converter;
|
|
|
|
Addressee::List list = converter.parseVCards( data );
|
|
|
|
|
|
|
|
// print formatted name of first contact
|
|
|
|
tqDebug( "name=%s", list[ 0 ].formattedName().latin1() );
|
|
|
|
|
|
|
|
\endcode
|
|
|
|
*/
|
|
|
|
class KABC_EXPORT VCardConverter
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
@li v2_1 - VCard format version 2.1
|
|
|
|
@li v3_0 - VCard format version 3.0
|
|
|
|
*/
|
|
|
|
enum Version
|
|
|
|
{
|
|
|
|
v2_1,
|
|
|
|
v3_0
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
Constructor.
|
|
|
|
*/
|
|
|
|
VCardConverter();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~VCardConverter();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates a string in vCard format which contains the given
|
|
|
|
contact.
|
|
|
|
|
|
|
|
@param addr The contact object
|
|
|
|
@param version The version of the generated vCard format
|
|
|
|
*/
|
|
|
|
TQString createVCard( const Addressee &addr, Version version = v3_0 );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates a string in vCard format which contains the given
|
|
|
|
list of contact.
|
|
|
|
|
|
|
|
@param list The list of contact objects
|
|
|
|
@param version The version of the generated vCard format
|
|
|
|
*/
|
|
|
|
// FIXME: Add error handling
|
|
|
|
TQString createVCards( Addressee::List list, Version version = v3_0 );
|
|
|
|
|
|
|
|
// FIXME: Add "createVCards( AddressBook * )"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parses a string in vCard format and returns the first contact.
|
|
|
|
*/
|
|
|
|
Addressee parseVCard( const TQString& vcard );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parses a string in vCard format and returns a list of contact objects.
|
|
|
|
*/
|
|
|
|
// FIXME: Add error handling
|
|
|
|
Addressee::List parseVCards( const TQString& vcard );
|
|
|
|
|
|
|
|
// FIXME: Add "bool parseVCards( AddressBook *, const TQString &vcard )"
|
|
|
|
|
|
|
|
/**
|
|
|
|
@deprecated
|
|
|
|
*/
|
|
|
|
bool vCardToAddressee( const TQString&, Addressee &, Version version = v3_0 ) KDE_DEPRECATED;
|
|
|
|
|
|
|
|
/**
|
|
|
|
@deprecated
|
|
|
|
*/
|
|
|
|
bool addresseeToVCard( const Addressee&, TQString&, Version version = v3_0 ) KDE_DEPRECATED;
|
|
|
|
|
|
|
|
private:
|
|
|
|
/**
|
|
|
|
Split a string and replaces escaped separators on the fly with
|
|
|
|
unescaped ones.
|
|
|
|
*/
|
|
|
|
TQStringList splitString( const TQChar &sep, const TQString &value );
|
|
|
|
|
|
|
|
struct VCardConverterData;
|
|
|
|
VCardConverterData *d;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper functions
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a TQDateTime to a date string as it is used in VCard and LDIF files.
|
|
|
|
* The return value is in the form "yyyyMMddThhmmssZ" (e.g. "20031201T120000Z")
|
|
|
|
* @param dateTime date and time to be converted
|
|
|
|
* @since 3.2
|
|
|
|
*/
|
|
|
|
KABC_EXPORT TQString dateToVCardString( const TQDateTime &dateTime );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a TQDate to a short date string as it is used in VCard and LDIF files.
|
|
|
|
* The return value is in the form "yyyyMMdd" (e.g. "20031201")
|
|
|
|
* @param date date to be converted
|
|
|
|
* @since 3.2
|
|
|
|
*/
|
|
|
|
KABC_EXPORT TQString dateToVCardString( const TQDate &date );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a date string as it is used in VCard and LDIF files to a TQDateTime value.
|
|
|
|
* If the date string does not contain a time value, it will be returned as 00:00:00.
|
|
|
|
* (e.g. "20031201T120000" will return a TQDateTime for 2003-12-01 at 12:00)
|
|
|
|
* @param dateString string representing the date and time.
|
|
|
|
* @since 3.2
|
|
|
|
*/
|
|
|
|
KABC_EXPORT TQDateTime VCardStringToDate( const TQString &dateString );
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|