-rw-r--r-- | library/backend/event.cpp | 5 | ||||
-rw-r--r-- | library/backend/event.h | 4 |
2 files changed, 6 insertions, 3 deletions
diff --git a/library/backend/event.cpp b/library/backend/event.cpp index 8f3f780..7cac314 100644 --- a/library/backend/event.cpp +++ b/library/backend/event.cpp | |||
@@ -1,1320 +1,1323 @@ | |||
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 "event.h" | 21 | #include "event.h" |
22 | #include "qfiledirect_p.h" | 22 | #include "qfiledirect_p.h" |
23 | #include <qtopia/timeconversion.h> | 23 | #include <qtopia/timeconversion.h> |
24 | #include <qtopia/stringutil.h> | 24 | #include <qtopia/stringutil.h> |
25 | #include <qtopia/private/recordfields.h> | 25 | #include <qtopia/private/recordfields.h> |
26 | #include <qbuffer.h> | 26 | #include <qbuffer.h> |
27 | #include <time.h> | 27 | #include <time.h> |
28 | #include "vobject_p.h" | 28 | #include "vobject_p.h" |
29 | 29 | ||
30 | #include <stdio.h> | 30 | #include <stdio.h> |
31 | 31 | ||
32 | using namespace Qtopia; | 32 | using namespace Qtopia; |
33 | 33 | ||
34 | static void write( QString& buf, const Event::RepeatPattern &r ) | 34 | static void write( QString& buf, const Event::RepeatPattern &r ) |
35 | { | 35 | { |
36 | buf += " rtype=\""; | 36 | buf += " rtype=\""; |
37 | switch ( r.type ) { | 37 | switch ( r.type ) { |
38 | case Event::Daily: | 38 | case Event::Daily: |
39 | buf += "Daily"; | 39 | buf += "Daily"; |
40 | break; | 40 | break; |
41 | case Event::Weekly: | 41 | case Event::Weekly: |
42 | buf += "Weekly"; | 42 | buf += "Weekly"; |
43 | break; | 43 | break; |
44 | case Event::MonthlyDay: | 44 | case Event::MonthlyDay: |
45 | buf += "MonthlyDay"; | 45 | buf += "MonthlyDay"; |
46 | break; | 46 | break; |
47 | case Event::MonthlyDate: | 47 | case Event::MonthlyDate: |
48 | buf += "MonthlyDate"; | 48 | buf += "MonthlyDate"; |
49 | break; | 49 | break; |
50 | case Event::Yearly: | 50 | case Event::Yearly: |
51 | buf += "Yearly"; | 51 | buf += "Yearly"; |
52 | break; | 52 | break; |
53 | default: | 53 | default: |
54 | buf += "NoRepeat"; | 54 | buf += "NoRepeat"; |
55 | break; | 55 | break; |
56 | } | 56 | } |
57 | buf += "\""; | 57 | buf += "\""; |
58 | if ( r.days > 0 ) | 58 | if ( r.days > 0 ) |
59 | buf += " rweekdays=\"" + QString::number( static_cast<int>( r.days ) ) + "\""; | 59 | buf += " rweekdays=\"" + QString::number( static_cast<int>( r.days ) ) + "\""; |
60 | if ( r.position != 0 ) | 60 | if ( r.position != 0 ) |
61 | buf += " rposition=\"" + QString::number( r.position ) + "\""; | 61 | buf += " rposition=\"" + QString::number( r.position ) + "\""; |
62 | 62 | ||
63 | buf += " rfreq=\"" + QString::number( r.frequency ) + "\""; | 63 | buf += " rfreq=\"" + QString::number( r.frequency ) + "\""; |
64 | buf += " rhasenddate=\"" + QString::number( static_cast<int>( r.hasEndDate ) ) + "\""; | 64 | buf += " rhasenddate=\"" + QString::number( static_cast<int>( r.hasEndDate ) ) + "\""; |
65 | if ( r.hasEndDate ) | 65 | if ( r.hasEndDate ) |
66 | buf += " enddt=\"" | 66 | buf += " enddt=\"" |
67 | + QString::number( r.endDateUTC ? r.endDateUTC : time( 0 ) ) | 67 | + QString::number( r.endDateUTC ? r.endDateUTC : time( 0 ) ) |
68 | + "\""; | 68 | + "\""; |
69 | buf += " created=\"" + QString::number( r.createTime ) + "\""; | 69 | buf += " created=\"" + QString::number( r.createTime ) + "\""; |
70 | } | 70 | } |
71 | 71 | ||
72 | Qtopia::UidGen Event::sUidGen( Qtopia::UidGen::Qtopia ); | 72 | Qtopia::UidGen Event::sUidGen( Qtopia::UidGen::Qtopia ); |
73 | 73 | ||
74 | /*! | 74 | /*! |
75 | \class Event event.h | 75 | \class Event event.h |
76 | \brief The Event class holds the data of a calendar event. | 76 | \brief The Event class holds the data of a calendar event. |
77 | 77 | ||
78 | This data includes descriptive data of the event and schedualing information. | 78 | This data includes descriptive data of the event and schedualing information. |
79 | 79 | ||
80 | \ingroup qtopiaemb | 80 | \ingroup qtopiaemb |
81 | \ingroup qtopiadesktop | 81 | \ingroup qtopiadesktop |
82 | */ | 82 | */ |
83 | 83 | ||
84 | /*! | 84 | /*! |
85 | \class Event::RepeatPattern | 85 | \class Event::RepeatPattern |
86 | \class The Event::RepeatPattern class is internal. | 86 | \class The Event::RepeatPattern class is internal. |
87 | \internal | 87 | \internal |
88 | */ | 88 | */ |
89 | 89 | ||
90 | /*! | 90 | /*! |
91 | \enum Event::Days | 91 | \enum Event::Days |
92 | \internal | 92 | \internal |
93 | */ | 93 | */ |
94 | 94 | ||
95 | /*! | 95 | /*! |
96 | \enum Event::Type | 96 | \enum Event::Type |
97 | \internal | 97 | \internal |
98 | */ | 98 | */ |
99 | 99 | ||
100 | /*! | 100 | /*! |
101 | \enum Event::SoundTypeChoice | 101 | \enum Event::SoundTypeChoice |
102 | 102 | ||
103 | This enum type defines what kind of sound is made when an alarm occurs | 103 | This enum type defines what kind of sound is made when an alarm occurs |
104 | for an event. The currently defined types are: | 104 | for an event. The currently defined types are: |
105 | 105 | ||
106 | <ul> | 106 | <ul> |
107 | <li>\c Silent - No sound is produced. | 107 | <li>\c Silent - No sound is produced. |
108 | <li>\c Loud - A loud sound is produced. | 108 | <li>\c Loud - A loud sound is produced. |
109 | </ul> | 109 | </ul> |
110 | */ | 110 | */ |
111 | 111 | ||
112 | /*! | 112 | /*! |
113 | \fn bool Event::operator<( const Event & ) const | 113 | \fn bool Event::operator<( const Event & ) const |
114 | \internal | 114 | \internal |
115 | */ | 115 | */ |
116 | 116 | ||
117 | /*! | 117 | /*! |
118 | \fn bool Event::operator<=( const Event & ) const | 118 | \fn bool Event::operator<=( const Event & ) const |
119 | \internal | 119 | \internal |
120 | */ | 120 | */ |
121 | 121 | ||
122 | /*! | 122 | /*! |
123 | \fn bool Event::operator!=( const Event & ) const | 123 | \fn bool Event::operator!=( const Event & ) const |
124 | \internal | 124 | \internal |
125 | */ | 125 | */ |
126 | 126 | ||
127 | /*! | 127 | /*! |
128 | \fn bool Event::operator>( const Event & ) const | 128 | \fn bool Event::operator>( const Event & ) const |
129 | \internal | 129 | \internal |
130 | */ | 130 | */ |
131 | 131 | ||
132 | /*! | 132 | /*! |
133 | \fn bool Event::operator>=( const Event & ) const | 133 | \fn bool Event::operator>=( const Event & ) const |
134 | \internal | 134 | \internal |
135 | */ | 135 | */ |
136 | 136 | ||
137 | /*! | 137 | /*! |
138 | \enum Event::RepeatType | 138 | \enum Event::RepeatType |
139 | 139 | ||
140 | This enum defines how a event will repeat, if at all. | 140 | This enum defines how a event will repeat, if at all. |
141 | 141 | ||
142 | <ul> | 142 | <ul> |
143 | <li>\c NoRepeat - Event does not repeat. | 143 | <li>\c NoRepeat - Event does not repeat. |
144 | <li>\c Daily - Event occurs every n days. | 144 | <li>\c Daily - Event occurs every n days. |
145 | <li>\c Weekly - Event occurs every n weeks. | 145 | <li>\c Weekly - Event occurs every n weeks. |
146 | <li>\c MonthlyDay - Event occurs every n months. Event will always occur in | 146 | <li>\c MonthlyDay - Event occurs every n months. Event will always occur in |
147 | the same week and same day of week as the first event. | 147 | the same week and same day of week as the first event. |
148 | <li>\c MonthlyDate - Event occurs every n months. Event will always occur | 148 | <li>\c MonthlyDate - Event occurs every n months. Event will always occur |
149 | on the same day of the month as the first event. | 149 | on the same day of the month as the first event. |
150 | <li>\c Yearly - Event occurs every n years. | 150 | <li>\c Yearly - Event occurs every n years. |
151 | </ul> | 151 | </ul> |
152 | */ | 152 | */ |
153 | 153 | ||
154 | /*! | 154 | /*! |
155 | \fn bool Event::isAllDay() const | 155 | \fn bool Event::isAllDay() const |
156 | 156 | ||
157 | Returns TRUE if the event is an all day event. Otherwise returns FALSE. | 157 | Returns TRUE if the event is an all day event. Otherwise returns FALSE. |
158 | */ | 158 | */ |
159 | 159 | ||
160 | /*! | 160 | /*! |
161 | \fn void Event::setAllDay(bool allday) | 161 | \fn void Event::setAllDay(bool allday) |
162 | 162 | ||
163 | If \a allday is TRUE, will set the event to be an all day event. | 163 | If \a allday is TRUE, will set the event to be an all day event. |
164 | Otherwise sets the event to not be an all day event. | 164 | Otherwise sets the event to not be an all day event. |
165 | 165 | ||
166 | \warning This function may affect the start and end times of the event. | 166 | \warning This function may affect the start and end times of the event. |
167 | */ | 167 | */ |
168 | 168 | ||
169 | /*! | 169 | /*! |
170 | \fn QDateTime Event::start() const | 170 | \fn QDateTime Event::start() const |
171 | 171 | ||
172 | Returns the start date and time of the first occurance of the event. | 172 | Returns the start date and time of the first occurance of the event. |
173 | */ | 173 | */ |
174 | 174 | ||
175 | /*! | 175 | /*! |
176 | \fn QDateTime Event::end() const | 176 | \fn QDateTime Event::end() const |
177 | 177 | ||
178 | Returns the end date and time of the first occurance of the event. | 178 | Returns the end date and time of the first occurance of the event. |
179 | */ | 179 | */ |
180 | 180 | ||
181 | /*! | 181 | /*! |
182 | \fn time_t Event::startTime() const | 182 | \fn time_t Event::startTime() const |
183 | \internal | 183 | \internal |
184 | */ | 184 | */ |
185 | 185 | ||
186 | /*! | 186 | /*! |
187 | \fn time_t Event::endTime() const | 187 | \fn time_t Event::endTime() const |
188 | \internal | 188 | \internal |
189 | */ | 189 | */ |
190 | 190 | ||
191 | /*! | 191 | /*! |
192 | \fn void Event::setAlarm(int delay, SoundTypeChoice s) | 192 | \fn void Event::setAlarm(int delay, SoundTypeChoice s) |
193 | 193 | ||
194 | Sets the alarm delay of the event to \a delay and the sound type of the | 194 | Sets the alarm delay of the event to \a delay and the sound type of the |
195 | alarm to \a s. | 195 | alarm to \a s. |
196 | */ | 196 | */ |
197 | 197 | ||
198 | /*! | 198 | /*! |
199 | \fn void Event::clearAlarm() | 199 | \fn void Event::clearAlarm() |
200 | 200 | ||
201 | Clears the alarm for the event. | 201 | Clears the alarm for the event. |
202 | */ | 202 | */ |
203 | 203 | ||
204 | /*! | 204 | /*! |
205 | \fn int Event::alarmDelay() const | 205 | \fn int Event::alarmDelay() const |
206 | 206 | ||
207 | Returns the delay in minutes between the alarm for an event and the | 207 | Returns the delay in minutes between the alarm for an event and the |
208 | start of the event. | 208 | start of the event. |
209 | */ | 209 | */ |
210 | 210 | ||
211 | /*! | 211 | /*! |
212 | \fn Event::RepeatType Event::repeatType() const | 212 | \fn Event::RepeatType Event::repeatType() const |
213 | 213 | ||
214 | Returns the repeat pattern type for the event. | 214 | Returns the repeat pattern type for the event. |
215 | 215 | ||
216 | \sa frequency() | 216 | \sa frequency() |
217 | */ | 217 | */ |
218 | 218 | ||
219 | /*! | 219 | /*! |
220 | \fn int Event::weekOffset() const | 220 | \fn int Event::weekOffset() const |
221 | 221 | ||
222 | Returns the number of weeks from the start of the month that this event | 222 | Returns the number of weeks from the start of the month that this event |
223 | occurs. | 223 | occurs. |
224 | */ | 224 | */ |
225 | 225 | ||
226 | /*! | 226 | /*! |
227 | \fn QDate Event::repeatTill() const | 227 | \fn QDate Event::repeatTill() const |
228 | 228 | ||
229 | Returns the date that the event will continue to repeat until. If the event | 229 | Returns the date that the event will continue to repeat until. If the event |
230 | repeats forever the value returned is undefined. | 230 | repeats forever the value returned is undefined. |
231 | 231 | ||
232 | \sa repeatForever() | 232 | \sa repeatForever() |
233 | */ | 233 | */ |
234 | 234 | ||
235 | /*! | 235 | /*! |
236 | \fn bool Event::repeatForever() const | 236 | \fn bool Event::repeatForever() const |
237 | 237 | ||
238 | Returns FALSE if there is a date set for the event to continue until. | 238 | Returns FALSE if there is a date set for the event to continue until. |
239 | Otherwise returns TRUE. | 239 | Otherwise returns TRUE. |
240 | */ | 240 | */ |
241 | 241 | ||
242 | /*! | 242 | /*! |
243 | \fn bool Event::doRepeat() const | 243 | \fn bool Event::doRepeat() const |
244 | \internal | 244 | \internal |
245 | */ | 245 | */ |
246 | 246 | ||
247 | /*! | 247 | /*! |
248 | \fn bool Event::repeatOnWeekDay(int day) const | 248 | \fn bool Event::repeatOnWeekDay(int day) const |
249 | 249 | ||
250 | Returns TRUE if the event has a RepeatType of Weekly and is set to occur on | 250 | Returns TRUE if the event has a RepeatType of Weekly and is set to occur on |
251 | \a day each week. Otherwise returns FALSE. | 251 | \a day each week. Otherwise returns FALSE. |
252 | 252 | ||
253 | \sa QDate::dayName() | 253 | \sa QDate::dayName() |
254 | */ | 254 | */ |
255 | 255 | ||
256 | /*! | 256 | /*! |
257 | \fn void Event::setRepeatOnWeekDay(int day, bool enable) | 257 | \fn void Event::setRepeatOnWeekDay(int day, bool enable) |
258 | 258 | ||
259 | If \a enable is TRUE then sets the event to occur on \a day each week. | 259 | If \a enable is TRUE then sets the event to occur on \a day each week. |
260 | Otherwise sets the event not to occur on \a day. | 260 | Otherwise sets the event not to occur on \a day. |
261 | 261 | ||
262 | \warning this function is only relavent for a event with RepeatType of | 262 | \warning this function is only relavent for a event with RepeatType of |
263 | Weekly. | 263 | Weekly. |
264 | 264 | ||
265 | \sa QDate::dayName() | 265 | \sa QDate::dayName() |
266 | */ | 266 | */ |
267 | 267 | ||
268 | /*! | 268 | /*! |
269 | \fn int Event::frequency() const | 269 | \fn int Event::frequency() const |
270 | 270 | ||
271 | Returns how often the event repeats. | 271 | Returns how often the event repeats. |
272 | 272 | ||
273 | \sa repeatType() | 273 | \sa repeatType() |
274 | */ | 274 | */ |
275 | 275 | ||
276 | /*! | 276 | /*! |
277 | \fn void Event::setRepeatType(RepeatType t) | 277 | \fn void Event::setRepeatType(RepeatType t) |
278 | 278 | ||
279 | Sets the repeat pattern type of the event to \a t. | 279 | Sets the repeat pattern type of the event to \a t. |
280 | 280 | ||
281 | \sa setFrequency() | 281 | \sa setFrequency() |
282 | */ | 282 | */ |
283 | 283 | ||
284 | /*! | 284 | /*! |
285 | \fn void Event::setFrequency(int n) | 285 | \fn void Event::setFrequency(int n) |
286 | 286 | ||
287 | Sets how often the event occurs with in its repeat pattern. | 287 | Sets how often the event occurs with in its repeat pattern. |
288 | 288 | ||
289 | \sa setRepeatType() | 289 | \sa setRepeatType() |
290 | */ | 290 | */ |
291 | 291 | ||
292 | /*! | 292 | /*! |
293 | \fn void Event::setRepeatTill(const QDate &d) | 293 | \fn void Event::setRepeatTill(const QDate &d) |
294 | 294 | ||
295 | Sets the event to repeat until \a d. | 295 | Sets the event to repeat until \a d. |
296 | */ | 296 | */ |
297 | 297 | ||
298 | /*! | 298 | /*! |
299 | \fn void Event::setRepeatForever(bool enable) | 299 | \fn void Event::setRepeatForever(bool enable) |
300 | 300 | ||
301 | If \a enable is TRUE, sets the event to repeat forever. Otherwise | 301 | If \a enable is TRUE, sets the event to repeat forever. Otherwise |
302 | sets the event to stop repeating at some date. | 302 | sets the event to stop repeating at some date. |
303 | 303 | ||
304 | \warning This function may affect the specific date the event will repeat | 304 | \warning This function may affect the specific date the event will repeat |
305 | till. | 305 | till. |
306 | */ | 306 | */ |
307 | 307 | ||
308 | /*! | 308 | /*! |
309 | \fn bool Event::match(const QRegExp &r) const | 309 | \fn bool Event::match(const QRegExp &r) const |
310 | 310 | ||
311 | Returns TRUE if the event matches the regular expression \a r. | 311 | Returns TRUE if the event matches the regular expression \a r. |
312 | Otherwise returns FALSE. | 312 | Otherwise returns FALSE. |
313 | */ | 313 | */ |
314 | 314 | ||
315 | /*! | 315 | /*! |
316 | \fn char Event::day(int) | 316 | \fn char Event::day(int) |
317 | \internal | 317 | \internal |
318 | */ | 318 | */ |
319 | 319 | ||
320 | /*! | 320 | /*! |
321 | Creates a new, empty event. | 321 | Creates a new, empty event. |
322 | */ | 322 | */ |
323 | Event::Event() : Record() | 323 | Event::Event() : Record() |
324 | { | 324 | { |
325 | startUTC = endUTC = time( 0 ); | 325 | startUTC = endUTC = time( 0 ); |
326 | typ = Normal; | 326 | typ = Normal; |
327 | hAlarm = FALSE; | 327 | hAlarm = FALSE; |
328 | hRepeat = FALSE; | 328 | hRepeat = FALSE; |
329 | aMinutes = 0; | 329 | aMinutes = 0; |
330 | aSound = Silent; | 330 | aSound = Silent; |
331 | pattern.type = NoRepeat; | 331 | pattern.type = NoRepeat; |
332 | pattern.frequency = -1; | 332 | pattern.frequency = -1; |
333 | } | 333 | } |
334 | 334 | ||
335 | /*! | 335 | /*! |
336 | \internal | 336 | \internal |
337 | */ | 337 | */ |
338 | Event::Event( const QMap<int, QString> &map ) | 338 | Event::Event( const QMap<int, QString> &map ) |
339 | { | 339 | { |
340 | setDescription( map[DatebookDescription] ); | 340 | setDescription( map[DatebookDescription] ); |
341 | setLocation( map[Location] ); | 341 | setLocation( map[Location] ); |
342 | setCategories( idsFromString( map[DatebookCategory] ) ); | 342 | setCategories( idsFromString( map[DatebookCategory] ) ); |
343 | setTimeZone( map[TimeZone] ); | 343 | setTimeZone( map[TimeZone] ); |
344 | setNotes( map[Note] ); | 344 | setNotes( map[Note] ); |
345 | setStart( TimeConversion::fromUTC( map[StartDateTime].toUInt() ) ); | 345 | setStart( TimeConversion::fromUTC( map[StartDateTime].toUInt() ) ); |
346 | setEnd( TimeConversion::fromUTC( map[EndDateTime].toUInt() ) ); | 346 | setEnd( TimeConversion::fromUTC( map[EndDateTime].toUInt() ) ); |
347 | setType( (Event::Type) map[DatebookType].toInt() ); | 347 | setType( (Event::Type) map[DatebookType].toInt() ); |
348 | setAlarm( ( map[HasAlarm] == "1" ? TRUE : FALSE ), map[AlarmTime].toInt(), (Event::SoundTypeChoice)map[SoundType].toInt() ); | 348 | setAlarm( ( map[HasAlarm] == "1" ? TRUE : FALSE ), map[AlarmTime].toInt(), (Event::SoundTypeChoice)map[SoundType].toInt() ); |
349 | Event::RepeatPattern p; | 349 | Event::RepeatPattern p; |
350 | p.type = (Event::RepeatType) map[ RepeatPatternType ].toInt(); | 350 | p.type = (Event::RepeatType) map[ RepeatPatternType ].toInt(); |
351 | p.frequency = map[ RepeatPatternFrequency ].toInt(); | 351 | p.frequency = map[ RepeatPatternFrequency ].toInt(); |
352 | p.position = map[ RepeatPatternPosition ].toInt(); | 352 | p.position = map[ RepeatPatternPosition ].toInt(); |
353 | p.days = map[ RepeatPatternDays ].toInt(); | 353 | p.days = map[ RepeatPatternDays ].toInt(); |
354 | p.hasEndDate = map[ RepeatPatternHasEndDate ].toInt(); | 354 | p.hasEndDate = map[ RepeatPatternHasEndDate ].toInt(); |
355 | p.endDateUTC = map[ RepeatPatternEndDate ].toUInt(); | 355 | p.endDateUTC = map[ RepeatPatternEndDate ].toUInt(); |
356 | setRepeat( p ); | 356 | setRepeat( p ); |
357 | 357 | ||
358 | setUid( map[ DatebookUid ].toInt() ); | 358 | setUid( map[ DatebookUid ].toInt() ); |
359 | } | 359 | } |
360 | 360 | ||
361 | /*! | 361 | /*! |
362 | Destroys an event. | 362 | Destroys an event. |
363 | */ | 363 | */ |
364 | Event::~Event() | 364 | Event::~Event() |
365 | { | 365 | { |
366 | } | 366 | } |
367 | 367 | ||
368 | /*! | 368 | /*! |
369 | \internal | 369 | \internal |
370 | */ | 370 | */ |
371 | int Event::week( const QDate& date ) | 371 | int Event::week( const QDate& date ) |
372 | { | 372 | { |
373 | // Calculates the week this date is in within that | 373 | // Calculates the week this date is in within that |
374 | // month. Equals the "row" is is in in the month view | 374 | // month. Equals the "row" is is in in the month view |
375 | int week = 1; | 375 | int week = 1; |
376 | QDate tmp( date.year(), date.month(), 1 ); | 376 | QDate tmp( date.year(), date.month(), 1 ); |
377 | 377 | ||
378 | if ( date.dayOfWeek() < tmp.dayOfWeek() ) | 378 | if ( date.dayOfWeek() < tmp.dayOfWeek() ) |
379 | ++week; | 379 | ++week; |
380 | 380 | ||
381 | week += ( date.day() - 1 ) / 7; | 381 | week += ( date.day() - 1 ) / 7; |
382 | return week; | 382 | return week; |
383 | } | 383 | } |
384 | 384 | ||
385 | /*! | 385 | /*! |
386 | \internal | 386 | \internal |
387 | */ | 387 | */ |
388 | int Event::occurrence( const QDate& date ) | 388 | int Event::occurrence( const QDate& date ) |
389 | { | 389 | { |
390 | // calculates the number of occurrances of this day of the | 390 | // calculates the number of occurrances of this day of the |
391 | // week till the given date (e.g 3rd Wednesday of the month) | 391 | // week till the given date (e.g 3rd Wednesday of the month) |
392 | return ( date.day() - 1 ) / 7 + 1; | 392 | return ( date.day() - 1 ) / 7 + 1; |
393 | } | 393 | } |
394 | 394 | ||
395 | /*! | 395 | /*! |
396 | \internal | 396 | \internal |
397 | */ | 397 | */ |
398 | int Event::dayOfWeek( char day ) | 398 | int Event::dayOfWeek( char day ) |
399 | { | 399 | { |
400 | int dayOfWeek = 1; | 400 | int dayOfWeek = 1; |
401 | char i = Event::MON; | 401 | char i = Event::MON; |
402 | while ( !( i & day ) && i <= Event::SUN ) { | 402 | while ( !( i & day ) && i <= Event::SUN ) { |
403 | i <<= 1; | 403 | i <<= 1; |
404 | ++dayOfWeek; | 404 | ++dayOfWeek; |
405 | } | 405 | } |
406 | return dayOfWeek; | 406 | return dayOfWeek; |
407 | } | 407 | } |
408 | 408 | ||
409 | /*! | 409 | /*! |
410 | \internal | 410 | \internal |
411 | */ | 411 | */ |
412 | int Event::monthDiff( const QDate& first, const QDate& second ) | 412 | int Event::monthDiff( const QDate& first, const QDate& second ) |
413 | { | 413 | { |
414 | return ( second.year() - first.year() ) * 12 + | 414 | return ( second.year() - first.year() ) * 12 + |
415 | second.month() - first.month(); | 415 | second.month() - first.month(); |
416 | } | 416 | } |
417 | 417 | ||
418 | /*! | 418 | /*! |
419 | \internal | 419 | \internal |
420 | */ | 420 | */ |
421 | QMap<int, QString> Event::toMap() const | 421 | QMap<int, QString> Event::toMap() const |
422 | { | 422 | { |
423 | QMap<int, QString> m; | 423 | QMap<int, QString> m; |
424 | 424 | ||
425 | if ( !description().isEmpty() ) | 425 | if ( !description().isEmpty() ) |
426 | m.insert( DatebookDescription, description() ); | 426 | m.insert( DatebookDescription, description() ); |
427 | if ( !location().isEmpty() ) | 427 | if ( !location().isEmpty() ) |
428 | m.insert ( Location, location() ); | 428 | m.insert ( Location, location() ); |
429 | if ( categories().count() ) | 429 | if ( categories().count() ) |
430 | m.insert ( DatebookCategory, idsToString( categories() ) ); | 430 | m.insert ( DatebookCategory, idsToString( categories() ) ); |
431 | if ( !timeZone().isEmpty() ) | 431 | if ( !timeZone().isEmpty() ) |
432 | m.insert ( TimeZone, timeZone() ); | 432 | m.insert ( TimeZone, timeZone() ); |
433 | if ( !notes().isEmpty() ) | 433 | if ( !notes().isEmpty() ) |
434 | m.insert ( Note, notes() ); | 434 | m.insert ( Note, notes() ); |
435 | 435 | ||
436 | m.insert ( StartDateTime, QString::number( TimeConversion::toUTC( start() ) ) ); | 436 | m.insert ( StartDateTime, QString::number( TimeConversion::toUTC( start() ) ) ); |
437 | m.insert ( EndDateTime, QString::number( TimeConversion::toUTC( end() ) ) ); | 437 | m.insert ( EndDateTime, QString::number( TimeConversion::toUTC( end() ) ) ); |
438 | m.insert ( DatebookType, QString::number( (int)type() ) ); | 438 | m.insert ( DatebookType, QString::number( (int)type() ) ); |
439 | m.insert ( HasAlarm, ( hasAlarm() ? "1" : "0" ) ); | 439 | m.insert ( HasAlarm, ( hasAlarm() ? "1" : "0" ) ); |
440 | m.insert ( SoundType, QString::number( (int)alarmSound() ) ); | 440 | m.insert ( SoundType, QString::number( (int)alarmSound() ) ); |
441 | m.insert ( AlarmTime, QString::number( alarmTime() ) ); | 441 | m.insert ( AlarmTime, QString::number( alarmTime() ) ); |
442 | m.insert ( RepeatPatternType, QString::number( static_cast<int>( repeatPattern().type ) ) ); | 442 | m.insert ( RepeatPatternType, QString::number( static_cast<int>( repeatPattern().type ) ) ); |
443 | m.insert ( RepeatPatternFrequency, QString::number( repeatPattern().frequency ) ); | 443 | m.insert ( RepeatPatternFrequency, QString::number( repeatPattern().frequency ) ); |
444 | m.insert ( RepeatPatternPosition, QString::number( repeatPattern().position ) ); | 444 | m.insert ( RepeatPatternPosition, QString::number( repeatPattern().position ) ); |
445 | m.insert ( RepeatPatternDays, QString::number( repeatPattern().days ) ); | 445 | m.insert ( RepeatPatternDays, QString::number( repeatPattern().days ) ); |
446 | m.insert ( RepeatPatternHasEndDate, QString::number( static_cast<int>( repeatPattern().hasEndDate ) ) ); | 446 | m.insert ( RepeatPatternHasEndDate, QString::number( static_cast<int>( repeatPattern().hasEndDate ) ) ); |
447 | m.insert ( RepeatPatternEndDate, QString::number( repeatPattern().endDateUTC ) ); | 447 | m.insert ( RepeatPatternEndDate, QString::number( repeatPattern().endDateUTC ) ); |
448 | 448 | ||
449 | m.insert( DatebookUid, QString::number( uid()) ); | 449 | m.insert( DatebookUid, QString::number( uid()) ); |
450 | 450 | ||
451 | return m; | 451 | return m; |
452 | } | 452 | } |
453 | 453 | ||
454 | /*! | 454 | /*! |
455 | \internal | 455 | \internal |
456 | */ | 456 | */ |
457 | void Event::setRepeat( const RepeatPattern &p ) | 457 | void Event::setRepeat( const RepeatPattern &p ) |
458 | { | 458 | { |
459 | setRepeat( p.type != NoRepeat, p ); | 459 | setRepeat( p.type != NoRepeat, p ); |
460 | } | 460 | } |
461 | 461 | ||
462 | /*! | 462 | /*! |
463 | Sets the description of the event to \a s. | 463 | Sets the description of the event to \a s. |
464 | */ | 464 | */ |
465 | void Event::setDescription( const QString &s ) | 465 | void Event::setDescription( const QString &s ) |
466 | { | 466 | { |
467 | descript = s; | 467 | descript = s; |
468 | } | 468 | } |
469 | 469 | ||
470 | /*! | 470 | /*! |
471 | Sets the location of the event to \a s. | 471 | Sets the location of the event to \a s. |
472 | */ | 472 | */ |
473 | void Event::setLocation( const QString &s ) | 473 | void Event::setLocation( const QString &s ) |
474 | { | 474 | { |
475 | locat = s; | 475 | locat = s; |
476 | } | 476 | } |
477 | 477 | ||
478 | // void Event::setCategory( const QString &s ) | 478 | // void Event::setCategory( const QString &s ) |
479 | // { | 479 | // { |
480 | // categ = s; | 480 | // categ = s; |
481 | // } | 481 | // } |
482 | 482 | ||
483 | /*! | 483 | /*! |
484 | \internal | 484 | \internal |
485 | */ | 485 | */ |
486 | void Event::setType( Type t ) | 486 | void Event::setType( Type t ) |
487 | { | 487 | { |
488 | typ = t; | 488 | typ = t; |
489 | } | 489 | } |
490 | 490 | ||
491 | /*! | 491 | /*! |
492 | Sets the start date and time of the first or only occurance of this event | 492 | Sets the start date and time of the first or only occurance of this event |
493 | to the date and time \a d. \a d should be in local time. | 493 | to the date and time \a d. \a d should be in local time. |
494 | */ | 494 | */ |
495 | void Event::setStart( const QDateTime &d ) | 495 | void Event::setStart( const QDateTime &d ) |
496 | { | 496 | { |
497 | startUTC = TimeConversion::toUTC( d ); | 497 | startUTC = TimeConversion::toUTC( d ); |
498 | } | 498 | } |
499 | 499 | ||
500 | /*! | 500 | /*! |
501 | \internal | 501 | \internal |
502 | */ | 502 | */ |
503 | void Event::setStart( time_t time ) | 503 | void Event::setStart( time_t time ) |
504 | { | 504 | { |
505 | startUTC = time; | 505 | startUTC = time; |
506 | } | 506 | } |
507 | 507 | ||
508 | /*! | 508 | /*! |
509 | Sets the end date and time of the first or only occurance of this event | 509 | Sets the end date and time of the first or only occurance of this event |
510 | to the date and time \a d. \a d should be in local time. | 510 | to the date and time \a d. \a d should be in local time. |
511 | */ | 511 | */ |
512 | void Event::setEnd( const QDateTime &d ) | 512 | void Event::setEnd( const QDateTime &d ) |
513 | { | 513 | { |
514 | endUTC = TimeConversion::toUTC( d ); | 514 | endUTC = TimeConversion::toUTC( d ); |
515 | } | 515 | } |
516 | 516 | ||
517 | /*! | 517 | /*! |
518 | \internal | 518 | \internal |
519 | */ | 519 | */ |
520 | void Event::setEnd( time_t time ) | 520 | void Event::setEnd( time_t time ) |
521 | { | 521 | { |
522 | endUTC = time; | 522 | endUTC = time; |
523 | } | 523 | } |
524 | 524 | ||
525 | /*! | 525 | /*! |
526 | \internal | 526 | \internal |
527 | */ | 527 | */ |
528 | void Event::setTimeZone( const QString &z ) | 528 | void Event::setTimeZone( const QString &z ) |
529 | { | 529 | { |
530 | tz = z; | 530 | tz = z; |
531 | } | 531 | } |
532 | 532 | ||
533 | /*! | 533 | /*! |
534 | \internal | 534 | \internal |
535 | */ | 535 | */ |
536 | void Event::setAlarm( bool b, int minutes, SoundTypeChoice s ) | 536 | void Event::setAlarm( bool b, int minutes, SoundTypeChoice s ) |
537 | { | 537 | { |
538 | hAlarm = b; | 538 | hAlarm = b; |
539 | aMinutes = minutes; | 539 | aMinutes = minutes; |
540 | aSound = s; | 540 | aSound = s; |
541 | } | 541 | } |
542 | 542 | ||
543 | /*! | 543 | /*! |
544 | \internal | 544 | \internal |
545 | */ | 545 | */ |
546 | void Event::setRepeat( bool b, const RepeatPattern &p ) | 546 | void Event::setRepeat( bool b, const RepeatPattern &p ) |
547 | { | 547 | { |
548 | hRepeat = b; | 548 | hRepeat = b; |
549 | pattern = p; | 549 | pattern = p; |
550 | } | 550 | } |
551 | 551 | ||
552 | /*! | 552 | /*! |
553 | Sets the notes for the event to \a n. | 553 | Sets the notes for the event to \a n. |
554 | */ | 554 | */ |
555 | void Event::setNotes( const QString &n ) | 555 | void Event::setNotes( const QString &n ) |
556 | { | 556 | { |
557 | note = n; | 557 | note = n; |
558 | } | 558 | } |
559 | 559 | ||
560 | /*! | 560 | /*! |
561 | Returns the description of the event. | 561 | Returns the description of the event. |
562 | */ | 562 | */ |
563 | const QString &Event::description() const | 563 | const QString &Event::description() const |
564 | { | 564 | { |
565 | return descript; | 565 | return descript; |
566 | } | 566 | } |
567 | 567 | ||
568 | /*! | 568 | /*! |
569 | Returns the location of the event. | 569 | Returns the location of the event. |
570 | */ | 570 | */ |
571 | const QString &Event::location() const | 571 | const QString &Event::location() const |
572 | { | 572 | { |
573 | return locat; | 573 | return locat; |
574 | } | 574 | } |
575 | 575 | ||
576 | // QString Event::category() const | 576 | // QString Event::category() const |
577 | // { | 577 | // { |
578 | // return categ; | 578 | // return categ; |
579 | // } | 579 | // } |
580 | 580 | ||
581 | /*! | 581 | /*! |
582 | \internal | 582 | \internal |
583 | */ | 583 | */ |
584 | Event::Type Event::type() const | 584 | Event::Type Event::type() const |
585 | { | 585 | { |
586 | return typ; | 586 | return typ; |
587 | } | 587 | } |
588 | /* | ||
588 | QDateTime Event::start() const { | 589 | QDateTime Event::start() const { |
589 | return start( TRUE ); | 590 | return start( TRUE ); |
590 | } | 591 | } |
592 | */ | ||
591 | /*! | 593 | /*! |
592 | \internal | 594 | \internal |
593 | */ | 595 | */ |
594 | QDateTime Event::start( bool actual ) const | 596 | QDateTime Event::start( bool actual ) const |
595 | { | 597 | { |
596 | QDateTime dt = (startUTC > 0) ? TimeConversion::fromUTC( startUTC ) : QDateTime::currentDateTime(); | 598 | QDateTime dt = (startUTC > 0) ? TimeConversion::fromUTC( startUTC ) : QDateTime::currentDateTime(); |
597 | 599 | ||
598 | if ( actual && typ == AllDay ) { | 600 | if ( actual && typ == AllDay ) { |
599 | QTime t = dt.time(); | 601 | QTime t = dt.time(); |
600 | t.setHMS( 0, 0, 0 ); | 602 | t.setHMS( 0, 0, 0 ); |
601 | dt.setTime( t ); | 603 | dt.setTime( t ); |
602 | } | 604 | } |
603 | return dt; | 605 | return dt; |
604 | } | 606 | } |
605 | 607 | /* | |
606 | QDateTime Event::end() const { | 608 | QDateTime Event::end() const { |
607 | return end( TRUE ); | 609 | return end( TRUE ); |
608 | } | 610 | } |
611 | */ | ||
609 | /*! | 612 | /*! |
610 | \internal | 613 | \internal |
611 | */ | 614 | */ |
612 | QDateTime Event::end( bool actual ) const | 615 | QDateTime Event::end( bool actual ) const |
613 | { | 616 | { |
614 | QDateTime dt = (endUTC > 0) ? TimeConversion::fromUTC( endUTC ) : QDateTime::currentDateTime(); | 617 | QDateTime dt = (endUTC > 0) ? TimeConversion::fromUTC( endUTC ) : QDateTime::currentDateTime(); |
615 | 618 | ||
616 | if ( actual && typ == AllDay ) { | 619 | if ( actual && typ == AllDay ) { |
617 | QTime t = dt.time(); | 620 | QTime t = dt.time(); |
618 | t.setHMS( 23, 59, 59 ); | 621 | t.setHMS( 23, 59, 59 ); |
619 | dt.setTime( t ); | 622 | dt.setTime( t ); |
620 | } | 623 | } |
621 | return dt; | 624 | return dt; |
622 | } | 625 | } |
623 | 626 | ||
624 | /*! | 627 | /*! |
625 | \internal | 628 | \internal |
626 | */ | 629 | */ |
627 | const QString &Event::timeZone() const | 630 | const QString &Event::timeZone() const |
628 | { | 631 | { |
629 | return tz; | 632 | return tz; |
630 | } | 633 | } |
631 | 634 | ||
632 | /*! | 635 | /*! |
633 | \internal | 636 | \internal |
634 | */ | 637 | */ |
635 | bool Event::hasAlarm() const | 638 | bool Event::hasAlarm() const |
636 | { | 639 | { |
637 | return hAlarm; | 640 | return hAlarm; |
638 | } | 641 | } |
639 | 642 | ||
640 | /*! | 643 | /*! |
641 | \internal | 644 | \internal |
642 | */ | 645 | */ |
643 | int Event::alarmTime() const | 646 | int Event::alarmTime() const |
644 | { | 647 | { |
645 | return aMinutes; | 648 | return aMinutes; |
646 | } | 649 | } |
647 | 650 | ||
648 | /*! | 651 | /*! |
649 | Returns the sound type for the alarm of this event. | 652 | Returns the sound type for the alarm of this event. |
650 | */ | 653 | */ |
651 | Event::SoundTypeChoice Event::alarmSound() const | 654 | Event::SoundTypeChoice Event::alarmSound() const |
652 | { | 655 | { |
653 | return aSound; | 656 | return aSound; |
654 | } | 657 | } |
655 | 658 | ||
656 | /*! | 659 | /*! |
657 | \internal | 660 | \internal |
658 | */ | 661 | */ |
659 | bool Event::hasRepeat() const | 662 | bool Event::hasRepeat() const |
660 | { | 663 | { |
661 | return doRepeat(); | 664 | return doRepeat(); |
662 | } | 665 | } |
663 | 666 | ||
664 | /*! | 667 | /*! |
665 | \internal | 668 | \internal |
666 | */ | 669 | */ |
667 | const Event::RepeatPattern &Event::repeatPattern() const | 670 | const Event::RepeatPattern &Event::repeatPattern() const |
668 | { | 671 | { |
669 | return pattern; | 672 | return pattern; |
670 | } | 673 | } |
671 | 674 | ||
672 | /*! | 675 | /*! |
673 | \internal | 676 | \internal |
674 | */ | 677 | */ |
675 | Event::RepeatPattern &Event::repeatPattern() | 678 | Event::RepeatPattern &Event::repeatPattern() |
676 | { | 679 | { |
677 | return pattern; | 680 | return pattern; |
678 | } | 681 | } |
679 | 682 | ||
680 | /*! | 683 | /*! |
681 | Returns the notes for the event. | 684 | Returns the notes for the event. |
682 | */ | 685 | */ |
683 | const QString &Event::notes() const | 686 | const QString &Event::notes() const |
684 | { | 687 | { |
685 | return note; | 688 | return note; |
686 | } | 689 | } |
687 | 690 | ||
688 | /*! | 691 | /*! |
689 | \internal | 692 | \internal |
690 | */ | 693 | */ |
691 | bool Event::operator==( const Event &e ) const | 694 | bool Event::operator==( const Event &e ) const |
692 | { | 695 | { |
693 | if ( uid() && e.uid() == uid() ) | 696 | if ( uid() && e.uid() == uid() ) |
694 | return TRUE; | 697 | return TRUE; |
695 | return ( e.descript == descript && | 698 | return ( e.descript == descript && |
696 | e.locat == locat && | 699 | e.locat == locat && |
697 | e.categ == categ && | 700 | e.categ == categ && |
698 | e.typ == typ && | 701 | e.typ == typ && |
699 | e.startUTC == startUTC && | 702 | e.startUTC == startUTC && |
700 | e.endUTC == endUTC && | 703 | e.endUTC == endUTC && |
701 | e.tz == tz && | 704 | e.tz == tz && |
702 | e.hAlarm == hAlarm && | 705 | e.hAlarm == hAlarm && |
703 | e.aMinutes == aMinutes && | 706 | e.aMinutes == aMinutes && |
704 | e.aSound == aSound && | 707 | e.aSound == aSound && |
705 | e.hRepeat == hRepeat && | 708 | e.hRepeat == hRepeat && |
706 | e.pattern == pattern && | 709 | e.pattern == pattern && |
707 | e.note == note ); | 710 | e.note == note ); |
708 | } | 711 | } |
709 | 712 | ||
710 | /*! | 713 | /*! |
711 | \internal | 714 | \internal |
712 | Appends the contact information to \a buf. | 715 | Appends the contact information to \a buf. |
713 | */ | 716 | */ |
714 | void Event::save( QString& buf ) | 717 | void Event::save( QString& buf ) |
715 | { | 718 | { |
716 | buf += " description=\"" + Qtopia::escapeString(descript) + "\""; | 719 | buf += " description=\"" + Qtopia::escapeString(descript) + "\""; |
717 | if ( !locat.isEmpty() ) | 720 | if ( !locat.isEmpty() ) |
718 | buf += " location=\"" + Qtopia::escapeString(locat) + "\""; | 721 | buf += " location=\"" + Qtopia::escapeString(locat) + "\""; |
719 | // save the categoies differently.... | 722 | // save the categoies differently.... |
720 | QString strCats = idsToString( categories() ); | 723 | QString strCats = idsToString( categories() ); |
721 | buf += " categories=\"" + Qtopia::escapeString(strCats) + "\""; | 724 | buf += " categories=\"" + Qtopia::escapeString(strCats) + "\""; |
722 | buf += " uid=\"" + QString::number( uid() ) + "\""; | 725 | buf += " uid=\"" + QString::number( uid() ) + "\""; |
723 | if ( (Type)typ != Normal ) | 726 | if ( (Type)typ != Normal ) |
724 | buf += " type=\"AllDay\""; | 727 | buf += " type=\"AllDay\""; |
725 | if ( hAlarm ) { | 728 | if ( hAlarm ) { |
726 | buf += " alarm=\"" + QString::number( aMinutes ) + "\" sound=\""; | 729 | buf += " alarm=\"" + QString::number( aMinutes ) + "\" sound=\""; |
727 | if ( aSound == Event::Loud ) | 730 | if ( aSound == Event::Loud ) |
728 | buf += "loud"; | 731 | buf += "loud"; |
729 | else | 732 | else |
730 | buf += "silent"; | 733 | buf += "silent"; |
731 | buf += "\""; | 734 | buf += "\""; |
732 | } | 735 | } |
733 | if ( hRepeat ) | 736 | if ( hRepeat ) |
734 | write( buf, pattern ); | 737 | write( buf, pattern ); |
735 | 738 | ||
736 | buf += " start=\"" | 739 | buf += " start=\"" |
737 | + QString::number( startUTC ) | 740 | + QString::number( startUTC ) |
738 | + "\""; | 741 | + "\""; |
739 | 742 | ||
740 | buf += " end=\"" | 743 | buf += " end=\"" |
741 | + QString::number( endUTC ) | 744 | + QString::number( endUTC ) |
742 | + "\""; | 745 | + "\""; |
743 | 746 | ||
744 | if ( !note.isEmpty() ) | 747 | if ( !note.isEmpty() ) |
745 | buf += " note=\"" + Qtopia::escapeString( note ) + "\""; | 748 | buf += " note=\"" + Qtopia::escapeString( note ) + "\""; |
746 | buf += customToXml(); | 749 | buf += customToXml(); |
747 | } | 750 | } |
748 | 751 | ||
749 | /*! | 752 | /*! |
750 | \internal | 753 | \internal |
751 | */ | 754 | */ |
752 | bool Event::RepeatPattern::operator==( const Event::RepeatPattern &right ) const | 755 | bool Event::RepeatPattern::operator==( const Event::RepeatPattern &right ) const |
753 | { | 756 | { |
754 | // *sigh* | 757 | // *sigh* |
755 | return ( type == right.type | 758 | return ( type == right.type |
756 | && frequency == right.frequency | 759 | && frequency == right.frequency |
757 | && position == right.position | 760 | && position == right.position |
758 | && days == right.days | 761 | && days == right.days |
759 | && hasEndDate == right.hasEndDate | 762 | && hasEndDate == right.hasEndDate |
760 | && endDateUTC == right.endDateUTC | 763 | && endDateUTC == right.endDateUTC |
761 | && createTime == right.createTime ); | 764 | && createTime == right.createTime ); |
762 | } | 765 | } |
763 | 766 | ||
764 | /*! | 767 | /*! |
765 | \class EffectiveEvent | 768 | \class EffectiveEvent |
766 | \brief The EffectiveEvent class the data for a single occurance of an event. | 769 | \brief The EffectiveEvent class the data for a single occurance of an event. |
767 | 770 | ||
768 | This class describes the event for a single occurance of it. For example if | 771 | This class describes the event for a single occurance of it. For example if |
769 | an Event occurs every week, the effective event might represent the third | 772 | an Event occurs every week, the effective event might represent the third |
770 | occurance of this Event. | 773 | occurance of this Event. |
771 | 774 | ||
772 | \ingroup qtopiaemb | 775 | \ingroup qtopiaemb |
773 | \ingroup qtopiadesktop | 776 | \ingroup qtopiadesktop |
774 | \warning This class will be phased out in Qtopia 3.x | 777 | \warning This class will be phased out in Qtopia 3.x |
775 | */ | 778 | */ |
776 | 779 | ||
777 | /*! | 780 | /*! |
778 | \enum EffectiveEvent::Position | 781 | \enum EffectiveEvent::Position |
779 | \internal | 782 | \internal |
780 | */ | 783 | */ |
781 | 784 | ||
782 | /*! | 785 | /*! |
783 | \fn EffectiveEvent &EffectiveEvent::operator=(const EffectiveEvent &) | 786 | \fn EffectiveEvent &EffectiveEvent::operator=(const EffectiveEvent &) |
784 | \internal | 787 | \internal |
785 | */ | 788 | */ |
786 | 789 | ||
787 | class EffectiveEventPrivate | 790 | class EffectiveEventPrivate |
788 | { | 791 | { |
789 | public: | 792 | public: |
790 | //currently the existence of the d pointer means multi-day repeating, | 793 | //currently the existence of the d pointer means multi-day repeating, |
791 | //msut be changed if we use the d pointer for anything else. | 794 | //msut be changed if we use the d pointer for anything else. |
792 | QDate startDate; | 795 | QDate startDate; |
793 | QDate endDate; | 796 | QDate endDate; |
794 | }; | 797 | }; |
795 | 798 | ||
796 | /*! | 799 | /*! |
797 | \internal | 800 | \internal |
798 | */ | 801 | */ |
799 | EffectiveEvent::EffectiveEvent() | 802 | EffectiveEvent::EffectiveEvent() |
800 | { | 803 | { |
801 | mDate = QDate::currentDate(); | 804 | mDate = QDate::currentDate(); |
802 | mStart = mEnd = QTime::currentTime(); | 805 | mStart = mEnd = QTime::currentTime(); |
803 | d = 0; | 806 | d = 0; |
804 | } | 807 | } |
805 | 808 | ||
806 | /*! | 809 | /*! |
807 | \internal | 810 | \internal |
808 | */ | 811 | */ |
809 | EffectiveEvent::EffectiveEvent( const Event &e, const QDate &date, Position pos ) | 812 | EffectiveEvent::EffectiveEvent( const Event &e, const QDate &date, Position pos ) |
810 | { | 813 | { |
811 | mEvent = e; | 814 | mEvent = e; |
812 | mDate = date; | 815 | mDate = date; |
813 | if ( pos & Start ) | 816 | if ( pos & Start ) |
814 | mStart = e.start( TRUE ).time(); | 817 | mStart = e.start( TRUE ).time(); |
815 | else | 818 | else |
816 | mStart = QTime( 0, 0, 0 ); | 819 | mStart = QTime( 0, 0, 0 ); |
817 | 820 | ||
818 | if ( pos & End ) | 821 | if ( pos & End ) |
819 | mEnd = e.end( TRUE ).time(); | 822 | mEnd = e.end( TRUE ).time(); |
820 | else | 823 | else |
821 | mEnd = QTime( 23, 59, 59 ); | 824 | mEnd = QTime( 23, 59, 59 ); |
822 | d = 0; | 825 | d = 0; |
823 | } | 826 | } |
824 | 827 | ||
825 | /*! | 828 | /*! |
826 | \internal | 829 | \internal |
827 | */ | 830 | */ |
828 | EffectiveEvent::~EffectiveEvent() | 831 | EffectiveEvent::~EffectiveEvent() |
829 | { | 832 | { |
830 | delete d; | 833 | delete d; |
831 | } | 834 | } |
832 | 835 | ||
833 | /*! | 836 | /*! |
834 | \internal | 837 | \internal |
835 | */ | 838 | */ |
836 | EffectiveEvent::EffectiveEvent( const EffectiveEvent &e ) | 839 | EffectiveEvent::EffectiveEvent( const EffectiveEvent &e ) |
837 | { | 840 | { |
838 | d = 0; | 841 | d = 0; |
839 | *this = e; | 842 | *this = e; |
840 | } | 843 | } |
841 | 844 | ||
842 | EffectiveEvent& EffectiveEvent::operator=( const EffectiveEvent & e ) | 845 | EffectiveEvent& EffectiveEvent::operator=( const EffectiveEvent & e ) |
843 | { | 846 | { |
844 | if ( &e == this ) | 847 | if ( &e == this ) |
845 | return *this; | 848 | return *this; |
846 | delete d; | 849 | delete d; |
847 | if ( e.d ) { | 850 | if ( e.d ) { |
848 | d = new EffectiveEventPrivate; | 851 | d = new EffectiveEventPrivate; |
849 | d->startDate = e.d->startDate; | 852 | d->startDate = e.d->startDate; |
850 | d->endDate = e.d->endDate; | 853 | d->endDate = e.d->endDate; |
851 | } else { | 854 | } else { |
852 | d = 0; | 855 | d = 0; |
853 | } | 856 | } |
854 | mEvent = e.mEvent; | 857 | mEvent = e.mEvent; |
855 | mDate = e.mDate; | 858 | mDate = e.mDate; |
856 | mStart = e.mStart; | 859 | mStart = e.mStart; |
857 | mEnd = e.mEnd; | 860 | mEnd = e.mEnd; |
858 | 861 | ||
859 | return *this; | 862 | return *this; |
860 | 863 | ||
861 | } | 864 | } |
862 | 865 | ||
863 | // QString EffectiveEvent::category() const | 866 | // QString EffectiveEvent::category() const |
864 | // { | 867 | // { |
865 | // return mEvent.category(); | 868 | // return mEvent.category(); |
866 | // } | 869 | // } |
867 | 870 | ||
868 | /*! | 871 | /*! |
869 | Returns the description of the event for this effective event. | 872 | Returns the description of the event for this effective event. |
870 | */ | 873 | */ |
871 | const QString &EffectiveEvent::description( ) const | 874 | const QString &EffectiveEvent::description( ) const |
872 | { | 875 | { |
873 | return mEvent.description(); | 876 | return mEvent.description(); |
874 | } | 877 | } |
875 | 878 | ||
876 | /*! | 879 | /*! |
877 | \internal | 880 | \internal |
878 | */ | 881 | */ |
879 | const QString &EffectiveEvent::location( ) const | 882 | const QString &EffectiveEvent::location( ) const |
880 | { | 883 | { |
881 | return mEvent.location(); | 884 | return mEvent.location(); |
882 | } | 885 | } |
883 | 886 | ||
884 | /*! | 887 | /*! |
885 | \internal | 888 | \internal |
886 | */ | 889 | */ |
887 | const QString &EffectiveEvent::notes() const | 890 | const QString &EffectiveEvent::notes() const |
888 | { | 891 | { |
889 | return mEvent.notes(); | 892 | return mEvent.notes(); |
890 | } | 893 | } |
891 | 894 | ||
892 | /*! | 895 | /*! |
893 | Returns the event associated with this effective event. | 896 | Returns the event associated with this effective event. |
894 | */ | 897 | */ |
895 | const Event &EffectiveEvent::event() const | 898 | const Event &EffectiveEvent::event() const |
896 | { | 899 | { |
897 | return mEvent; | 900 | return mEvent; |
898 | } | 901 | } |
899 | 902 | ||
900 | /*! | 903 | /*! |
901 | \internal | 904 | \internal |
902 | */ | 905 | */ |
903 | const QTime &EffectiveEvent::end() const | 906 | const QTime &EffectiveEvent::end() const |
904 | { | 907 | { |
905 | return mEnd; | 908 | return mEnd; |
906 | } | 909 | } |
907 | 910 | ||
908 | /*! | 911 | /*! |
909 | \internal | 912 | \internal |
910 | */ | 913 | */ |
911 | const QTime &EffectiveEvent::start() const | 914 | const QTime &EffectiveEvent::start() const |
912 | { | 915 | { |
913 | return mStart; | 916 | return mStart; |
914 | } | 917 | } |
915 | 918 | ||
916 | /*! | 919 | /*! |
917 | Returns the date the effective event occurs on. | 920 | Returns the date the effective event occurs on. |
918 | */ | 921 | */ |
919 | const QDate &EffectiveEvent::date() const | 922 | const QDate &EffectiveEvent::date() const |
920 | { | 923 | { |
921 | return mDate; | 924 | return mDate; |
922 | } | 925 | } |
923 | 926 | ||
924 | /*! | 927 | /*! |
925 | \internal | 928 | \internal |
926 | */ | 929 | */ |
927 | int EffectiveEvent::length() const | 930 | int EffectiveEvent::length() const |
928 | { | 931 | { |
929 | return (mEnd.hour() * 60 - mStart.hour() * 60) | 932 | return (mEnd.hour() * 60 - mStart.hour() * 60) |
930 | + QABS(mStart.minute() - mEnd.minute() ); | 933 | + QABS(mStart.minute() - mEnd.minute() ); |
931 | } | 934 | } |
932 | 935 | ||
933 | /*! | 936 | /*! |
934 | \internal | 937 | \internal |
935 | */ | 938 | */ |
936 | void EffectiveEvent::setDate( const QDate &dt ) | 939 | void EffectiveEvent::setDate( const QDate &dt ) |
937 | { | 940 | { |
938 | mDate = dt; | 941 | mDate = dt; |
939 | } | 942 | } |
940 | 943 | ||
941 | /*! | 944 | /*! |
942 | \internal | 945 | \internal |
943 | */ | 946 | */ |
944 | void EffectiveEvent::setStart( const QTime &start ) | 947 | void EffectiveEvent::setStart( const QTime &start ) |
945 | { | 948 | { |
946 | mStart = start; | 949 | mStart = start; |
947 | } | 950 | } |
948 | 951 | ||
949 | /*! | 952 | /*! |
950 | \internal | 953 | \internal |
951 | */ | 954 | */ |
952 | void EffectiveEvent::setEnd( const QTime &end ) | 955 | void EffectiveEvent::setEnd( const QTime &end ) |
953 | { | 956 | { |
954 | mEnd = end; | 957 | mEnd = end; |
955 | } | 958 | } |
956 | 959 | ||
957 | /*! | 960 | /*! |
958 | \internal | 961 | \internal |
959 | */ | 962 | */ |
960 | void EffectiveEvent::setEvent( Event e ) | 963 | void EffectiveEvent::setEvent( Event e ) |
961 | { | 964 | { |
962 | mEvent = e; | 965 | mEvent = e; |
963 | } | 966 | } |
964 | 967 | ||
965 | /*! | 968 | /*! |
966 | \internal | 969 | \internal |
967 | */ | 970 | */ |
968 | bool EffectiveEvent::operator<( const EffectiveEvent &e ) const | 971 | bool EffectiveEvent::operator<( const EffectiveEvent &e ) const |
969 | { | 972 | { |
970 | if ( mDate < e.date() ) | 973 | if ( mDate < e.date() ) |
971 | return TRUE; | 974 | return TRUE; |
972 | if ( mDate == e.date() ) | 975 | if ( mDate == e.date() ) |
973 | return ( mStart < e.start() ); | 976 | return ( mStart < e.start() ); |
974 | else | 977 | else |
975 | return FALSE; | 978 | return FALSE; |
976 | } | 979 | } |
977 | 980 | ||
978 | /*! | 981 | /*! |
979 | \internal | 982 | \internal |
980 | */ | 983 | */ |
981 | bool EffectiveEvent::operator<=( const EffectiveEvent &e ) const | 984 | bool EffectiveEvent::operator<=( const EffectiveEvent &e ) const |
982 | { | 985 | { |
983 | return (mDate <= e.date() ); | 986 | return (mDate <= e.date() ); |
984 | } | 987 | } |
985 | 988 | ||
986 | /*! | 989 | /*! |
987 | \internal | 990 | \internal |
988 | */ | 991 | */ |
989 | bool EffectiveEvent::operator==( const EffectiveEvent &e ) const | 992 | bool EffectiveEvent::operator==( const EffectiveEvent &e ) const |
990 | { | 993 | { |
991 | return ( mDate == e.date() | 994 | return ( mDate == e.date() |
992 | && mStart == e.start() | 995 | && mStart == e.start() |
993 | && mEnd == e.end() | 996 | && mEnd == e.end() |
994 | && mEvent == e.event() ); | 997 | && mEvent == e.event() ); |
995 | } | 998 | } |
996 | 999 | ||
997 | /*! | 1000 | /*! |
998 | \internal | 1001 | \internal |
999 | */ | 1002 | */ |
1000 | bool EffectiveEvent::operator!=( const EffectiveEvent &e ) const | 1003 | bool EffectiveEvent::operator!=( const EffectiveEvent &e ) const |
1001 | { | 1004 | { |
1002 | return !(*this == e); | 1005 | return !(*this == e); |
1003 | } | 1006 | } |
1004 | 1007 | ||
1005 | /*! | 1008 | /*! |
1006 | \internal | 1009 | \internal |
1007 | */ | 1010 | */ |
1008 | bool EffectiveEvent::operator>( const EffectiveEvent &e ) const | 1011 | bool EffectiveEvent::operator>( const EffectiveEvent &e ) const |
1009 | { | 1012 | { |
1010 | return !(*this <= e ); | 1013 | return !(*this <= e ); |
1011 | } | 1014 | } |
1012 | 1015 | ||
1013 | /*! | 1016 | /*! |
1014 | \internal | 1017 | \internal |
1015 | */ | 1018 | */ |
1016 | bool EffectiveEvent::operator>=(const EffectiveEvent &e) const | 1019 | bool EffectiveEvent::operator>=(const EffectiveEvent &e) const |
1017 | { | 1020 | { |
1018 | return !(*this < e); | 1021 | return !(*this < e); |
1019 | } | 1022 | } |
1020 | 1023 | ||
1021 | /*! | 1024 | /*! |
1022 | \internal | 1025 | \internal |
1023 | */ | 1026 | */ |
1024 | void EffectiveEvent::setEffectiveDates( const QDate &from, const QDate &to ) | 1027 | void EffectiveEvent::setEffectiveDates( const QDate &from, const QDate &to ) |
1025 | { | 1028 | { |
1026 | if ( !from.isValid() ) { | 1029 | if ( !from.isValid() ) { |
1027 | delete d; | 1030 | delete d; |
1028 | d = 0; | 1031 | d = 0; |
1029 | return; | 1032 | return; |
1030 | } | 1033 | } |
1031 | if ( !d ) | 1034 | if ( !d ) |
1032 | d = new EffectiveEventPrivate; | 1035 | d = new EffectiveEventPrivate; |
1033 | d->startDate = from; | 1036 | d->startDate = from; |
1034 | d->endDate = to; | 1037 | d->endDate = to; |
1035 | } | 1038 | } |
1036 | 1039 | ||
1037 | /*! | 1040 | /*! |
1038 | \internal | 1041 | \internal |
1039 | */ | 1042 | */ |
1040 | QDate EffectiveEvent::startDate() const | 1043 | QDate EffectiveEvent::startDate() const |
1041 | { | 1044 | { |
1042 | if ( d ) | 1045 | if ( d ) |
1043 | return d->startDate; | 1046 | return d->startDate; |
1044 | else if ( mEvent.hasRepeat() ) | 1047 | else if ( mEvent.hasRepeat() ) |
1045 | return mDate; // single day, since multi-day should have a d pointer | 1048 | return mDate; // single day, since multi-day should have a d pointer |
1046 | else | 1049 | else |
1047 | return mEvent.start().date(); | 1050 | return mEvent.start().date(); |
1048 | } | 1051 | } |
1049 | 1052 | ||
1050 | /*! | 1053 | /*! |
1051 | \internal | 1054 | \internal |
1052 | */ | 1055 | */ |
1053 | QDate EffectiveEvent::endDate() const | 1056 | QDate EffectiveEvent::endDate() const |
1054 | { | 1057 | { |
1055 | if ( d ) | 1058 | if ( d ) |
1056 | return d->endDate; | 1059 | return d->endDate; |
1057 | else if ( mEvent.hasRepeat() ) | 1060 | else if ( mEvent.hasRepeat() ) |
1058 | return mDate; // single day, since multi-day should have a d pointer | 1061 | return mDate; // single day, since multi-day should have a d pointer |
1059 | else | 1062 | else |
1060 | return mEvent.end().date(); | 1063 | return mEvent.end().date(); |
1061 | } | 1064 | } |
1062 | 1065 | ||
1063 | /*! | 1066 | /*! |
1064 | \internal | 1067 | \internal |
1065 | */ | 1068 | */ |
1066 | int EffectiveEvent::size() const | 1069 | int EffectiveEvent::size() const |
1067 | { | 1070 | { |
1068 | return ( mEnd.hour() - mStart.hour() ) * 3600 | 1071 | return ( mEnd.hour() - mStart.hour() ) * 3600 |
1069 | + (mEnd.minute() - mStart.minute() * 60 | 1072 | + (mEnd.minute() - mStart.minute() * 60 |
1070 | + mEnd.second() - mStart.second() ); | 1073 | + mEnd.second() - mStart.second() ); |
1071 | } | 1074 | } |
1072 | 1075 | ||
1073 | 1076 | ||
1074 | // vcal conversion code | 1077 | // vcal conversion code |
1075 | static inline VObject *safeAddPropValue( VObject *o, const char *prop, const QString &value ) | 1078 | static inline VObject *safeAddPropValue( VObject *o, const char *prop, const QString &value ) |
1076 | { | 1079 | { |
1077 | VObject *ret = 0; | 1080 | VObject *ret = 0; |
1078 | if ( o && !value.isEmpty() ) | 1081 | if ( o && !value.isEmpty() ) |
1079 | ret = addPropValue( o, prop, value.latin1() ); | 1082 | ret = addPropValue( o, prop, value.latin1() ); |
1080 | return ret; | 1083 | return ret; |
1081 | } | 1084 | } |
1082 | 1085 | ||
1083 | static inline VObject *safeAddProp( VObject *o, const char *prop) | 1086 | static inline VObject *safeAddProp( VObject *o, const char *prop) |
1084 | { | 1087 | { |
1085 | VObject *ret = 0; | 1088 | VObject *ret = 0; |
1086 | if ( o ) | 1089 | if ( o ) |
1087 | ret = addProp( o, prop ); | 1090 | ret = addProp( o, prop ); |
1088 | return ret; | 1091 | return ret; |
1089 | } | 1092 | } |
1090 | 1093 | ||
1091 | static VObject *createVObject( const Event &e ) | 1094 | static VObject *createVObject( const Event &e ) |
1092 | { | 1095 | { |
1093 | VObject *vcal = newVObject( VCCalProp ); | 1096 | VObject *vcal = newVObject( VCCalProp ); |
1094 | safeAddPropValue( vcal, VCVersionProp, "1.0" ); | 1097 | safeAddPropValue( vcal, VCVersionProp, "1.0" ); |
1095 | VObject *event = safeAddProp( vcal, VCEventProp ); | 1098 | VObject *event = safeAddProp( vcal, VCEventProp ); |
1096 | 1099 | ||
1097 | safeAddPropValue( event, VCDTstartProp, TimeConversion::toISO8601( e.start() ) ); | 1100 | safeAddPropValue( event, VCDTstartProp, TimeConversion::toISO8601( e.start() ) ); |
1098 | safeAddPropValue( event, VCDTendProp, TimeConversion::toISO8601( e.end() ) ); | 1101 | safeAddPropValue( event, VCDTendProp, TimeConversion::toISO8601( e.end() ) ); |
1099 | safeAddPropValue( event, "X-Qtopia-NOTES", e.description() ); | 1102 | safeAddPropValue( event, "X-Qtopia-NOTES", e.description() ); |
1100 | safeAddPropValue( event, VCDescriptionProp, e.description() ); | 1103 | safeAddPropValue( event, VCDescriptionProp, e.description() ); |
1101 | safeAddPropValue( event, VCLocationProp, e.location() ); | 1104 | safeAddPropValue( event, VCLocationProp, e.location() ); |
1102 | 1105 | ||
1103 | if ( e.hasAlarm() ) { | 1106 | if ( e.hasAlarm() ) { |
1104 | VObject *alarm = safeAddProp( event, VCAAlarmProp ); | 1107 | VObject *alarm = safeAddProp( event, VCAAlarmProp ); |
1105 | QDateTime dt = e.start(); | 1108 | QDateTime dt = e.start(); |
1106 | dt = dt.addSecs( -e.alarmTime()*60 ); | 1109 | dt = dt.addSecs( -e.alarmTime()*60 ); |
1107 | safeAddPropValue( alarm, VCRunTimeProp, TimeConversion::toISO8601( dt ) ); | 1110 | safeAddPropValue( alarm, VCRunTimeProp, TimeConversion::toISO8601( dt ) ); |
1108 | safeAddPropValue( alarm, VCAudioContentProp, | 1111 | safeAddPropValue( alarm, VCAudioContentProp, |
1109 | (e.alarmSound() == Event::Silent ? "silent" : "alarm" ) ); | 1112 | (e.alarmSound() == Event::Silent ? "silent" : "alarm" ) ); |
1110 | } | 1113 | } |
1111 | 1114 | ||
1112 | safeAddPropValue( event, "X-Qtopia-TIMEZONE", e.timeZone() ); | 1115 | safeAddPropValue( event, "X-Qtopia-TIMEZONE", e.timeZone() ); |
1113 | 1116 | ||
1114 | if ( e.type() == Event::AllDay ) | 1117 | if ( e.type() == Event::AllDay ) |
1115 | safeAddPropValue( event, "X-Qtopia-AllDay", e.timeZone() ); | 1118 | safeAddPropValue( event, "X-Qtopia-AllDay", e.timeZone() ); |
1116 | 1119 | ||
1117 | // ### repeat missing | 1120 | // ### repeat missing |
1118 | 1121 | ||
1119 | // ### categories missing | 1122 | // ### categories missing |
1120 | 1123 | ||
1121 | return vcal; | 1124 | return vcal; |
1122 | } | 1125 | } |
1123 | 1126 | ||
1124 | 1127 | ||
1125 | static Event parseVObject( VObject *obj ) | 1128 | static Event parseVObject( VObject *obj ) |
1126 | { | 1129 | { |
1127 | Event e; | 1130 | Event e; |
1128 | 1131 | ||
1129 | bool haveAlarm = FALSE; | 1132 | bool haveAlarm = FALSE; |
1130 | bool haveStart = FALSE; | 1133 | bool haveStart = FALSE; |
1131 | bool haveEnd = FALSE; | 1134 | bool haveEnd = FALSE; |
1132 | QDateTime alarmTime; | 1135 | QDateTime alarmTime; |
1133 | Event::SoundTypeChoice soundType = Event::Silent; | 1136 | Event::SoundTypeChoice soundType = Event::Silent; |
1134 | 1137 | ||
1135 | VObjectIterator it; | 1138 | VObjectIterator it; |
1136 | initPropIterator( &it, obj ); | 1139 | initPropIterator( &it, obj ); |
1137 | while( moreIteration( &it ) ) { | 1140 | while( moreIteration( &it ) ) { |
1138 | VObject *o = nextVObject( &it ); | 1141 | VObject *o = nextVObject( &it ); |
1139 | QCString name = vObjectName( o ); | 1142 | QCString name = vObjectName( o ); |
1140 | QCString value = vObjectStringZValue( o ); | 1143 | QCString value = vObjectStringZValue( o ); |
1141 | if ( name == VCDTstartProp ) { | 1144 | if ( name == VCDTstartProp ) { |
1142 | e.setStart( TimeConversion::fromISO8601( value ) ); | 1145 | e.setStart( TimeConversion::fromISO8601( value ) ); |
1143 | haveStart = TRUE; | 1146 | haveStart = TRUE; |
1144 | } | 1147 | } |
1145 | else if ( name == VCDTendProp ) { | 1148 | else if ( name == VCDTendProp ) { |
1146 | e.setEnd( TimeConversion::fromISO8601( value ) ); | 1149 | e.setEnd( TimeConversion::fromISO8601( value ) ); |
1147 | haveEnd = TRUE; | 1150 | haveEnd = TRUE; |
1148 | } | 1151 | } |
1149 | else if ( name == "X-Qtopia-NOTES" ) { | 1152 | else if ( name == "X-Qtopia-NOTES" ) { |
1150 | e.setNotes( value ); | 1153 | e.setNotes( value ); |
1151 | } | 1154 | } |
1152 | else if ( name == VCDescriptionProp ) { | 1155 | else if ( name == VCDescriptionProp ) { |
1153 | e.setDescription( value ); | 1156 | e.setDescription( value ); |
1154 | } | 1157 | } |
1155 | else if ( name == VCLocationProp ) { | 1158 | else if ( name == VCLocationProp ) { |
1156 | e.setLocation( value ); | 1159 | e.setLocation( value ); |
1157 | } | 1160 | } |
1158 | else if ( name == VCAudioContentProp ) { | 1161 | else if ( name == VCAudioContentProp ) { |
1159 | haveAlarm = TRUE; | 1162 | haveAlarm = TRUE; |
1160 | VObjectIterator nit; | 1163 | VObjectIterator nit; |
1161 | initPropIterator( &nit, o ); | 1164 | initPropIterator( &nit, o ); |
1162 | while( moreIteration( &nit ) ) { | 1165 | while( moreIteration( &nit ) ) { |
1163 | VObject *o = nextVObject( &nit ); | 1166 | VObject *o = nextVObject( &nit ); |
1164 | QCString name = vObjectName( o ); | 1167 | QCString name = vObjectName( o ); |
1165 | QCString value = vObjectStringZValue( o ); | 1168 | QCString value = vObjectStringZValue( o ); |
1166 | if ( name == VCRunTimeProp ) | 1169 | if ( name == VCRunTimeProp ) |
1167 | alarmTime = TimeConversion::fromISO8601( value ); | 1170 | alarmTime = TimeConversion::fromISO8601( value ); |
1168 | else if ( name == VCAudioContentProp ) { | 1171 | else if ( name == VCAudioContentProp ) { |
1169 | if ( value == "silent" ) | 1172 | if ( value == "silent" ) |
1170 | soundType = Event::Silent; | 1173 | soundType = Event::Silent; |
1171 | else | 1174 | else |
1172 | soundType = Event::Loud; | 1175 | soundType = Event::Loud; |
1173 | } | 1176 | } |
1174 | } | 1177 | } |
1175 | } | 1178 | } |
1176 | else if ( name == "X-Qtopia-TIMEZONE") { | 1179 | else if ( name == "X-Qtopia-TIMEZONE") { |
1177 | e.setTimeZone( value ); | 1180 | e.setTimeZone( value ); |
1178 | } | 1181 | } |
1179 | else if ( name == "X-Qtopia-AllDay" ) { | 1182 | else if ( name == "X-Qtopia-AllDay" ) { |
1180 | e.setType( Event::AllDay ); | 1183 | e.setType( Event::AllDay ); |
1181 | } | 1184 | } |
1182 | #if 0 | 1185 | #if 0 |
1183 | else { | 1186 | else { |
1184 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); | 1187 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); |
1185 | VObjectIterator nit; | 1188 | VObjectIterator nit; |
1186 | initPropIterator( &nit, o ); | 1189 | initPropIterator( &nit, o ); |
1187 | while( moreIteration( &nit ) ) { | 1190 | while( moreIteration( &nit ) ) { |
1188 | VObject *o = nextVObject( &nit ); | 1191 | VObject *o = nextVObject( &nit ); |
1189 | QCString name = vObjectName( o ); | 1192 | QCString name = vObjectName( o ); |
1190 | QString value = vObjectStringZValue( o ); | 1193 | QString value = vObjectStringZValue( o ); |
1191 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); | 1194 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); |
1192 | } | 1195 | } |
1193 | } | 1196 | } |
1194 | #endif | 1197 | #endif |
1195 | } | 1198 | } |
1196 | 1199 | ||
1197 | if ( !haveStart && !haveEnd ) | 1200 | if ( !haveStart && !haveEnd ) |
1198 | e.setStart( QDateTime::currentDateTime() ); | 1201 | e.setStart( QDateTime::currentDateTime() ); |
1199 | 1202 | ||
1200 | if ( !haveEnd ) { | 1203 | if ( !haveEnd ) { |
1201 | e.setType( Event::AllDay ); | 1204 | e.setType( Event::AllDay ); |
1202 | e.setEnd( e.start() ); | 1205 | e.setEnd( e.start() ); |
1203 | } | 1206 | } |
1204 | 1207 | ||
1205 | if ( haveAlarm ) { | 1208 | if ( haveAlarm ) { |
1206 | int minutes = alarmTime.secsTo( e.start() ) / 60; | 1209 | int minutes = alarmTime.secsTo( e.start() ) / 60; |
1207 | e.setAlarm( TRUE, minutes, soundType ); | 1210 | e.setAlarm( TRUE, minutes, soundType ); |
1208 | } | 1211 | } |
1209 | return e; | 1212 | return e; |
1210 | } | 1213 | } |
1211 | 1214 | ||
1212 | 1215 | ||
1213 | /*! | 1216 | /*! |
1214 | Writes the list of \a events as a set of VCards to the file \a filename. | 1217 | Writes the list of \a events as a set of VCards to the file \a filename. |
1215 | */ | 1218 | */ |
1216 | void Event::writeVCalendar( const QString &filename, const QValueList<Event> &events) | 1219 | void Event::writeVCalendar( const QString &filename, const QValueList<Event> &events) |
1217 | { | 1220 | { |
1218 | 1221 | ||
1219 | QFileDirect f( filename.utf8().data() ); | 1222 | QFileDirect f( filename.utf8().data() ); |
1220 | 1223 | ||
1221 | if ( !f.open( IO_WriteOnly ) ) { | 1224 | if ( !f.open( IO_WriteOnly ) ) { |
1222 | 1225 | ||
1223 | qWarning("Unable to open vcard write"); | 1226 | qWarning("Unable to open vcard write"); |
1224 | 1227 | ||
1225 | return; | 1228 | return; |
1226 | 1229 | ||
1227 | } | 1230 | } |
1228 | 1231 | ||
1229 | 1232 | ||
1230 | QValueList<Event>::ConstIterator it; | 1233 | QValueList<Event>::ConstIterator it; |
1231 | for( it = events.begin(); it != events.end(); ++it ) { | 1234 | for( it = events.begin(); it != events.end(); ++it ) { |
1232 | VObject *obj = createVObject( *it ); | 1235 | VObject *obj = createVObject( *it ); |
1233 | writeVObject( f.directHandle() , obj ); | 1236 | writeVObject( f.directHandle() , obj ); |
1234 | cleanVObject( obj ); | 1237 | cleanVObject( obj ); |
1235 | } | 1238 | } |
1236 | 1239 | ||
1237 | 1240 | ||
1238 | cleanStrTbl(); | 1241 | cleanStrTbl(); |
1239 | } | 1242 | } |
1240 | 1243 | ||
1241 | /*! | 1244 | /*! |
1242 | Writes \a event as a VCard to the file \a filename. | 1245 | Writes \a event as a VCard to the file \a filename. |
1243 | */ | 1246 | */ |
1244 | void Event::writeVCalendar( const QString &filename, const Event &event) | 1247 | void Event::writeVCalendar( const QString &filename, const Event &event) |
1245 | { | 1248 | { |
1246 | 1249 | ||
1247 | QFileDirect f( filename.utf8().data() ); | 1250 | QFileDirect f( filename.utf8().data() ); |
1248 | 1251 | ||
1249 | if ( !f.open( IO_WriteOnly ) ) { | 1252 | if ( !f.open( IO_WriteOnly ) ) { |
1250 | 1253 | ||
1251 | qWarning("Unable to open vcard write"); | 1254 | qWarning("Unable to open vcard write"); |
1252 | 1255 | ||
1253 | return; | 1256 | return; |
1254 | 1257 | ||
1255 | } | 1258 | } |
1256 | 1259 | ||
1257 | 1260 | ||
1258 | VObject *obj = createVObject( event ); | 1261 | VObject *obj = createVObject( event ); |
1259 | writeVObject( f.directHandle() , obj ); | 1262 | writeVObject( f.directHandle() , obj ); |
1260 | cleanVObject( obj ); | 1263 | cleanVObject( obj ); |
1261 | 1264 | ||
1262 | cleanStrTbl(); | 1265 | cleanStrTbl(); |
1263 | } | 1266 | } |
1264 | 1267 | ||
1265 | /*! | 1268 | /*! |
1266 | Returns the set of events read as VCards from the file \a filename. | 1269 | Returns the set of events read as VCards from the file \a filename. |
1267 | */ | 1270 | */ |
1268 | QValueList<Event> Event::readVCalendar( const QString &filename ) | 1271 | QValueList<Event> Event::readVCalendar( const QString &filename ) |
1269 | { | 1272 | { |
1270 | VObject *obj = Parse_MIME_FromFileName( (char *)filename.utf8().data() ); | 1273 | VObject *obj = Parse_MIME_FromFileName( (char *)filename.utf8().data() ); |
1271 | 1274 | ||
1272 | QValueList<Event> events; | 1275 | QValueList<Event> events; |
1273 | 1276 | ||
1274 | while ( obj ) { | 1277 | while ( obj ) { |
1275 | QCString name = vObjectName( obj ); | 1278 | QCString name = vObjectName( obj ); |
1276 | if ( name == VCCalProp ) { | 1279 | if ( name == VCCalProp ) { |
1277 | VObjectIterator nit; | 1280 | VObjectIterator nit; |
1278 | initPropIterator( &nit, obj ); | 1281 | initPropIterator( &nit, obj ); |
1279 | while( moreIteration( &nit ) ) { | 1282 | while( moreIteration( &nit ) ) { |
1280 | VObject *o = nextVObject( &nit ); | 1283 | VObject *o = nextVObject( &nit ); |
1281 | QCString name = vObjectName( o ); | 1284 | QCString name = vObjectName( o ); |
1282 | if ( name == VCEventProp ) | 1285 | if ( name == VCEventProp ) |
1283 | events.append( parseVObject( o ) ); | 1286 | events.append( parseVObject( o ) ); |
1284 | } | 1287 | } |
1285 | } else if ( name == VCEventProp ) { | 1288 | } else if ( name == VCEventProp ) { |
1286 | // shouldn't happen, but just to be sure | 1289 | // shouldn't happen, but just to be sure |
1287 | events.append( parseVObject( obj ) ); | 1290 | events.append( parseVObject( obj ) ); |
1288 | } | 1291 | } |
1289 | VObject *t = obj; | 1292 | VObject *t = obj; |
1290 | obj = nextVObjectInList(obj); | 1293 | obj = nextVObjectInList(obj); |
1291 | cleanVObject( t ); | 1294 | cleanVObject( t ); |
1292 | } | 1295 | } |
1293 | 1296 | ||
1294 | return events; | 1297 | return events; |
1295 | } | 1298 | } |
1296 | 1299 | ||
1297 | bool Event::match( const QRegExp &r ) const | 1300 | bool Event::match( const QRegExp &r ) const |
1298 | { | 1301 | { |
1299 | bool returnMe; | 1302 | bool returnMe; |
1300 | returnMe = false; | 1303 | returnMe = false; |
1301 | 1304 | ||
1302 | if ( descript.find( r ) > -1 ) | 1305 | if ( descript.find( r ) > -1 ) |
1303 | returnMe = true; | 1306 | returnMe = true; |
1304 | else if ( locat.find( r ) > -1 ) | 1307 | else if ( locat.find( r ) > -1 ) |
1305 | returnMe = true; | 1308 | returnMe = true; |
1306 | else if ( TimeConversion::fromUTC( startUTC ).toString().find( r ) > -1 ) | 1309 | else if ( TimeConversion::fromUTC( startUTC ).toString().find( r ) > -1 ) |
1307 | returnMe = true; | 1310 | returnMe = true; |
1308 | else if ( TimeConversion::fromUTC( endUTC ).toString().find( r ) > -1 ) | 1311 | else if ( TimeConversion::fromUTC( endUTC ).toString().find( r ) > -1 ) |
1309 | returnMe = true; | 1312 | returnMe = true; |
1310 | else if ( tz.find( r ) > -1 ) | 1313 | else if ( tz.find( r ) > -1 ) |
1311 | returnMe = true; | 1314 | returnMe = true; |
1312 | else if ( note.find( r ) > -1 ) | 1315 | else if ( note.find( r ) > -1 ) |
1313 | returnMe = true; | 1316 | returnMe = true; |
1314 | else if ( doRepeat() ) { | 1317 | else if ( doRepeat() ) { |
1315 | if ( pattern.hasEndDate ) | 1318 | if ( pattern.hasEndDate ) |
1316 | if ( TimeConversion::fromUTC( pattern.endDateUTC ).toString().find(r) > -1 ) | 1319 | if ( TimeConversion::fromUTC( pattern.endDateUTC ).toString().find(r) > -1 ) |
1317 | returnMe = true; | 1320 | returnMe = true; |
1318 | } | 1321 | } |
1319 | return returnMe; | 1322 | return returnMe; |
1320 | } | 1323 | } |
diff --git a/library/backend/event.h b/library/backend/event.h index 2b275a4..4610d85 100644 --- a/library/backend/event.h +++ b/library/backend/event.h | |||
@@ -1,375 +1,375 @@ | |||
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 | #ifndef __EVENT_H__ | 21 | #ifndef __EVENT_H__ |
22 | #define __EVENT_H__ | 22 | #define __EVENT_H__ |
23 | 23 | ||
24 | #include <qdatetime.h> | 24 | #include <qdatetime.h> |
25 | #include <qvaluelist.h> | 25 | #include <qvaluelist.h> |
26 | #include <qcolor.h> | 26 | #include <qcolor.h> |
27 | 27 | ||
28 | #ifdef PALMTOPCENTER | 28 | #ifdef PALMTOPCENTER |
29 | #include <qpc/qsorter.h> | 29 | #include <qpc/qsorter.h> |
30 | #endif | 30 | #endif |
31 | #include <qtopia/private/palmtoprecord.h> | 31 | #include <qtopia/private/palmtoprecord.h> |
32 | 32 | ||
33 | #include <qpe/timeconversion.h> | 33 | #include <qpe/timeconversion.h> |
34 | 34 | ||
35 | static const QColor colorNormal = QColor(255, 0 , 0 ); | 35 | static const QColor colorNormal = QColor(255, 0 , 0 ); |
36 | static const QColor colorRepeat = QColor(0 , 0 , 255); | 36 | static const QColor colorRepeat = QColor(0 , 0 , 255); |
37 | static const QColor colorNormalLight = QColor(255, 220, 220); | 37 | static const QColor colorNormalLight = QColor(255, 220, 220); |
38 | static const QColor colorRepeatLight = QColor(200, 200, 255); | 38 | static const QColor colorRepeatLight = QColor(200, 200, 255); |
39 | 39 | ||
40 | class EventPrivate; | 40 | class EventPrivate; |
41 | class QPC_EXPORT Event : public Qtopia::Record | 41 | class QPC_EXPORT Event : public Qtopia::Record |
42 | { | 42 | { |
43 | public: | 43 | public: |
44 | enum RepeatType { NoRepeat = -1, Daily, Weekly, MonthlyDay, | 44 | enum RepeatType { NoRepeat = -1, Daily, Weekly, MonthlyDay, |
45 | MonthlyDate, Yearly }; | 45 | MonthlyDate, Yearly }; |
46 | 46 | ||
47 | // Don't use this. | 47 | // Don't use this. |
48 | enum Days { MON = 0x01, TUE = 0x02, WED = 0x04, THU = 0x08, | 48 | enum Days { MON = 0x01, TUE = 0x02, WED = 0x04, THU = 0x08, |
49 | FRI = 0x10, SAT = 0x20, SUN = 0x40 }; | 49 | FRI = 0x10, SAT = 0x20, SUN = 0x40 }; |
50 | // Don't use this. | 50 | // Don't use this. |
51 | struct QPC_EXPORT RepeatPattern | 51 | struct QPC_EXPORT RepeatPattern |
52 | { | 52 | { |
53 | RepeatPattern() { | 53 | RepeatPattern() { |
54 | type = NoRepeat; frequency = -1; days = 0; position = 0; createTime = -1; | 54 | type = NoRepeat; frequency = -1; days = 0; position = 0; createTime = -1; |
55 | hasEndDate = FALSE; endDateUTC = 0; } | 55 | hasEndDate = FALSE; endDateUTC = 0; } |
56 | bool operator ==( const RepeatPattern &right ) const; | 56 | bool operator ==( const RepeatPattern &right ) const; |
57 | 57 | ||
58 | RepeatType type; | 58 | RepeatType type; |
59 | int frequency; | 59 | int frequency; |
60 | int position;// the posistion in the month (e.g. the first sunday, etc) positive, count from the front negative count from the end... | 60 | int position;// the posistion in the month (e.g. the first sunday, etc) positive, count from the front negative count from the end... |
61 | char days; // a mask for days OR in your days! | 61 | char days; // a mask for days OR in your days! |
62 | bool hasEndDate; | 62 | bool hasEndDate; |
63 | QDate endDate() const { return TimeConversion::fromUTC( endDateUTC ).date(); } | 63 | QDate endDate() const { return TimeConversion::fromUTC( endDateUTC ).date(); } |
64 | void setEndDate( const QDate &dt ) { endDateUTC = TimeConversion::toUTC( dt ); } | 64 | void setEndDate( const QDate &dt ) { endDateUTC = TimeConversion::toUTC( dt ); } |
65 | time_t endDateUTC; | 65 | time_t endDateUTC; |
66 | time_t createTime; | 66 | time_t createTime; |
67 | }; | 67 | }; |
68 | 68 | ||
69 | Event(); | 69 | Event(); |
70 | Event( const QMap<int, QString > & map ); | 70 | Event( const QMap<int, QString > & map ); |
71 | virtual ~Event(); | 71 | virtual ~Event(); |
72 | 72 | ||
73 | QMap<int, QString> toMap() const; | 73 | QMap<int, QString> toMap() const; |
74 | 74 | ||
75 | static void writeVCalendar( const QString &filename, const QValueList<Event> &events); | 75 | static void writeVCalendar( const QString &filename, const QValueList<Event> &events); |
76 | static void writeVCalendar( const QString &filename, const Event &event); | 76 | static void writeVCalendar( const QString &filename, const Event &event); |
77 | static QValueList<Event> readVCalendar( const QString &filename ); | 77 | static QValueList<Event> readVCalendar( const QString &filename ); |
78 | 78 | ||
79 | enum Type { Normal, AllDay }; | 79 | enum Type { Normal, AllDay }; |
80 | enum SoundTypeChoice { Silent, Loud }; | 80 | enum SoundTypeChoice { Silent, Loud }; |
81 | 81 | ||
82 | // Don't use these, there are essentially meaningless. | 82 | // Don't use these, there are essentially meaningless. |
83 | bool operator<( const Event &e1) const { return start() < e1.start(); }; | 83 | bool operator<( const Event &e1) const { return start() < e1.start(); }; |
84 | bool operator<=( const Event &e1 ) const { return start() <= e1.start(); }; | 84 | bool operator<=( const Event &e1 ) const { return start() <= e1.start(); }; |
85 | bool operator!=( const Event &e1 ) const { return !( *this == e1 ); }; | 85 | bool operator!=( const Event &e1 ) const { return !( *this == e1 ); }; |
86 | bool operator>( const Event &e1 ) const { return start() > e1.start(); }; | 86 | bool operator>( const Event &e1 ) const { return start() > e1.start(); }; |
87 | bool operator>=(const Event &e1 ) const { return start() >= e1.start(); }; | 87 | bool operator>=(const Event &e1 ) const { return start() >= e1.start(); }; |
88 | bool operator==( const Event &e ) const; | 88 | bool operator==( const Event &e ) const; |
89 | 89 | ||
90 | void setDescription( const QString &s ); | 90 | void setDescription( const QString &s ); |
91 | const QString &description() const; | 91 | const QString &description() const; |
92 | 92 | ||
93 | void setLocation( const QString &s ); | 93 | void setLocation( const QString &s ); |
94 | const QString &location() const; | 94 | const QString &location() const; |
95 | 95 | ||
96 | void setNotes( const QString &n ); | 96 | void setNotes( const QString &n ); |
97 | const QString ¬es() const; | 97 | const QString ¬es() const; |
98 | 98 | ||
99 | void setType( Type t ); // Don't use me. | 99 | void setType( Type t ); // Don't use me. |
100 | Type type() const; // Don't use me. | 100 | Type type() const; // Don't use me. |
101 | 101 | ||
102 | void setAllDay(bool); | 102 | void setAllDay(bool); |
103 | bool isAllDay() const; | 103 | bool isAllDay() const; |
104 | 104 | ||
105 | void setStart( const QDateTime &d ); | 105 | void setStart( const QDateTime &d ); |
106 | void setStart( time_t time ); // don't use me. | 106 | void setStart( time_t time ); // don't use me. |
107 | QDateTime start( ) const; | 107 | QDateTime start( ) const; |
108 | QDateTime start( bool actual ) const; // don't use me. | 108 | QDateTime start( bool actual ) const; // don't use me. |
109 | time_t startTime() const { return startUTC; } // don't use me. | 109 | time_t startTime() const { return startUTC; } // don't use me. |
110 | void setEnd( const QDateTime &e ); | 110 | void setEnd( const QDateTime &e ); |
111 | void setEnd( time_t time ); // don't use me | 111 | void setEnd( time_t time ); // don't use me |
112 | QDateTime end( ) const; | 112 | QDateTime end( ) const; |
113 | QDateTime end( bool actual ) const; // don't use me. | 113 | QDateTime end( bool actual ) const; // don't use me. |
114 | time_t endTime() const { return endUTC; } // don't use me. | 114 | time_t endTime() const { return endUTC; } // don't use me. |
115 | void setTimeZone( const QString & ); | 115 | void setTimeZone( const QString & ); |
116 | const QString &timeZone() const; | 116 | const QString &timeZone() const; |
117 | void setAlarm( int minutes, SoundTypeChoice ); | 117 | void setAlarm( int minutes, SoundTypeChoice ); |
118 | void clearAlarm(); | 118 | void clearAlarm(); |
119 | void setAlarm( bool b, int minutes, SoundTypeChoice ); // Don't use me. | 119 | void setAlarm( bool b, int minutes, SoundTypeChoice ); // Don't use me. |
120 | bool hasAlarm() const; | 120 | bool hasAlarm() const; |
121 | int alarmDelay() const; | 121 | int alarmDelay() const; |
122 | int alarmTime() const; // Don't use me. | 122 | int alarmTime() const; // Don't use me. |
123 | SoundTypeChoice alarmSound() const; | 123 | SoundTypeChoice alarmSound() const; |
124 | 124 | ||
125 | RepeatType repeatType() const; | 125 | RepeatType repeatType() const; |
126 | int frequency() const; | 126 | int frequency() const; |
127 | int weekOffset() const; | 127 | int weekOffset() const; |
128 | QDate repeatTill() const; | 128 | QDate repeatTill() const; |
129 | bool repeatForever() const; | 129 | bool repeatForever() const; |
130 | bool repeatOnWeekDay(int day) const; | 130 | bool repeatOnWeekDay(int day) const; |
131 | 131 | ||
132 | void setRepeatType(RepeatType); | 132 | void setRepeatType(RepeatType); |
133 | void setFrequency(int); | 133 | void setFrequency(int); |
134 | void setRepeatTill(const QDate &); | 134 | void setRepeatTill(const QDate &); |
135 | void setRepeatForever(bool); | 135 | void setRepeatForever(bool); |
136 | void setRepeatOnWeekDay(int day, bool enable); | 136 | void setRepeatOnWeekDay(int day, bool enable); |
137 | 137 | ||
138 | // Don't use any of these. | 138 | // Don't use any of these. |
139 | void setRepeat( bool b, const RepeatPattern &p ); | 139 | void setRepeat( bool b, const RepeatPattern &p ); |
140 | void setRepeat( const RepeatPattern &p ); | 140 | void setRepeat( const RepeatPattern &p ); |
141 | bool hasRepeat() const; | 141 | bool hasRepeat() const; |
142 | const RepeatPattern &repeatPattern() const; | 142 | const RepeatPattern &repeatPattern() const; |
143 | RepeatPattern &repeatPattern(); | 143 | RepeatPattern &repeatPattern(); |
144 | bool doRepeat() const { return pattern.type != NoRepeat; } | 144 | bool doRepeat() const { return pattern.type != NoRepeat; } |
145 | 145 | ||
146 | void save( QString& buf ); | 146 | void save( QString& buf ); |
147 | //void load( Node *n ); | 147 | //void load( Node *n ); |
148 | 148 | ||
149 | bool match( const QRegExp &r ) const; | 149 | bool match( const QRegExp &r ) const; |
150 | 150 | ||
151 | // Don't use these either. Functionality will be moved elsewhere. | 151 | // Don't use these either. Functionality will be moved elsewhere. |
152 | 152 | ||
153 | // helper function to calculate the week of the given date | 153 | // helper function to calculate the week of the given date |
154 | static int week( const QDate& date ); | 154 | static int week( const QDate& date ); |
155 | // calculates the number of occurrences of the week day of | 155 | // calculates the number of occurrences of the week day of |
156 | // the given date from the start of the month | 156 | // the given date from the start of the month |
157 | static int occurrence( const QDate& date ); | 157 | static int occurrence( const QDate& date ); |
158 | // returns a proper days-char for a given dayOfWeek() | 158 | // returns a proper days-char for a given dayOfWeek() |
159 | static char day( int dayOfWeek ) { return 1 << ( dayOfWeek - 1 ); } | 159 | static char day( int dayOfWeek ) { return 1 << ( dayOfWeek - 1 ); } |
160 | // returns the dayOfWeek for the *first* day it finds (ignores | 160 | // returns the dayOfWeek for the *first* day it finds (ignores |
161 | // any further days!). Returns 1 (Monday) if there isn't any day found | 161 | // any further days!). Returns 1 (Monday) if there isn't any day found |
162 | static int dayOfWeek( char day ); | 162 | static int dayOfWeek( char day ); |
163 | // returns the difference of months from first to second. | 163 | // returns the difference of months from first to second. |
164 | static int monthDiff( const QDate& first, const QDate& second ); | 164 | static int monthDiff( const QDate& first, const QDate& second ); |
165 | 165 | ||
166 | private: | 166 | private: |
167 | Qtopia::UidGen &uidGen() { return sUidGen; } | 167 | Qtopia::UidGen &uidGen() { return sUidGen; } |
168 | static Qtopia::UidGen sUidGen; | 168 | static Qtopia::UidGen sUidGen; |
169 | 169 | ||
170 | QString descript, locat, categ; | 170 | QString descript, locat, categ; |
171 | Type typ : 4; | 171 | Type typ : 4; |
172 | bool startTimeDirty : 1; | 172 | bool startTimeDirty : 1; |
173 | bool endTimeDirty : 1; | 173 | bool endTimeDirty : 1; |
174 | time_t startUTC, endUTC; | 174 | time_t startUTC, endUTC; |
175 | QString tz; | 175 | QString tz; |
176 | bool hAlarm, hRepeat; | 176 | bool hAlarm, hRepeat; |
177 | int aMinutes; | 177 | int aMinutes; |
178 | SoundTypeChoice aSound; | 178 | SoundTypeChoice aSound; |
179 | RepeatPattern pattern; | 179 | RepeatPattern pattern; |
180 | QString note; | 180 | QString note; |
181 | // ADDITION | 181 | // ADDITION |
182 | int mRid;// Recode ID | 182 | int mRid;// Recode ID |
183 | int mRinfo;// Recode Info | 183 | int mRinfo;// Recode Info |
184 | // | 184 | // |
185 | EventPrivate *d; | 185 | EventPrivate *d; |
186 | 186 | ||
187 | }; | 187 | }; |
188 | 188 | ||
189 | // Since an event spans multiple day, it is better to have this | 189 | // Since an event spans multiple day, it is better to have this |
190 | // class to represent a day instead of creating many | 190 | // class to represent a day instead of creating many |
191 | // dummy events... | 191 | // dummy events... |
192 | 192 | ||
193 | class EffectiveEventPrivate; | 193 | class EffectiveEventPrivate; |
194 | class QPC_EXPORT EffectiveEvent | 194 | class QPC_EXPORT EffectiveEvent |
195 | { | 195 | { |
196 | public: | 196 | public: |
197 | // If we calculate the effective event of a multi-day event | 197 | // If we calculate the effective event of a multi-day event |
198 | // we have to figure out whether we are at the first day, | 198 | // we have to figure out whether we are at the first day, |
199 | // at the end, or anywhere else ("middle"). This is important | 199 | // at the end, or anywhere else ("middle"). This is important |
200 | // for the start/end times (00:00/23:59) | 200 | // for the start/end times (00:00/23:59) |
201 | // MidWay: 00:00 -> 23:59, as we are "in the middle" of a multi- | 201 | // MidWay: 00:00 -> 23:59, as we are "in the middle" of a multi- |
202 | // day event | 202 | // day event |
203 | // Start: start time -> 23:59 | 203 | // Start: start time -> 23:59 |
204 | // End: 00:00 -> end time | 204 | // End: 00:00 -> end time |
205 | // Start | End == StartEnd: for single-day events (default) | 205 | // Start | End == StartEnd: for single-day events (default) |
206 | // here we draw start time -> end time | 206 | // here we draw start time -> end time |
207 | enum Position { MidWay = 0, Start = 1, End = 2, StartEnd = 3 }; | 207 | enum Position { MidWay = 0, Start = 1, End = 2, StartEnd = 3 }; |
208 | 208 | ||
209 | EffectiveEvent(); | 209 | EffectiveEvent(); |
210 | EffectiveEvent( const Event &event, const QDate &startDate, Position pos = StartEnd ); | 210 | EffectiveEvent( const Event &event, const QDate &startDate, Position pos = StartEnd ); |
211 | EffectiveEvent( const EffectiveEvent & ); | 211 | EffectiveEvent( const EffectiveEvent & ); |
212 | EffectiveEvent& operator=( const EffectiveEvent & ); | 212 | EffectiveEvent& operator=( const EffectiveEvent & ); |
213 | ~EffectiveEvent(); | 213 | ~EffectiveEvent(); |
214 | 214 | ||
215 | 215 | ||
216 | bool operator<( const EffectiveEvent &e ) const; | 216 | bool operator<( const EffectiveEvent &e ) const; |
217 | bool operator<=( const EffectiveEvent &e ) const; | 217 | bool operator<=( const EffectiveEvent &e ) const; |
218 | bool operator==( const EffectiveEvent &e ) const; | 218 | bool operator==( const EffectiveEvent &e ) const; |
219 | bool operator!=( const EffectiveEvent &e ) const; | 219 | bool operator!=( const EffectiveEvent &e ) const; |
220 | bool operator>( const EffectiveEvent &e ) const; | 220 | bool operator>( const EffectiveEvent &e ) const; |
221 | bool operator>= ( const EffectiveEvent &e ) const; | 221 | bool operator>= ( const EffectiveEvent &e ) const; |
222 | 222 | ||
223 | void setStart( const QTime &start ); | 223 | void setStart( const QTime &start ); |
224 | void setEnd( const QTime &end ); | 224 | void setEnd( const QTime &end ); |
225 | void setEvent( Event e ); | 225 | void setEvent( Event e ); |
226 | void setDate( const QDate &date ); | 226 | void setDate( const QDate &date ); |
227 | void setEffectiveDates( const QDate &from, const QDate &to ); | 227 | void setEffectiveDates( const QDate &from, const QDate &to ); |
228 | 228 | ||
229 | // QString category() const; | 229 | // QString category() const; |
230 | const QString &description() const; | 230 | const QString &description() const; |
231 | const QString &location() const; | 231 | const QString &location() const; |
232 | const QString ¬es() const; | 232 | const QString ¬es() const; |
233 | const Event &event() const; | 233 | const Event &event() const; |
234 | const QTime &start() const; | 234 | const QTime &start() const; |
235 | const QTime &end() const; | 235 | const QTime &end() const; |
236 | const QDate &date() const; | 236 | const QDate &date() const; |
237 | int length() const; | 237 | int length() const; |
238 | int size() const; | 238 | int size() const; |
239 | 239 | ||
240 | QDate startDate() const; | 240 | QDate startDate() const; |
241 | QDate endDate() const; | 241 | QDate endDate() const; |
242 | 242 | ||
243 | private: | 243 | private: |
244 | class EffectiveEventPrivate *d; | 244 | class EffectiveEventPrivate *d; |
245 | Event mEvent; | 245 | Event mEvent; |
246 | QDate mDate; | 246 | QDate mDate; |
247 | QTime mStart, | 247 | QTime mStart, |
248 | mEnd; | 248 | mEnd; |
249 | 249 | ||
250 | }; | 250 | }; |
251 | 251 | ||
252 | inline void Event::setAlarm( int minutes, SoundTypeChoice s ) | 252 | inline void Event::setAlarm( int minutes, SoundTypeChoice s ) |
253 | { | 253 | { |
254 | setAlarm(TRUE, minutes, s); | 254 | setAlarm(TRUE, minutes, s); |
255 | } | 255 | } |
256 | 256 | ||
257 | inline void Event::clearAlarm() | 257 | inline void Event::clearAlarm() |
258 | { | 258 | { |
259 | setAlarm(FALSE, 0, Silent); | 259 | setAlarm(FALSE, 0, Silent); |
260 | } | 260 | } |
261 | 261 | ||
262 | inline int Event::alarmDelay() const | 262 | inline int Event::alarmDelay() const |
263 | { | 263 | { |
264 | return alarmTime(); | 264 | return alarmTime(); |
265 | } | 265 | } |
266 | 266 | ||
267 | inline void Event::setAllDay(bool enable) | 267 | inline void Event::setAllDay(bool enable) |
268 | { | 268 | { |
269 | if (enable) | 269 | if (enable) |
270 | setType(AllDay); | 270 | setType(AllDay); |
271 | else | 271 | else |
272 | setType(Normal); | 272 | setType(Normal); |
273 | }; | 273 | }; |
274 | 274 | ||
275 | inline bool Event::isAllDay() const | 275 | inline bool Event::isAllDay() const |
276 | { | 276 | { |
277 | return type() == AllDay; | 277 | return type() == AllDay; |
278 | } | 278 | } |
279 | 279 | ||
280 | inline Event::RepeatType Event::repeatType() const | 280 | inline Event::RepeatType Event::repeatType() const |
281 | { | 281 | { |
282 | return repeatPattern().type; | 282 | return repeatPattern().type; |
283 | } | 283 | } |
284 | 284 | ||
285 | inline int Event::frequency() const | 285 | inline int Event::frequency() const |
286 | { | 286 | { |
287 | return repeatPattern().frequency; | 287 | return repeatPattern().frequency; |
288 | } | 288 | } |
289 | 289 | ||
290 | inline int Event::weekOffset() const | 290 | inline int Event::weekOffset() const |
291 | { | 291 | { |
292 | if (start().date().day() == 1) | 292 | if (start().date().day() == 1) |
293 | return 1; | 293 | return 1; |
294 | return (start().date().day() - 1) / 7 + 1; | 294 | return (start().date().day() - 1) / 7 + 1; |
295 | } | 295 | } |
296 | 296 | ||
297 | inline QDate Event::repeatTill() const | 297 | inline QDate Event::repeatTill() const |
298 | { | 298 | { |
299 | return repeatPattern().endDate(); | 299 | return repeatPattern().endDate(); |
300 | } | 300 | } |
301 | 301 | ||
302 | inline bool Event::repeatForever() const | 302 | inline bool Event::repeatForever() const |
303 | { | 303 | { |
304 | return !repeatPattern().hasEndDate; | 304 | return !repeatPattern().hasEndDate; |
305 | } | 305 | } |
306 | 306 | ||
307 | inline void Event::setRepeatType(RepeatType t) | 307 | inline void Event::setRepeatType(RepeatType t) |
308 | { | 308 | { |
309 | pattern.type = t; | 309 | pattern.type = t; |
310 | } | 310 | } |
311 | 311 | ||
312 | inline void Event::setFrequency(int f) | 312 | inline void Event::setFrequency(int f) |
313 | { | 313 | { |
314 | pattern.frequency = f; | 314 | pattern.frequency = f; |
315 | } | 315 | } |
316 | 316 | ||
317 | inline void Event::setRepeatTill(const QDate &d) | 317 | inline void Event::setRepeatTill(const QDate &d) |
318 | { | 318 | { |
319 | pattern.setEndDate(d); | 319 | pattern.setEndDate(d); |
320 | pattern.hasEndDate = TRUE; | 320 | pattern.hasEndDate = TRUE; |
321 | } | 321 | } |
322 | 322 | ||
323 | inline void Event::setRepeatForever(bool b) | 323 | inline void Event::setRepeatForever(bool b) |
324 | { | 324 | { |
325 | if (!b == pattern.hasEndDate) | 325 | if (!b == pattern.hasEndDate) |
326 | return; | 326 | return; |
327 | if (!b && !pattern.hasEndDate) | 327 | if (!b && !pattern.hasEndDate) |
328 | pattern.setEndDate(end().date()); | 328 | pattern.setEndDate(end().date()); |
329 | pattern.hasEndDate = !b; | 329 | pattern.hasEndDate = !b; |
330 | } | 330 | } |
331 | 331 | ||
332 | inline bool Event::repeatOnWeekDay(int day) const | 332 | inline bool Event::repeatOnWeekDay(int day) const |
333 | { | 333 | { |
334 | if (pattern.type != Weekly) | 334 | if (pattern.type != Weekly) |
335 | return FALSE; | 335 | return FALSE; |
336 | return ( (1 << (day - 1)) & pattern.days ) != 0; | 336 | return ( (1 << (day - 1)) & pattern.days ) != 0; |
337 | } | 337 | } |
338 | 338 | ||
339 | inline void Event::setRepeatOnWeekDay(int day, bool enable) | 339 | inline void Event::setRepeatOnWeekDay(int day, bool enable) |
340 | { | 340 | { |
341 | if ( repeatOnWeekDay( day ) != enable ) | 341 | if ( repeatOnWeekDay( day ) != enable ) |
342 | pattern.days ^= 1 << (day - 1); | 342 | pattern.days ^= 1 << (day - 1); |
343 | } | 343 | } |
344 | /* | 344 | |
345 | inline QDateTime Event::start( ) const | 345 | inline QDateTime Event::start( ) const |
346 | { | 346 | { |
347 | return start(FALSE); | 347 | return start(FALSE); |
348 | } | 348 | } |
349 | 349 | ||
350 | inline QDateTime Event::end( ) const | 350 | inline QDateTime Event::end( ) const |
351 | { | 351 | { |
352 | return end(FALSE); | 352 | return end(FALSE); |
353 | } | 353 | } |
354 | */ | 354 | |
355 | #ifdef PALMTOPCENTER | 355 | #ifdef PALMTOPCENTER |
356 | class QPC_EXPORT EffectiveEventSizeSorter : public QSorter<EffectiveEvent> | 356 | class QPC_EXPORT EffectiveEventSizeSorter : public QSorter<EffectiveEvent> |
357 | { | 357 | { |
358 | public: | 358 | public: |
359 | int compare( const EffectiveEvent& a, const EffectiveEvent& b ) const | 359 | int compare( const EffectiveEvent& a, const EffectiveEvent& b ) const |
360 | { | 360 | { |
361 | return a.size() - b.size(); | 361 | return a.size() - b.size(); |
362 | } | 362 | } |
363 | }; | 363 | }; |
364 | 364 | ||
365 | class QPC_EXPORT EffectiveEventTimeSorter : public QSorter<EffectiveEvent> | 365 | class QPC_EXPORT EffectiveEventTimeSorter : public QSorter<EffectiveEvent> |
366 | { | 366 | { |
367 | public: | 367 | public: |
368 | int compare( const EffectiveEvent& a, const EffectiveEvent& b ) const | 368 | int compare( const EffectiveEvent& a, const EffectiveEvent& b ) const |
369 | { | 369 | { |
370 | return a.start().secsTo( b.start() ); | 370 | return a.start().secsTo( b.start() ); |
371 | } | 371 | } |
372 | }; | 372 | }; |
373 | #endif | 373 | #endif |
374 | 374 | ||
375 | #endif | 375 | #endif |