• 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
  • conflicthandling
conflicthandler_p.h
1 /*
2  Copyright (c) 2010 KDAB
3  Author: Tobias Koenig <tokoe@kde.org>
4 
5  This library is free software; you can redistribute it and/or modify it
6  under the terms of the GNU Library General Public License as published by
7  the Free Software Foundation; either version 2 of the License, or (at your
8  option) any later version.
9 
10  This library is distributed in the hope that it will be useful, but WITHOUT
11  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
13  License for more details.
14 
15  You should have received a copy of the GNU Library General Public License
16  along with this library; see the file COPYING.LIB. If not, write to the
17  Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18  02110-1301, USA.
19 */
20 
21 #ifndef AKONADI_CONFLICTHANDLER_P_H
22 #define AKONADI_CONFLICTHANDLER_P_H
23 
24 #include <QtCore/QObject>
25 
26 #include <akonadi/item.h>
27 
28 class KJob;
29 
30 namespace Akonadi {
31 
32 class Session;
33 
39 class ConflictHandler : public QObject
40 {
41  Q_OBJECT
42 
43  public:
48  enum ConflictType {
49  LocalLocalConflict,
50  LocalRemoteConflict,
51  BackendConflict
52  };
53 
57  enum ResolveStrategy {
58  UseLocalItem,
59  UseOtherItem,
60  UseBothItems
61  };
62 
69  explicit ConflictHandler( ConflictType type, QObject *parent = 0 );
70 
78  void setConflictingItems( const Akonadi::Item &changedItem, const Akonadi::Item &conflictingItem );
79 
80  public Q_SLOTS:
84  void start();
85 
86  Q_SIGNALS:
91  void conflictResolved();
92 
99  void error( const QString &message );
100 
101  private Q_SLOTS:
102  void slotOtherItemFetched( KJob* );
103  void slotUseLocalItemFinished( KJob* );
104  void slotUseBothItemsFinished( KJob* );
105  void resolve();
106 
107  private:
108  void useLocalItem();
109  void useOtherItem();
110  void useBothItems();
111 
112  ConflictType mConflictType;
113  Akonadi::Item mChangedItem;
114  Akonadi::Item mConflictingItem;
115 
116  Session *mSession;
117 };
118 
119 }
120 
121 #endif
Akonadi::ConflictHandler::ConflictHandler
ConflictHandler(ConflictType type, QObject *parent=0)
Creates a new conflict handler.
Definition: conflicthandler.cpp:34
Akonadi::ConflictHandler::UseLocalItem
The local item overwrites the other item inside the Akonadi storage.
Definition: conflicthandler_p.h:58
Akonadi::ConflictHandler::UseBothItems
Both items are kept in the Akonadi storage.
Definition: conflicthandler_p.h:60
Akonadi::ConflictHandler::error
void error(const QString &message)
This signal is emitted whenever an error occurred during the conflict handling.
Akonadi::ConflictHandler::setConflictingItems
void setConflictingItems(const Akonadi::Item &changedItem, const Akonadi::Item &conflictingItem)
Sets the items that causes the conflict.
Definition: conflicthandler.cpp:41
Akonadi::ConflictHandler::LocalLocalConflict
Changes of two Akonadi client applications conflict.
Definition: conflicthandler_p.h:49
Akonadi::ConflictHandler::conflictResolved
void conflictResolved()
This signal is emitted whenever the conflict has been resolved automatically or by the user...
Akonadi::Session
A communication session with the Akonadi storage.
Definition: session.h:59
Akonadi::ConflictHandler::UseOtherItem
The local item is dropped and the other item from the Akonadi storage is used.
Definition: conflicthandler_p.h:59
Akonadi::ConflictHandler
A class to handle conflicts in Akonadi.
Definition: conflicthandler_p.h:39
Akonadi::ConflictHandler::LocalRemoteConflict
Changes of an Akonadi client application and a resource conflict.
Definition: conflicthandler_p.h:50
Akonadi::ConflictHandler::ResolveStrategy
ResolveStrategy
Describes the strategy that should be used for resolving the conflict.
Definition: conflicthandler_p.h:57
Akonadi::ConflictHandler::ConflictType
ConflictType
Describes the type of conflict that should be resolved by the conflict handler.
Definition: conflicthandler_p.h:48
Akonadi::ConflictHandler::BackendConflict
Changes of a resource and the backend data conflict.
Definition: conflicthandler_p.h:51
Akonadi::ConflictHandler::start
void start()
Starts the conflict handling.
Definition: conflicthandler.cpp:47
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 23:00:26 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