• 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
recursiveitemfetchjob.cpp
1 /*
2  Copyright (c) 2009 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 "recursiveitemfetchjob.h"
21 
22 #include <akonadi/collectionfetchjob.h>
23 #include <akonadi/collectionfetchscope.h>
24 #include <akonadi/itemfetchjob.h>
25 #include <akonadi/itemfetchscope.h>
26 
27 #include <QtCore/QStringList>
28 #include <QtCore/QVariant>
29 
30 using namespace Akonadi;
31 
32 class RecursiveItemFetchJob::Private
33 {
34  public:
35  Private( const Collection &collection, const QStringList &mimeTypes, RecursiveItemFetchJob *parent )
36  : mParent( parent ), mCollection( collection ), mMimeTypes( mimeTypes ), mFetchCount( 0 )
37  {
38  }
39 
40  void collectionFetchResult( KJob *job )
41  {
42  if ( job->error() ) {
43  mParent->emitResult();
44  return;
45  }
46 
47  const CollectionFetchJob *fetchJob = qobject_cast<CollectionFetchJob*>( job );
48 
49  Collection::List collections = fetchJob->collections();
50  collections.prepend( mCollection );
51 
52  foreach ( const Collection &collection, collections ) {
53  ItemFetchJob *itemFetchJob = new ItemFetchJob( collection, mParent );
54  itemFetchJob->setFetchScope( mFetchScope );
55  mParent->connect( itemFetchJob, SIGNAL(result(KJob*)),
56  mParent, SLOT(itemFetchResult(KJob*)) );
57 
58  mFetchCount++;
59  }
60  }
61 
62  void itemFetchResult( KJob *job )
63  {
64  if ( !job->error() ) {
65  const ItemFetchJob *fetchJob = qobject_cast<ItemFetchJob*>( job );
66 
67  if ( !mMimeTypes.isEmpty() ) {
68  foreach ( const Item &item, fetchJob->items() ) {
69  if ( mMimeTypes.contains( item.mimeType() ) )
70  mItems << item;
71  }
72  } else {
73  mItems << fetchJob->items();
74  }
75  }
76 
77  mFetchCount--;
78 
79  if ( mFetchCount == 0 )
80  mParent->emitResult();
81  }
82 
83  RecursiveItemFetchJob *mParent;
84  Collection mCollection;
85  Item::List mItems;
86  ItemFetchScope mFetchScope;
87  QStringList mMimeTypes;
88 
89  int mFetchCount;
90 };
91 
92 RecursiveItemFetchJob::RecursiveItemFetchJob( const Collection &collection,
93  const QStringList &mimeTypes,
94  QObject * parent )
95  : KJob( parent ), d( new Private( collection, mimeTypes, this ) )
96 {
97 }
98 
99 RecursiveItemFetchJob::~RecursiveItemFetchJob()
100 {
101  delete d;
102 }
103 
104 void RecursiveItemFetchJob::setFetchScope( const ItemFetchScope &fetchScope )
105 {
106  d->mFetchScope = fetchScope;
107 }
108 
109 ItemFetchScope &RecursiveItemFetchJob::fetchScope()
110 {
111  return d->mFetchScope;
112 }
113 
114 void RecursiveItemFetchJob::start()
115 {
116  CollectionFetchJob *job = new CollectionFetchJob( d->mCollection, CollectionFetchJob::Recursive, this );
117 
118  if ( !d->mMimeTypes.isEmpty() )
119  job->fetchScope().setContentMimeTypes( d->mMimeTypes );
120 
121  connect( job, SIGNAL(result(KJob*)), this, SLOT(collectionFetchResult(KJob*)) );
122 }
123 
124 Akonadi::Item::List RecursiveItemFetchJob::items() const
125 {
126  return d->mItems;
127 }
128 
129 #include "moc_recursiveitemfetchjob.cpp"
Akonadi::RecursiveItemFetchJob::start
virtual void start()
Starts the recursive item fetch job.
Definition: recursiveitemfetchjob.cpp:114
Akonadi::CollectionFetchJob::collections
Collection::List collections() const
Returns the list of fetched collection.
Definition: collectionfetchjob.cpp:175
Akonadi::CollectionFetchJob::fetchScope
CollectionFetchScope & fetchScope()
Returns the collection fetch scope.
Definition: collectionfetchjob.cpp:437
Akonadi::Collection
Represents a collection of PIM items.
Definition: collection.h:75
Akonadi::CollectionFetchJob
Job that fetches collections from the Akonadi storage.
Definition: collectionfetchjob.h:53
Akonadi::RecursiveItemFetchJob::setFetchScope
void setFetchScope(const Akonadi::ItemFetchScope &fetchScope)
Sets the item fetch scope.
Definition: recursiveitemfetchjob.cpp:104
Akonadi::ItemFetchJob::items
Item::List items() const
Returns the fetched items.
Definition: itemfetchjob.cpp:228
Akonadi::ItemFetchJob::setFetchScope
void setFetchScope(ItemFetchScope &fetchScope)
Sets the item fetch scope.
Definition: itemfetchjob.cpp:242
Akonadi::CollectionFetchScope::setContentMimeTypes
void setContentMimeTypes(const QStringList &mimeTypes)
Sets a content mimetypes filter, that is only collections that contain at least one of the given mime...
Definition: collectionfetchscope.cpp:124
Akonadi::RecursiveItemFetchJob::fetchScope
Akonadi::ItemFetchScope & fetchScope()
Returns the item fetch scope.
Definition: recursiveitemfetchjob.cpp:109
Akonadi::ItemFetchScope
Specifies which parts of an item should be fetched from the Akonadi storage.
Definition: itemfetchscope.h:68
Akonadi::ItemFetchJob
Job that fetches items from the Akonadi storage.
Definition: itemfetchjob.h:82
Akonadi::RecursiveItemFetchJob
Job that fetches all items of a collection recursive.
Definition: recursiveitemfetchjob.h:84
Akonadi::RecursiveItemFetchJob::~RecursiveItemFetchJob
~RecursiveItemFetchJob()
Destroys the recursive item fetch job.
Definition: recursiveitemfetchjob.cpp:99
Akonadi::RecursiveItemFetchJob::RecursiveItemFetchJob
RecursiveItemFetchJob(const Akonadi::Collection &collection, const QStringList &mimeTypes, QObject *parent=0)
Creates a new recursive item fetch job.
Definition: recursiveitemfetchjob.cpp:92
Akonadi::CollectionFetchJob::Recursive
List all sub-collections.
Definition: collectionfetchjob.h:64
Akonadi::Collection::List
QList< Collection > List
Describes a list of collections.
Definition: collection.h:81
Akonadi::RecursiveItemFetchJob::items
Akonadi::Item::List items() const
Returns the list of fetched items.
Definition: recursiveitemfetchjob.cpp:124
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