• Skip to content
  • Skip to link menu
  • KDE API Reference
  • kdepimlibs-4.14.10 API Reference
  • KDE Home
  • Contact Us
 

akonadi

  • akonadi
linkjobimpl_p.h
1/*
2 Copyright (c) 2008,2009 Volker Krause <vkrause@kde.org>
3
4 This library is free software; you can redistribute it and/or modify it
5 under the terms of the GNU Library General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or (at your
7 option) any later version.
8
9 This library is distributed in the hope that it will be useful, but WITHOUT
10 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
12 License for more details.
13
14 You should have received a copy of the GNU Library General Public License
15 along with this library; see the file COPYING.LIB. If not, write to the
16 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17 02110-1301, USA.
18*/
19
20#ifndef AKONADI_LINKJOBIMPL_P_H
21#define AKONADI_LINKJOBIMPL_P_H
22
23#include "collection.h"
24#include "item.h"
25#include "job.h"
26#include "job_p.h"
27#include "protocolhelper_p.h"
28
29#include <kdebug.h>
30#include <KLocalizedString>
31
32namespace Akonadi {
33
35template <typename LinkJob> class LinkJobImpl : public JobPrivate
36{
37public:
38 LinkJobImpl(Job *parent)
39 : JobPrivate(parent)
40 {
41 }
42
43 inline void sendCommand(const char *asapCommand)
44 {
45 LinkJob *q = static_cast<LinkJob *>(q_func()); // Job would be enough already, but then we don't have access to the non-public stuff...
46 if (objectsToLink.isEmpty()) {
47 q->emitResult();
48 return;
49 }
50 if (!destination.isValid() && destination.remoteId().isEmpty()) {
51 q->setError(Job::Unknown);
52 q->setErrorText(i18n("No valid destination specified"));
53 q->emitResult();
54 return;
55 }
56
57 QByteArray command = newTag();
58 try {
59 command += ProtocolHelper::entitySetToByteArray(Collection::List() << destination, asapCommand);
60 } catch (const std::exception &e) {
61 q->setError(Job::Unknown);
62 q->setErrorText(QString::fromUtf8(e.what()));
63 q->emitResult();
64 return;
65 }
66
67 try {
68 command += ProtocolHelper::entitySetToByteArray(objectsToLink, QByteArray());
69 } catch (const std::exception &e) {
70 q->setError(Job::Unknown);
71 q->setErrorText(QString::fromUtf8(e.what()));
72 q->emitResult();
73 return;
74 }
75 command += '\n';
76
77 writeData(command);
78 }
79
80 Item::List objectsToLink;
81 Collection destination;
82};
83
84}
85
86#endif
Akonadi::Collection
Represents a collection of PIM items.
Definition collection.h:76
Akonadi::Collection::List
QList< Collection > List
Describes a list of collections.
Definition collection.h:81
Akonadi::Entity::remoteId
QString remoteId() const
Returns the remote id of the entity.
Definition entity.cpp:82
Akonadi::Entity::isValid
bool isValid() const
Returns whether the entity is valid.
Definition entity.cpp:97
Akonadi::JobPrivate
Definition job_p.h:32
Akonadi::JobPrivate::writeData
void writeData(const QByteArray &data)
Sends raw data to the backend.
Akonadi::JobPrivate::newTag
QByteArray newTag()
Returns a new unique command tag for communication with the backend.
Akonadi::Job
Base class for all actions in the Akonadi storage.
Definition job.h:87
Akonadi::Job::Unknown
@ Unknown
Unknown error.
Definition job.h:108
Akonadi::LinkJobImpl
Shared implementation details between item and collection move jobs.
Definition linkjobimpl_p.h:36
Akonadi::LinkJob
Job that links items inside the Akonadi storage.
Definition linkjob.h:65
Akonadi::ProtocolHelper::entitySetToByteArray
static QByteArray entitySetToByteArray(const QList< T > &_objects, const QByteArray &command)
Converts the given set of items into a protocol representation.
Definition protocolhelper_p.h:125
Akonadi
FreeBusyManager::Singleton.
Definition actionstatemanager_p.h:28
This file is part of the KDE documentation.
Documentation copyright © 1996-2024 The KDE developers.
Generated on Wed Jan 24 2024 00:00:00 by doxygen 1.10.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

akonadi

Skip menu "akonadi"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • Related Pages

kdepimlibs-4.14.10 API Reference

Skip menu "kdepimlibs-4.14.10 API Reference"
  • akonadi
  •   contact
  •   kmime
  •   socialutils
  • kabc
  • kalarmcal
  • kblog
  • kcal
  • kcalcore
  • kcalutils
  • kholidays
  • kimap
  • kioslave
  •   imap4
  •   mbox
  •   nntp
  • kldap
  • kmbox
  • kmime
  • kontactinterface
  • kpimidentities
  • kpimtextedit
  • kpimutils
  • kresources
  • ktnef
  • kxmlrpcclient
  • mailtransport
  • microblog
  • qgpgme
  • syndication
  •   atom
  •   rdf
  •   rss2
Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal