/usr/include/akonadi/itemserializerplugin.h is in kdepimlibs5-dev 4:4.14.2-2+deb8u2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | /*
Copyright (c) 2007 Till Adam <adam@kde.org>
Copyright (c) 2007 Volker Krause <vkrause@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 AKONADI_ITEMSERIALIZERPLUGIN_H
#define AKONADI_ITEMSERIALIZERPLUGIN_H
#include <QtCore/QByteArray>
#include <QtCore/QSet>
#include "item.h"
#include "akonadi_export.h"
class QIODevice;
namespace Akonadi {
/**
* @short The base class for item type serializer plugins.
*
* Serializer plugins convert between the payload of Akonadi::Item objects and
* a textual or binary representation of the actual content data.
* This allows to easily add support for new types to Akonadi.
*
* The following example shows how to implement a serializer plugin for
* a new data type PimNote.
*
* The PimNote data structure:
* @code
* typedef struct {
* QString author;
* QDateTime dateTime;
* QString text;
* } PimNote;
* @endcode
*
* The serializer plugin code:
* @code
* #include <QtCore/qplugin.h>
*
* class SerializerPluginPimNote : public QObject, public Akonadi::ItemSerializerPlugin
* {
* Q_OBJECT
* Q_INTERFACES( Akonadi::ItemSerializerPlugin )
*
* public:
* bool deserialize( Akonadi::Item& item, const QByteArray& label, QIODevice& data, int version )
* {
* // we don't handle versions in this example
* Q_UNUSED( version );
*
* // we work only on full payload
* if ( label != Akonadi::Item::FullPayload )
* return false;
*
* QDataStream stream( &data );
*
* PimNote note;
* stream >> note.author;
* stream >> note.dateTime;
* stream >> note.text;
*
* item.setPayload<PimNote>( note );
*
* return true;
* }
*
* void serialize( const Akonadi::Item& item, const QByteArray& label, QIODevice& data, int &version )
* {
* // we don't handle versions in this example
* Q_UNUSED( version );
*
* if ( label != Akonadi::Item::FullPayload || !item.hasPayload<PimNote>() )
* return;
*
* QDataStream stream( &data );
*
* PimNote note = item.payload<PimNote>();
*
* stream << note.author;
* stream << note.dateTime;
* stream << note.text;
* }
* };
*
* Q_EXPORT_PLUGIN2( akonadi_serializer_pimnote, SerializerPluginPimNote )
*
* @endcode
*
* The desktop file:
* @code
* [Misc]
* Name=Pim Note Serializer
* Comment=An Akonadi serializer plugin for note objects
*
* [Plugin]
* Type=application/x-pimnote
* X-KDE-Library=akonadi_serializer_pimnote
* @endcode
*
* @author Till Adam <adam@kde.org>, Volker Krause <vkrause@kde.org>
*/
class AKONADI_EXPORT ItemSerializerPlugin
{
public:
/**
* Destroys the item serializer plugin.
*/
virtual ~ItemSerializerPlugin();
/**
* Converts serialized item data provided in @p data into payload for @p item.
*
* @param item The item to which the payload should be added.
* It is guaranteed to have a mime type matching one of the supported
* mime types of this plugin.
* However it might contain a unsuited payload added manually
* by the application developer.
* Verifying the payload type in case a payload is already available
* is recommended therefore.
* @param label The part identifier of the part to deserialize.
* @p label might be an unsupported item part, return @c false if this is the case.
* @param data A QIODevice providing access to the serialized data.
* The QIODevice is opened in read-only mode and positioned at the beginning.
* The QIODevice is guaranteed to be valid.
* @param version The version of the data format as set by the user in serialize() or @c 0 (default).
* @return @c false if the specified part is not supported by this plugin, @c true if the part
* could be de-serialized successfully.
*/
virtual bool deserialize(Item &item, const QByteArray &label, QIODevice &data, int version) = 0;
/**
* Convert the payload object provided in @p item into its serialzed form into @p data.
*
* @param item The item which contains the payload.
* It is guaranteed to have a mimetype matching one of the supported
* mimetypes of this plugin as well as the existence of a payload object.
* However it might contain an unsupported payload added manually by
* the application developer.
* Verifying the payload type is recommended therefore.
* @param label The part identifier of the part to serialize.
* @p label will be one of the item parts returned by parts().
* @param data The QIODevice where the serialized data should be written to.
* The QIODevice is opened in write-only mode and positioned at the beginning.
* The QIODevice is guaranteed to be valid.
* @param version The version of the data format. Can be set by the user to handle different
* versions.
*/
virtual void serialize(const Item &item, const QByteArray &label, QIODevice &data, int &version) = 0;
/**
* Returns a list of available parts for the given item payload.
* The default implementation returns Item::FullPayload if a payload is set.
*
* @param item The item.
*/
virtual QSet<QByteArray> parts(const Item &item) const;
/**
* Override the plugin-lookup with @p plugin.
*
* After calling this each lookup will always return @p plugin.
* This is useful to inject a special plugin for testing purposes.
* To reset the plugin, set to 0.
*
* @since 4.12
*/
static void overridePluginLookup(QObject *plugin);
};
/**
* @short The extended base class for item type serializer plugins.
*
* @since 4.4
*/
class AKONADI_EXPORT ItemSerializerPluginV2 : public ItemSerializerPlugin
{
public:
/**
* Destroys the item serializer plugin.
*/
virtual ~ItemSerializerPluginV2();
/**
* Merges the payload parts in @p other into @p item.
*
* The default implementation is slow as it requires serializing @p other, and deserializing @p item multiple times.
* Reimplementing this is recommended if your type uses payload parts.
* @param item receives merged parts from @p other
* @param other the paylod parts to merge into @p item
* @since 4.4
*/
virtual void apply(Item &item, const Item &other);
/**
* Returns the parts available in the item @p item.
*
* This should be reimplemented to return available parts.
*
* The default implementation returns an empty set if the item has a payload,
* and a set containing Item::FullPayload if the item has no payload.
* @param item the item for which to list payload parts
* @since 4.4
*/
virtual QSet<QByteArray> availableParts(const Item &item) const;
};
}
Q_DECLARE_INTERFACE(Akonadi::ItemSerializerPlugin, "org.freedesktop.Akonadi.ItemSerializerPlugin/1.0")
Q_DECLARE_INTERFACE(Akonadi::ItemSerializerPluginV2, "org.freedesktop.Akonadi.ItemSerializerPlugin/1.1")
#endif
|