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

akonadi

  • sources
  • kde-4.14
  • kdepimlibs
  • akonadi
movejobimpl_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_MOVEJOBIMPL_P_H
21 #define AKONADI_MOVEJOBIMPL_P_H
22 
23 #include "collection.h"
24 #include "job.h"
25 #include "job_p.h"
26 #include "protocolhelper_p.h"
27 
28 #include <KLocalizedString>
29 
30 namespace Akonadi {
31 
33 template <typename T, typename MoveJob> class MoveJobImpl : public JobPrivate
34 {
35 public:
36  MoveJobImpl(Job *parent)
37  : JobPrivate(parent)
38  {
39  }
40 
41  inline void sendCommand(const char *asapCommand)
42  {
43  MoveJob *q = static_cast<MoveJob *>(q_func()); // Job would be enough already, but then we don't have access to the non-public stuff...
44  if (objectsToMove.isEmpty()) {
45  q->setError(Job::Unknown);
46  q->setErrorText(i18n("No objects specified for moving"));
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(objectsToMove, 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  command += ' ';
67  // with all the checks done before this indicates now whether this is a UID or RID based operation
68  if (objectsToMove.first().isValid()) {
69  command += QByteArray::number(destination.id());
70  } else {
71  command += ImapParser::quote(destination.remoteId().toUtf8());
72  }
73 
74  // Source is optional
75  if (source.isValid()) {
76  command += ' ' + QByteArray::number(source.id());
77  } else if (!source.remoteId().isEmpty()) {
78  command += ' ' + ImapParser::quote(source.remoteId().toUtf8());
79  }
80  command += '\n';
81  writeData(command);
82  }
83 
84  typename T::List objectsToMove;
85  Collection destination;
86  Collection source;
87 };
88 
89 }
90 
91 #endif
QByteArray
Akonadi::Job::Unknown
Unknown error.
Definition: job.h:108
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::Collection
Represents a collection of PIM items.
Definition: collection.h:75
Akonadi::Job
Base class for all actions in the Akonadi storage.
Definition: job.h:86
QString::fromUtf8
QString fromUtf8(const char *str, int size)
Akonadi::Entity::remoteId
QString remoteId() const
Returns the remote id of the entity.
Definition: entity.cpp:82
QString::isEmpty
bool isEmpty() const
QByteArray::number
QByteArray number(int n, int base)
Akonadi::Entity::id
Id id() const
Returns the unique identifier of the entity.
Definition: entity.cpp:72
Akonadi::JobPrivate::newTag
QByteArray newTag()
Returns a new unique command tag for communication with the backend.
Akonadi::MoveJobImpl
Shared implementation details between item and collection move jobs.
Definition: movejobimpl_p.h:33
Akonadi::JobPrivate::writeData
void writeData(const QByteArray &data)
Sends raw data to the backend.
Akonadi::JobPrivate
Definition: job_p.h:31
Akonadi::Entity::isValid
bool isValid() const
Returns whether the entity is valid.
Definition: entity.cpp:97
QString::toUtf8
QByteArray toUtf8() const
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:38:03 by doxygen 1.8.7 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
  • Modules
  • Related Pages

kdepimlibs API Reference

Skip menu "kdepimlibs 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

Search



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