• 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
itemmonitor.cpp
1 /*
2  Copyright (c) 2007-2008 Tobias Koenig <tokoe@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 #include "itemmonitor.h"
21 #include "itemmonitor_p.h"
22 
23 #include "itemfetchscope.h"
24 
25 #include <QtCore/QStringList>
26 
27 using namespace Akonadi;
28 
29 ItemMonitor::ItemMonitor()
30  : d( new Private( this ) )
31 {
32 }
33 
34 ItemMonitor::~ItemMonitor()
35 {
36  delete d;
37 }
38 
39 void ItemMonitor::setItem( const Item &item )
40 {
41  if ( item == d->mItem )
42  return;
43 
44  d->mMonitor->setItemMonitored( d->mItem, false );
45 
46  d->mItem = item;
47 
48  d->mMonitor->setItemMonitored( d->mItem, true );
49 
50  if ( !d->mItem.isValid() ) {
51  itemRemoved();
52  return;
53  }
54 
55  // start initial fetch of the new item
56  ItemFetchJob* job = new ItemFetchJob( d->mItem );
57  job->setFetchScope( fetchScope() );
58 
59  d->connect( job, SIGNAL(result(KJob*)), d, SLOT(initialFetchDone(KJob*)) );
60 }
61 
62 Item ItemMonitor::item() const
63 {
64  return d->mItem;
65 }
66 
67 void ItemMonitor::itemChanged( const Item& )
68 {
69 }
70 
71 void ItemMonitor::itemRemoved()
72 {
73 }
74 
75 void ItemMonitor::setFetchScope( const ItemFetchScope &fetchScope )
76 {
77  d->mMonitor->setItemFetchScope( fetchScope );
78 }
79 
80 ItemFetchScope &ItemMonitor::fetchScope()
81 {
82  return d->mMonitor->itemFetchScope();
83 }
84 
85 #include "moc_itemmonitor_p.cpp"
Akonadi::ItemMonitor::Private
Definition: itemmonitor_p.h:33
Akonadi::ItemMonitor::fetchScope
ItemFetchScope & fetchScope()
Returns the item fetch scope.
Definition: itemmonitor.cpp:80
Akonadi::ItemMonitor::itemRemoved
virtual void itemRemoved()
This method is called whenever the monitored item has been removed.
Definition: itemmonitor.cpp:71
Akonadi::ItemMonitor::~ItemMonitor
virtual ~ItemMonitor()
Destroys the item monitor.
Definition: itemmonitor.cpp:34
Akonadi::ItemMonitor::setFetchScope
void setFetchScope(const ItemFetchScope &fetchScope)
Sets the item fetch scope.
Definition: itemmonitor.cpp:75
Akonadi::ItemFetchJob::setFetchScope
void setFetchScope(ItemFetchScope &fetchScope)
Sets the item fetch scope.
Definition: itemfetchjob.cpp:242
Akonadi::ItemMonitor::item
Item item() const
Returns the currently monitored item.
Definition: itemmonitor.cpp:62
Akonadi::ItemFetchScope
Specifies which parts of an item should be fetched from the Akonadi storage.
Definition: itemfetchscope.h:68
Akonadi::ItemMonitor::ItemMonitor
ItemMonitor()
Creates a new item monitor.
Definition: itemmonitor.cpp:29
Akonadi::ItemMonitor::setItem
void setItem(const Item &item)
Sets the item that shall be monitored.
Definition: itemmonitor.cpp:39
Akonadi::ItemFetchJob
Job that fetches items from the Akonadi storage.
Definition: itemfetchjob.h:82
Akonadi::ItemMonitor::itemChanged
virtual void itemChanged(const Item &item)
This method is called whenever the monitored item has changed.
Definition: itemmonitor.cpp:67
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