45
|
1 /****************************************************************************
|
|
2 **
|
|
3 ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
|
|
4 ** Contact: Qt Software Information (qt-info@nokia.com)
|
|
5 **
|
|
6 ** This file is part of the demonstration applications of the Qt Toolkit.
|
|
7 **
|
|
8 ** $QT_BEGIN_LICENSE:LGPL$
|
|
9 ** Commercial Usage
|
|
10 ** Licensees holding valid Qt Commercial licenses may use this file in
|
|
11 ** accordance with the Qt Commercial License Agreement provided with the
|
|
12 ** Software or, alternatively, in accordance with the terms contained in
|
|
13 ** a written agreement between you and Nokia.
|
|
14 **
|
|
15 ** GNU Lesser General Public License Usage
|
|
16 ** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
17 ** General Public License version 2.1 as published by the Free Software
|
|
18 ** Foundation and appearing in the file LICENSE.LGPL included in the
|
|
19 ** packaging of this file. Please review the following information to
|
|
20 ** ensure the GNU Lesser General Public License version 2.1 requirements
|
|
21 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
|
22 **
|
|
23 ** In addition, as a special exception, Nokia gives you certain
|
|
24 ** additional rights. These rights are described in the Nokia Qt LGPL
|
|
25 ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
|
|
26 ** package.
|
|
27 **
|
|
28 ** GNU General Public License Usage
|
|
29 ** Alternatively, this file may be used under the terms of the GNU
|
|
30 ** General Public License version 3.0 as published by the Free Software
|
|
31 ** Foundation and appearing in the file LICENSE.GPL included in the
|
|
32 ** packaging of this file. Please review the following information to
|
|
33 ** ensure the GNU General Public License version 3.0 requirements will be
|
|
34 ** met: http://www.gnu.org/copyleft/gpl.html.
|
|
35 **
|
|
36 ** If you are unsure which license is appropriate for your use, please
|
|
37 ** contact the sales department at qt-sales@nokia.com.
|
|
38 ** $QT_END_LICENSE$
|
|
39 **
|
|
40 ****************************************************************************/
|
|
41 module autosaver;
|
|
42
|
|
43
|
73
|
44 import qt.core.QObject;
|
|
45 import qt.core.QBasicTimer;
|
|
46 import qt.core.QTime;
|
|
47 import qt.core.QDir;
|
|
48 import qt.core.QCoreApplication;
|
85
|
49 //import qt.core.QMetaObject;
|
73
|
50
|
85
|
51 //import QtDebug;
|
45
|
52
|
73
|
53
|
74
|
54 const uint AUTOSAVE_IN = 1000 * 3; // seconds
|
|
55 const uint MAXWAIT = 1000 * 15; // seconds
|
45
|
56
|
73
|
57
|
45
|
58 /*
|
73
|
59 This class will call the save() slot on the parent object when the parent changes.
|
|
60 It will wait several seconds after changed() to combining multiple changes and
|
|
61 prevent continuous writing to disk.
|
|
62 */
|
|
63
|
45
|
64 class AutoSaver : public QObject {
|
|
65
|
|
66 public:
|
73
|
67
|
|
68 this(QObject parent)
|
|
69 {
|
|
70 super(parent);
|
|
71 assert(parent);
|
|
72 }
|
|
73
|
74
|
74 ~this()
|
73
|
75 {
|
|
76 if (m_timer.isActive())
|
94
|
77 qWarning("AutoSaver: still active when destroyed, changes not saved.");
|
73
|
78 }
|
|
79
|
|
80 void saveIfNeccessary()
|
|
81 {
|
|
82 if (!m_timer.isActive())
|
|
83 return;
|
|
84 m_timer.stop();
|
94
|
85 m_firstChange = new QTime();
|
85
|
86
|
|
87 //TODO!
|
|
88 //if (!QMetaObject.invokeMethod(parent(), "save", Qt.DirectConnection)) {
|
94
|
89 // qWarning("AutoSaver: error invoking slot save() on parent");
|
85
|
90 //}
|
73
|
91 }
|
|
92
|
|
93 public:
|
|
94
|
74
|
95 void changeOccurred()
|
73
|
96 {
|
|
97 if (m_firstChange.isNull())
|
|
98 m_firstChange.start();
|
|
99
|
|
100 if (m_firstChange.elapsed() > MAXWAIT) {
|
|
101 saveIfNeccessary();
|
|
102 } else {
|
|
103 m_timer.start(AUTOSAVE_IN, this);
|
|
104 }
|
|
105 }
|
|
106
|
|
107 protected:
|
|
108
|
|
109 void timerEvent(QTimerEvent event)
|
|
110 {
|
|
111 if (event.timerId() == m_timer.timerId()) {
|
|
112 saveIfNeccessary();
|
|
113 } else {
|
94
|
114 super.timerEvent(event);
|
73
|
115 }
|
|
116 }
|
|
117
|
|
118 private:
|
|
119
|
|
120 QBasicTimer m_timer;
|
|
121 QTime m_firstChange;
|
45
|
122 }
|