1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
/*
* Copyright (C) 2016 Canonical, Ltd.
*
* Authors:
* Tiago Salem Herrmann <tiago.herrmann@canonical.com>
* Gustavo Pichorim Boiko <gustavo.boiko@canonical.com>
*
* This file is part of telephony-service.
*
* telephony-service is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 3.
*
* telephony-service is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef MESSAGEJOB_H
#define MESSAGEJOB_H
#include <QObject>
#include <QDBusAbstractAdaptor>
#include <QDBusContext>
class MessageJob : public QObject, protected QDBusContext
{
Q_OBJECT
Q_PROPERTY(int status READ status NOTIFY statusChanged)
Q_PROPERTY(bool isFinished READ isFinished NOTIFY isFinishedChanged)
Q_PROPERTY(QString objectPath READ objectPath CONSTANT)
Q_ENUMS(Status)
public:
enum Status {
Pending,
Initialising,
Running,
Finished,
Failed
};
explicit MessageJob(QObject *parent = 0);
virtual ~MessageJob();
void setAdaptorAndRegister(QDBusAbstractAdaptor *adaptor);
Status status() const;
bool isFinished() const;
QString objectPath() const;
void waitForFinished(int timeout = 10000);
Q_SIGNALS:
void statusChanged();
void isFinishedChanged();
void finished();
public Q_SLOTS:
virtual void startJob();
protected:
void setStatus(Status status);
void scheduleDeletion(int timeout = 60000);
private:
Status mStatus;
bool mFinished;
QString mObjectPath;
QDBusAbstractAdaptor *mAdaptor;
};
#endif // MESSAGEJOB_H
|