author | mickeyl <mickeyl> | 2004-07-01 13:33:35 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2004-07-01 13:33:35 (UTC) |
commit | 558c37f440baa57213d40639992bd29eaed1e12f (patch) (unidiff) | |
tree | 809b695bcb66794ad9d04efe3db06aae49f8ae1b /library/alarmserver.cpp | |
parent | fadef9ae9838b3fb6f770a64b4cc2d179c6e9f07 (diff) | |
download | opie-558c37f440baa57213d40639992bd29eaed1e12f.zip opie-558c37f440baa57213d40639992bd29eaed1e12f.tar.gz opie-558c37f440baa57213d40639992bd29eaed1e12f.tar.bz2 |
add a few missing includes
-rw-r--r-- | library/alarmserver.cpp | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/library/alarmserver.cpp b/library/alarmserver.cpp index 48ab9c1..ba7b015 100644 --- a/library/alarmserver.cpp +++ b/library/alarmserver.cpp | |||
@@ -1,288 +1,287 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include <qdir.h> | 21 | #include "alarmserver.h" |
22 | |||
23 | 22 | ||
23 | #include <qpe/global.h> | ||
24 | #include <qpe/qpeapplication.h> | 24 | #include <qpe/qpeapplication.h> |
25 | |||
26 | #include <qpe/qcopenvelope_qws.h> | 25 | #include <qpe/qcopenvelope_qws.h> |
27 | #include "alarmserver.h" | ||
28 | #include <qpe/timeconversion.h> | 26 | #include <qpe/timeconversion.h> |
29 | 27 | ||
28 | #include <qdir.h> | ||
29 | |||
30 | #include <sys/types.h> | 30 | #include <sys/types.h> |
31 | #include <sys/stat.h> | 31 | #include <sys/stat.h> |
32 | |||
33 | #include <stdlib.h> | 32 | #include <stdlib.h> |
34 | #include <unistd.h> | 33 | #include <unistd.h> |
35 | 34 | ||
36 | 35 | ||
37 | #undef USE_ATD // not used anymore -- we run opie-alarm on suspend/resume | 36 | #undef USE_ATD // not used anymore -- we run opie-alarm on suspend/resume |
38 | 37 | ||
39 | 38 | ||
40 | struct timerEventItem | 39 | struct timerEventItem |
41 | { | 40 | { |
42 | time_t UTCtime; | 41 | time_t UTCtime; |
43 | QCString channel, message; | 42 | QCString channel, message; |
44 | int data; | 43 | int data; |
45 | bool operator==( const timerEventItem &right ) const | 44 | bool operator==( const timerEventItem &right ) const |
46 | { | 45 | { |
47 | return ( UTCtime == right.UTCtime | 46 | return ( UTCtime == right.UTCtime |
48 | && channel == right.channel | 47 | && channel == right.channel |
49 | && message == right.message | 48 | && message == right.message |
50 | && data == right.data ); | 49 | && data == right.data ); |
51 | } | 50 | } |
52 | }; | 51 | }; |
53 | 52 | ||
54 | class TimerReceiverObject : public QObject | 53 | class TimerReceiverObject : public QObject |
55 | { | 54 | { |
56 | public: | 55 | public: |
57 | TimerReceiverObject() | 56 | TimerReceiverObject() |
58 | { } | 57 | { } |
59 | ~TimerReceiverObject() | 58 | ~TimerReceiverObject() |
60 | { } | 59 | { } |
61 | void resetTimer(); | 60 | void resetTimer(); |
62 | void setTimerEventItem(); | 61 | void setTimerEventItem(); |
63 | void deleteTimer(); | 62 | void deleteTimer(); |
64 | protected: | 63 | protected: |
65 | void timerEvent( QTimerEvent *te ); | 64 | void timerEvent( QTimerEvent *te ); |
66 | 65 | ||
67 | #ifdef USE_ATD | 66 | #ifdef USE_ATD |
68 | private: | 67 | private: |
69 | QString atfilename; | 68 | QString atfilename; |
70 | #endif | 69 | #endif |
71 | }; | 70 | }; |
72 | 71 | ||
73 | TimerReceiverObject *timerEventReceiver = NULL; | 72 | TimerReceiverObject *timerEventReceiver = NULL; |
74 | QList<timerEventItem> timerEventList; | 73 | QList<timerEventItem> timerEventList; |
75 | timerEventItem *nearestTimerEvent = NULL; | 74 | timerEventItem *nearestTimerEvent = NULL; |
76 | 75 | ||
77 | 76 | ||
78 | // set the timer to go off on the next event in the list | 77 | // set the timer to go off on the next event in the list |
79 | void setNearestTimerEvent() | 78 | void setNearestTimerEvent() |
80 | { | 79 | { |
81 | nearestTimerEvent = NULL; | 80 | nearestTimerEvent = NULL; |
82 | QListIterator<timerEventItem> it( timerEventList ); | 81 | QListIterator<timerEventItem> it( timerEventList ); |
83 | if ( *it ) | 82 | if ( *it ) |
84 | nearestTimerEvent = *it; | 83 | nearestTimerEvent = *it; |
85 | for ( ; *it; ++it ) | 84 | for ( ; *it; ++it ) |
86 | if ( (*it)->UTCtime < nearestTimerEvent->UTCtime ) | 85 | if ( (*it)->UTCtime < nearestTimerEvent->UTCtime ) |
87 | nearestTimerEvent = *it; | 86 | nearestTimerEvent = *it; |
88 | if (nearestTimerEvent) | 87 | if (nearestTimerEvent) |
89 | timerEventReceiver->resetTimer(); | 88 | timerEventReceiver->resetTimer(); |
90 | else | 89 | else |
91 | timerEventReceiver->deleteTimer(); | 90 | timerEventReceiver->deleteTimer(); |
92 | } | 91 | } |
93 | 92 | ||
94 | 93 | ||
95 | //store current state to file | 94 | //store current state to file |
96 | //Simple implementation. Should run on a timer. | 95 | //Simple implementation. Should run on a timer. |
97 | 96 | ||
98 | static void saveState() | 97 | static void saveState() |
99 | { | 98 | { |
100 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); | 99 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); |
101 | if ( timerEventList.isEmpty() ) { | 100 | if ( timerEventList.isEmpty() ) { |
102 | unlink( savefilename ); | 101 | unlink( savefilename ); |
103 | return ; | 102 | return ; |
104 | } | 103 | } |
105 | 104 | ||
106 | QFile savefile(savefilename + ".new"); | 105 | QFile savefile(savefilename + ".new"); |
107 | if ( savefile.open(IO_WriteOnly) ) { | 106 | if ( savefile.open(IO_WriteOnly) ) { |
108 | QDataStream ds( &savefile ); | 107 | QDataStream ds( &savefile ); |
109 | 108 | ||
110 | //save | 109 | //save |
111 | 110 | ||
112 | QListIterator<timerEventItem> it( timerEventList ); | 111 | QListIterator<timerEventItem> it( timerEventList ); |
113 | for ( ; *it; ++it ) { | 112 | for ( ; *it; ++it ) { |
114 | ds << it.current()->UTCtime; | 113 | ds << it.current()->UTCtime; |
115 | ds << it.current()->channel; | 114 | ds << it.current()->channel; |
116 | ds << it.current()->message; | 115 | ds << it.current()->message; |
117 | ds << it.current()->data; | 116 | ds << it.current()->data; |
118 | } | 117 | } |
119 | 118 | ||
120 | 119 | ||
121 | savefile.close(); | 120 | savefile.close(); |
122 | unlink( savefilename ); | 121 | unlink( savefilename ); |
123 | QDir d; | 122 | QDir d; |
124 | d.rename(savefilename + ".new", savefilename); | 123 | d.rename(savefilename + ".new", savefilename); |
125 | 124 | ||
126 | } | 125 | } |
127 | } | 126 | } |
128 | 127 | ||
129 | /*! | 128 | /*! |
130 | Sets up the alarm server. Restoring to previous state (session management). | 129 | Sets up the alarm server. Restoring to previous state (session management). |
131 | */ | 130 | */ |
132 | void AlarmServer::initialize() | 131 | void AlarmServer::initialize() |
133 | { | 132 | { |
134 | //read autosave file and put events in timerEventList | 133 | //read autosave file and put events in timerEventList |
135 | 134 | ||
136 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); | 135 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); |
137 | 136 | ||
138 | QFile savefile(savefilename); | 137 | QFile savefile(savefilename); |
139 | if ( savefile.open(IO_ReadOnly) ) { | 138 | if ( savefile.open(IO_ReadOnly) ) { |
140 | QDataStream ds( &savefile ); | 139 | QDataStream ds( &savefile ); |
141 | while ( !ds.atEnd() ) { | 140 | while ( !ds.atEnd() ) { |
142 | timerEventItem *newTimerEventItem = new timerEventItem; | 141 | timerEventItem *newTimerEventItem = new timerEventItem; |
143 | ds >> newTimerEventItem->UTCtime; | 142 | ds >> newTimerEventItem->UTCtime; |
144 | ds >> newTimerEventItem->channel; | 143 | ds >> newTimerEventItem->channel; |
145 | ds >> newTimerEventItem->message; | 144 | ds >> newTimerEventItem->message; |
146 | ds >> newTimerEventItem->data; | 145 | ds >> newTimerEventItem->data; |
147 | timerEventList.append( newTimerEventItem ); | 146 | timerEventList.append( newTimerEventItem ); |
148 | } | 147 | } |
149 | savefile.close(); | 148 | savefile.close(); |
150 | if (!timerEventReceiver) | 149 | if (!timerEventReceiver) |
151 | timerEventReceiver = new TimerReceiverObject; | 150 | timerEventReceiver = new TimerReceiverObject; |
152 | setNearestTimerEvent(); | 151 | setNearestTimerEvent(); |
153 | } | 152 | } |
154 | } | 153 | } |
155 | 154 | ||
156 | 155 | ||
157 | #ifdef USE_ATD | 156 | #ifdef USE_ATD |
158 | 157 | ||
159 | static const char* atdir = "/var/spool/at/"; | 158 | static const char* atdir = "/var/spool/at/"; |
160 | 159 | ||
161 | static bool triggerAtd( bool writeHWClock = FALSE ) | 160 | static bool triggerAtd( bool writeHWClock = FALSE ) |
162 | { | 161 | { |
163 | QFile trigger(QString(atdir) + "trigger"); | 162 | QFile trigger(QString(atdir) + "trigger"); |
164 | if ( trigger.open(IO_WriteOnly | IO_Raw) ) { | 163 | if ( trigger.open(IO_WriteOnly | IO_Raw) ) { |
165 | if ( trigger.writeBlock("\n", 2) != 2 ) { | 164 | if ( trigger.writeBlock("\n", 2) != 2 ) { |
166 | QMessageBox::critical( 0, QObject::tr( "Out of Space" ), | 165 | QMessageBox::critical( 0, QObject::tr( "Out of Space" ), |
167 | QObject::tr( "Unable to schedule alarm.\nFree some memory and try again." ) ); | 166 | QObject::tr( "Unable to schedule alarm.\nFree some memory and try again." ) ); |
168 | trigger.close(); | 167 | trigger.close(); |
169 | QFile::remove | 168 | QFile::remove |
170 | ( trigger.name() ); | 169 | ( trigger.name() ); |
171 | return FALSE; | 170 | return FALSE; |
172 | } | 171 | } |
173 | return TRUE; | 172 | return TRUE; |
174 | } | 173 | } |
175 | return FALSE; | 174 | return FALSE; |
176 | } | 175 | } |
177 | 176 | ||
178 | #else | 177 | #else |
179 | 178 | ||
180 | static bool writeResumeAt ( time_t wakeup ) | 179 | static bool writeResumeAt ( time_t wakeup ) |
181 | { | 180 | { |
182 | FILE *fp = ::fopen ( "/var/run/resumeat", "w" ); | 181 | FILE *fp = ::fopen ( "/var/run/resumeat", "w" ); |
183 | 182 | ||
184 | if ( fp ) { | 183 | if ( fp ) { |
185 | ::fprintf ( fp, "%d\n", (int) wakeup ); | 184 | ::fprintf ( fp, "%d\n", (int) wakeup ); |
186 | ::fclose ( fp ); | 185 | ::fclose ( fp ); |
187 | } | 186 | } |
188 | else | 187 | else |
189 | qWarning ( "Failed to write wakeup time to /var/run/resumeat" ); | 188 | qWarning ( "Failed to write wakeup time to /var/run/resumeat" ); |
190 | 189 | ||
191 | return ( fp ); | 190 | return ( fp ); |
192 | } | 191 | } |
193 | 192 | ||
194 | #endif | 193 | #endif |
195 | 194 | ||
196 | void TimerReceiverObject::deleteTimer() | 195 | void TimerReceiverObject::deleteTimer() |
197 | { | 196 | { |
198 | #ifdef USE_ATD | 197 | #ifdef USE_ATD |
199 | if ( !atfilename.isEmpty() ) { | 198 | if ( !atfilename.isEmpty() ) { |
200 | unlink( atfilename ); | 199 | unlink( atfilename ); |
201 | atfilename = QString::null; | 200 | atfilename = QString::null; |
202 | triggerAtd( FALSE ); | 201 | triggerAtd( FALSE ); |
203 | } | 202 | } |
204 | #else | 203 | #else |
205 | writeResumeAt ( 0 ); | 204 | writeResumeAt ( 0 ); |
206 | #endif | 205 | #endif |
207 | } | 206 | } |
208 | 207 | ||
209 | void TimerReceiverObject::resetTimer() | 208 | void TimerReceiverObject::resetTimer() |
210 | { | 209 | { |
211 | const int maxsecs = 2147000; | 210 | const int maxsecs = 2147000; |
212 | QDateTime nearest = TimeConversion::fromUTC(nearestTimerEvent->UTCtime); | 211 | QDateTime nearest = TimeConversion::fromUTC(nearestTimerEvent->UTCtime); |
213 | QDateTime now = QDateTime::currentDateTime(); | 212 | QDateTime now = QDateTime::currentDateTime(); |
214 | if ( nearest < now ) | 213 | if ( nearest < now ) |
215 | nearest = now; | 214 | nearest = now; |
216 | int secs = TimeConversion::secsTo( now, nearest ); | 215 | int secs = TimeConversion::secsTo( now, nearest ); |
217 | if ( secs > maxsecs ) { | 216 | if ( secs > maxsecs ) { |
218 | // too far for millisecond timing | 217 | // too far for millisecond timing |
219 | secs = maxsecs; | 218 | secs = maxsecs; |
220 | } | 219 | } |
221 | 220 | ||
222 | // System timer (needed so that we wake from deep sleep), | 221 | // System timer (needed so that we wake from deep sleep), |
223 | // from the Epoch in seconds. | 222 | // from the Epoch in seconds. |
224 | // | 223 | // |
225 | int at_secs = TimeConversion::toUTC(nearest); | 224 | int at_secs = TimeConversion::toUTC(nearest); |
226 | // qDebug("reset timer to %d seconds from Epoch",at_secs); | 225 | // qDebug("reset timer to %d seconds from Epoch",at_secs); |
227 | 226 | ||
228 | #ifdef USE_ATD | 227 | #ifdef USE_ATD |
229 | 228 | ||
230 | QString fn = atdir + QString::number(at_secs) + "." | 229 | QString fn = atdir + QString::number(at_secs) + "." |
231 | + QString::number(getpid()); | 230 | + QString::number(getpid()); |
232 | if ( fn != atfilename ) { | 231 | if ( fn != atfilename ) { |
233 | QFile atfile(fn + ".new"); | 232 | QFile atfile(fn + ".new"); |
234 | if ( atfile.open(IO_WriteOnly | IO_Raw) ) { | 233 | if ( atfile.open(IO_WriteOnly | IO_Raw) ) { |
235 | int total_written; | 234 | int total_written; |
236 | 235 | ||
237 | // just wake up and delete the at file | 236 | // just wake up and delete the at file |
238 | QString cmd = "#!/bin/sh\nrm " + fn; | 237 | QString cmd = "#!/bin/sh\nrm " + fn; |
239 | total_written = atfile.writeBlock(cmd.latin1(), cmd.length()); | 238 | total_written = atfile.writeBlock(cmd.latin1(), cmd.length()); |
240 | if ( total_written != int(cmd.length()) ) { | 239 | if ( total_written != int(cmd.length()) ) { |
241 | QMessageBox::critical( 0, tr("Out of Space"), | 240 | QMessageBox::critical( 0, tr("Out of Space"), |
242 | tr("Unable to schedule alarm.\n" | 241 | tr("Unable to schedule alarm.\n" |
243 | "Please free up space and try again") ); | 242 | "Please free up space and try again") ); |
244 | atfile.close(); | 243 | atfile.close(); |
245 | QFile::remove | 244 | QFile::remove |
246 | ( atfile.name() ); | 245 | ( atfile.name() ); |
247 | return ; | 246 | return ; |
248 | } | 247 | } |
249 | atfile.close(); | 248 | atfile.close(); |
250 | unlink( atfilename ); | 249 | unlink( atfilename ); |
251 | QDir d; | 250 | QDir d; |
252 | d.rename(fn + ".new", fn); | 251 | d.rename(fn + ".new", fn); |
253 | chmod(fn.latin1(), 0755); | 252 | chmod(fn.latin1(), 0755); |
254 | atfilename = fn; | 253 | atfilename = fn; |
255 | triggerAtd( FALSE ); | 254 | triggerAtd( FALSE ); |
256 | } | 255 | } |
257 | else { | 256 | else { |
258 | qWarning("Cannot open atd file %s", fn.latin1()); | 257 | qWarning("Cannot open atd file %s", fn.latin1()); |
259 | } | 258 | } |
260 | } | 259 | } |
261 | #else | 260 | #else |
262 | writeResumeAt ( at_secs ); | 261 | writeResumeAt ( at_secs ); |
263 | 262 | ||
264 | #endif | 263 | #endif |
265 | 264 | ||
266 | // Qt timers (does the actual alarm) | 265 | // Qt timers (does the actual alarm) |
267 | // from now in milliseconds | 266 | // from now in milliseconds |
268 | // | 267 | // |
269 | qDebug("AlarmServer waiting %d seconds", secs); | 268 | qDebug("AlarmServer waiting %d seconds", secs); |
270 | startTimer( 1000 * secs + 500 ); | 269 | startTimer( 1000 * secs + 500 ); |
271 | } | 270 | } |
272 | 271 | ||
273 | void TimerReceiverObject::timerEvent( QTimerEvent * ) | 272 | void TimerReceiverObject::timerEvent( QTimerEvent * ) |
274 | { | 273 | { |
275 | bool needSave = FALSE; | 274 | bool needSave = FALSE; |
276 | killTimers(); | 275 | killTimers(); |
277 | if (nearestTimerEvent) { | 276 | if (nearestTimerEvent) { |
278 | if ( nearestTimerEvent->UTCtime | 277 | if ( nearestTimerEvent->UTCtime |
279 | <= TimeConversion::toUTC(QDateTime::currentDateTime()) ) { | 278 | <= TimeConversion::toUTC(QDateTime::currentDateTime()) ) { |
280 | #ifndef QT_NO_COP | 279 | #ifndef QT_NO_COP |
281 | QCopEnvelope e( nearestTimerEvent->channel, | 280 | QCopEnvelope e( nearestTimerEvent->channel, |
282 | nearestTimerEvent->message ); | 281 | nearestTimerEvent->message ); |
283 | e << TimeConversion::fromUTC( nearestTimerEvent->UTCtime ) | 282 | e << TimeConversion::fromUTC( nearestTimerEvent->UTCtime ) |
284 | << nearestTimerEvent->data; | 283 | << nearestTimerEvent->data; |
285 | #endif | 284 | #endif |
286 | 285 | ||
287 | timerEventList.remove( nearestTimerEvent ); | 286 | timerEventList.remove( nearestTimerEvent ); |
288 | needSave = TRUE; | 287 | needSave = TRUE; |