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

akonadi

  • 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
28class KJob;
29
30namespace Akonadi {
31
32class Session;
33
39class ConflictHandler : public QObject
40{
41 Q_OBJECT
42
43public:
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
80public Q_SLOTS:
84 void start();
85
86Q_SIGNALS:
91 void conflictResolved();
92
99 void error( const QString &message );
100
101private Q_SLOTS:
102 void slotOtherItemFetched( KJob * );
103 void slotUseLocalItemFinished( KJob * );
104 void slotUseBothItemsFinished( KJob * );
105 void resolve();
106
107private:
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
A class to handle conflicts in Akonadi.
Definition: conflicthandler_p.h:40
Akonadi::ConflictHandler::start
void start()
Starts the conflict handling.
Definition: conflicthandler.cpp:47
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::error
void error(const QString &message)
This signal is emitted whenever an error occurred during the conflict handling.
Akonadi::ConflictHandler::conflictResolved
void conflictResolved()
This signal is emitted whenever the conflict has been resolved automatically or by the user.
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
@ BackendConflict
Changes of a resource and the backend data conflict.
Definition: conflicthandler_p.h:51
Akonadi::ConflictHandler::LocalLocalConflict
@ LocalLocalConflict
Changes of two Akonadi client applications conflict.
Definition: conflicthandler_p.h:49
Akonadi::ConflictHandler::LocalRemoteConflict
@ 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::UseOtherItem
@ UseOtherItem
The local item is dropped and the other item from the Akonadi storage is used.
Definition: conflicthandler_p.h:59
Akonadi::ConflictHandler::UseBothItems
@ UseBothItems
Both items are kept in the Akonadi storage.
Definition: conflicthandler_p.h:60
Akonadi::ConflictHandler::UseLocalItem
@ UseLocalItem
The local item overwrites the other item inside the Akonadi storage.
Definition: conflicthandler_p.h:58
Akonadi::Session
A communication session with the Akonadi storage.
Definition: session.h:60
Akonadi
FreeBusyManager::Singleton.
Definition: actionstatemanager_p.h:28
This file is part of the KDE documentation.
Documentation copyright © 1996-2022 The KDE developers.
Generated on Thu Jul 21 2022 00:00:00 by doxygen 1.9.5 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-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