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

akregator

  • sources
  • kde-4.14
  • kdepim
  • akregator
  • src
progressmanager.cpp
Go to the documentation of this file.
1 /*
2  This file is part of Akregator.
3 
4  Copyright (C) 2005 Frank Osterfeld <osterfeld@kde.org>
5 
6  This program is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2 of the License, or
9  (at your option) any later version.
10 
11  This program is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with this program; if not, write to the Free Software
18  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 
20  As a special exception, permission is given to link this program
21  with any edition of Qt, and distribute the resulting executable,
22  without including the source code for Qt in the source distribution.
23 */
24 
25 #include "progressmanager.h"
26 #include "feed.h"
27 #include "treenode.h"
28 
29 #include <QHash>
30 
31 #include <klocale.h>
32 
33 #include <libkdepim/progresswidget/progressmanager.h>
34 
35 using namespace boost;
36 
37 namespace Akregator {
38 
39 class ProgressManager::ProgressManagerPrivate
40 {
41  public:
42  ProgressManagerPrivate() : feedList() {}
43  shared_ptr<FeedList> feedList;
44  QHash<Feed*, ProgressItemHandler*> handlers;
45 
46 };
47 
48 ProgressManager* ProgressManager::m_self = 0;
49 
50 ProgressManager* ProgressManager::self()
51 {
52  static ProgressManager sself;
53  if (!m_self)
54  m_self = &sself;
55  return m_self;
56 }
57 
58 ProgressManager::ProgressManager() : d(new ProgressManagerPrivate)
59 {
60 }
61 
62 ProgressManager::~ProgressManager()
63 {
64  delete d;
65  d = 0;
66 }
67 
68 void ProgressManager::setFeedList(const shared_ptr<FeedList>& feedList)
69 {
70  if ( feedList == d->feedList )
71  return;
72 
73  if ( d->feedList )
74  {
75  qDeleteAll( d->handlers );
76  d->handlers.clear();
77  d->feedList->disconnect( this );
78  }
79 
80  d->feedList = feedList;
81 
82  if ( d->feedList )
83  {
84  QVector<Feed*> list = feedList->feeds();
85 
86  foreach( TreeNode* i, list )
87  slotNodeAdded( i );
88  connect(feedList.get(), SIGNAL(signalNodeAdded(Akregator::TreeNode*)), this, SLOT(slotNodeAdded(Akregator::TreeNode*)));
89  connect(feedList.get(), SIGNAL(signalNodeRemoved(Akregator::TreeNode*)), this, SLOT(slotNodeRemoved(Akregator::TreeNode*)));
90  }
91 }
92 
93 void ProgressManager::slotNodeAdded(TreeNode* node)
94 {
95  Feed* const feed = qobject_cast<Feed*>(node);
96  if (!feed)
97  return;
98 
99  if ( d->handlers.contains( feed ) )
100  return;
101 
102  d->handlers[feed] = new ProgressItemHandler(feed);
103  connect(feed, SIGNAL(signalDestroyed(Akregator::TreeNode*)), this, SLOT(slotNodeDestroyed(Akregator::TreeNode*)));
104 }
105 
106 void ProgressManager::slotNodeRemoved(TreeNode* node)
107 {
108  Feed* feed = qobject_cast<Feed*>(node);
109  if (feed)
110  {
111  feed->disconnect( this );
112  delete d->handlers[feed];
113  d->handlers.remove(feed);
114  }
115 }
116 
117 void ProgressManager::slotNodeDestroyed(TreeNode* node)
118 {
119  Feed* feed = qobject_cast<Feed*>(node);
120  if (feed)
121  {
122  delete d->handlers[feed];
123  d->handlers.remove(feed);
124  }
125 }
126 
127 class ProgressItemHandler::ProgressItemHandlerPrivate
128 {
129  public:
130 
131  Feed* feed;
132  KPIM::ProgressItem* progressItem;
133 };
134 
135 ProgressItemHandler::ProgressItemHandler(Feed* feed) : d(new ProgressItemHandlerPrivate)
136 {
137  d->feed = feed;
138  d->progressItem = 0;
139 
140  connect(feed, SIGNAL(fetchStarted(Akregator::Feed*)), this, SLOT(slotFetchStarted()));
141  connect(feed, SIGNAL(fetched(Akregator::Feed*)), this, SLOT(slotFetchCompleted()));
142  connect(feed, SIGNAL(fetchError(Akregator::Feed*)), this, SLOT(slotFetchError()));
143  connect(feed, SIGNAL(fetchAborted(Akregator::Feed*)), this, SLOT(slotFetchAborted()));
144 }
145 
146 ProgressItemHandler::~ProgressItemHandler()
147 {
148  if (d->progressItem)
149  {
150  d->progressItem->setComplete();
151  d->progressItem = 0;
152  }
153 
154  delete d;
155  d = 0;
156 }
157 
158 void ProgressItemHandler::slotFetchStarted()
159 {
160  if (d->progressItem)
161  {
162  d->progressItem->setComplete();
163  d->progressItem = 0;
164  }
165 
166  d->progressItem = KPIM::ProgressManager::createProgressItem(KPIM::ProgressManager::getUniqueID(), d->feed->title(), QString(), true);
167 
168  connect(d->progressItem, SIGNAL(progressItemCanceled(KPIM::ProgressItem*)), d->feed, SLOT(slotAbortFetch()));
169 }
170 
171 
172 void ProgressItemHandler::slotFetchCompleted()
173 {
174  if (d->progressItem)
175  {
176  d->progressItem->setStatus(i18n("Fetch completed"));
177  d->progressItem->setComplete();
178  d->progressItem = 0;
179  }
180 }
181 
182 void ProgressItemHandler::slotFetchError()
183 {
184  if (d->progressItem)
185  {
186  d->progressItem->setStatus(i18n("Fetch error"));
187  d->progressItem->setComplete();
188  d->progressItem = 0;
189  }
190 }
191 
192 void ProgressItemHandler::slotFetchAborted()
193 {
194  if (d->progressItem)
195  {
196  d->progressItem->setStatus(i18n("Fetch aborted"));
197  d->progressItem->setComplete();
198  d->progressItem = 0;
199  }
200 }
201 
202 } // namespace Akregator
203 
treenode.h
Akregator::ProgressItemHandler::~ProgressItemHandler
~ProgressItemHandler()
Definition: progressmanager.cpp:146
Akregator::ProgressManager::~ProgressManager
~ProgressManager()
Definition: progressmanager.cpp:62
Akregator::ProgressItemHandler::slotFetchCompleted
void slotFetchCompleted()
Definition: progressmanager.cpp:172
QObject::disconnect
bool disconnect(const QObject *sender, const char *signal, const QObject *receiver, const char *method)
feed.h
Akregator::ProgressManager::setFeedList
void setFeedList(const boost::shared_ptr< FeedList > &feedList)
sets the feed list to be managed
Definition: progressmanager.cpp:68
Akregator::ProgressItemHandler::slotFetchStarted
void slotFetchStarted()
Definition: progressmanager.cpp:158
QHash
Definition: feedlist.h:41
progressmanager.h
QString
Akregator::ProgressItemHandler::slotFetchError
void slotFetchError()
Definition: progressmanager.cpp:182
Akregator::ProgressItemHandler::ProgressItemHandler
ProgressItemHandler(Feed *feed)
Definition: progressmanager.cpp:135
QVector
Akregator::ProgressItemHandler::slotFetchAborted
void slotFetchAborted()
Definition: progressmanager.cpp:192
Akregator::Feed
represents a feed
Definition: feed.h:53
Akregator::ProgressItemHandler
this class handles the creation and deletion of progress items for one feed.
Definition: progressmanager.h:73
Akregator::ProgressManager::slotNodeDestroyed
void slotNodeDestroyed(Akregator::TreeNode *node)
Definition: progressmanager.cpp:117
QObject::connect
bool connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
Akregator::TreeNode
Abstract base class for all kind of elements in the feed tree, like feeds and feed groups (and search...
Definition: treenode.h:58
Akregator::ProgressManager::slotNodeAdded
void slotNodeAdded(Akregator::TreeNode *node)
Definition: progressmanager.cpp:93
Akregator::ProgressManager::slotNodeRemoved
void slotNodeRemoved(Akregator::TreeNode *node)
Definition: progressmanager.cpp:106
Akregator::ProgressManager
This class manages the progress items for all feeds.
Definition: progressmanager.h:43
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:34:00 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

akregator

Skip menu "akregator"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members

kdepim API Reference

Skip menu "kdepim API Reference"
  • akonadi_next
  • akregator
  • blogilo
  • calendarsupport
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt2
  • kjots
  • kleopatra
  • kmail
  • knode
  • knotes
  • kontact
  • korgac
  • korganizer
  • ktimetracker
  • libkdepim
  • libkleo
  • libkpgp
  • mailcommon
  • messagelist
  • messageviewer
  • pimprint

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