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

akonadi

  • sources
  • kde-4.12
  • kdepimlibs
  • 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 
32 namespace Akonadi {
33 
35 template <typename LinkJob> class LinkJobImpl : public JobPrivate
36 {
37  public:
38  LinkJobImpl( Job *parent ) : JobPrivate( parent ) {}
39 
40  inline void sendCommand( const char* asapCommand )
41  {
42  LinkJob *q = static_cast<LinkJob*>( q_func() ); // Job would be enough already, but then we don't have access to the non-public stuff...
43  if ( objectsToLink.isEmpty() ) {
44  q->emitResult();
45  return;
46  }
47  if ( !destination.isValid() && destination.remoteId().isEmpty() ) {
48  q->setError( Job::Unknown );
49  q->setErrorText( i18n( "No valid destination specified" ) );
50  q->emitResult();
51  return;
52  }
53 
54  QByteArray command = newTag();
55  try {
56  command += ProtocolHelper::entitySetToByteArray( Collection::List() << destination, asapCommand );
57  } catch ( const std::exception &e ) {
58  q->setError( Job::Unknown );
59  q->setErrorText( QString::fromUtf8( e.what() ) );
60  q->emitResult();
61  return;
62  }
63 
64  try {
65  command += ProtocolHelper::entitySetToByteArray( objectsToLink, QByteArray() );
66  } catch ( const std::exception &e ) {
67  q->setError( Job::Unknown );
68  q->setErrorText( QString::fromUtf8( e.what() ) );
69  q->emitResult();
70  return;
71  }
72  command += '\n';
73 
74  writeData( command );
75  }
76 
77  Item::List objectsToLink;
78  Collection destination;
79 };
80 
81 }
82 
83 #endif
Akonadi::Job::Unknown
Unknown error.
Definition: job.h:109
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:122
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
Akonadi::LinkJob
Job that links items inside the Akonadi storage.
Definition: linkjob.h:64
Akonadi::Entity::remoteId
QString remoteId() const
Returns the remote id of the entity.
Definition: entity.cpp:82
Akonadi::JobPrivate::newTag
QByteArray newTag()
Returns a new unique command tag for communication with the backend.
Akonadi::LinkJobImpl
Shared implementation details between item and collection move jobs.
Definition: linkjobimpl_p.h:35
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
Akonadi::Collection::List
QList< Collection > List
Describes a list of collections.
Definition: collection.h:81
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 23:00:27 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
  • kldap
  • kmbox
  • kmime
  • kpimidentities
  • kpimtextedit
  • kresources
  • ktnef
  • kxmlrpcclient
  • microblog

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