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

akregator

  • sources
  • kde-4.12
  • kdepim
  • akregator
  • interfaces
command.cpp
Go to the documentation of this file.
1 /*
2  This file is part of Akregator.
3 
4  Copyright (C) 2008 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 "command.h"
26 
27 #include <QEventLoop>
28 #include <QPointer>
29 #include <QWidget>
30 
31 using namespace Akregator;
32 
33 class Command::Private
34 {
35 public:
36  Private();
37  QPointer<QWidget> parentWidget;
38 };
39 
40 Command::Private::Private() : parentWidget()
41 {
42 }
43 
44 Command::Command( QObject* parent ) : QObject( parent ), d( new Private )
45 {
46 
47 }
48 
49 Command::~Command()
50 {
51  delete d;
52 }
53 
54 QWidget* Command::parentWidget() const
55 {
56  return d->parentWidget;
57 }
58 
59 void Command::setParentWidget( QWidget* parentWidget )
60 {
61  d->parentWidget = parentWidget;
62 }
63 
64 void Command::start()
65 {
66  doStart();
67  emit started();
68 }
69 
70 void Command::abort()
71 {
72  doAbort();
73 }
74 
75 void Command::done()
76 {
77  emit finished();
78  deleteLater();
79 }
80 
81 void Command::waitForFinished()
82 {
83  QEventLoop loop;
84  connect( this, SIGNAL(finished()), &loop, SLOT(quit()) );
85  loop.exec();
86 }
87 
88 #include "command.moc"
Akregator::Command::finished
void finished()
Akregator::Command::Command
Command(QObject *parent=0)
Definition: command.cpp:44
Akregator::Command::abort
void abort()
Definition: command.cpp:70
command.h
Akregator::Command::parentWidget
QWidget * parentWidget() const
Definition: command.cpp:54
QWidget
Akregator::Command::waitForFinished
void waitForFinished()
Definition: command.cpp:81
QObject
Akregator::Command::~Command
virtual ~Command()
Definition: command.cpp:49
Akregator::Command::setParentWidget
void setParentWidget(QWidget *parentWidget)
Definition: command.cpp:59
Akregator::Command::done
void done()
Definition: command.cpp:75
Akregator::Command::doAbort
virtual void doAbort()=0
Akregator::Command::doStart
virtual void doStart()=0
Akregator::Command::start
void start()
Definition: command.cpp:64
Akregator::Command::started
void started()
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:58:14 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

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