-rw-r--r-- | libkcal/incidencebase.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/libkcal/incidencebase.cpp b/libkcal/incidencebase.cpp index d7c4595..f1db8b7 100644 --- a/libkcal/incidencebase.cpp +++ b/libkcal/incidencebase.cpp | |||
@@ -133,338 +133,342 @@ void IncidenceBase::setUid(const QString &uid) | |||
133 | mUid = uid; | 133 | mUid = uid; |
134 | updated(); | 134 | updated(); |
135 | } | 135 | } |
136 | 136 | ||
137 | QString IncidenceBase::uid() const | 137 | QString IncidenceBase::uid() const |
138 | { | 138 | { |
139 | return mUid; | 139 | return mUid; |
140 | } | 140 | } |
141 | 141 | ||
142 | void IncidenceBase::setLastModified(const QDateTime &lm) | 142 | void IncidenceBase::setLastModified(const QDateTime &lm) |
143 | { | 143 | { |
144 | // DON'T! updated() because we call this from | 144 | // DON'T! updated() because we call this from |
145 | // Calendar::updateEvent(). | 145 | // Calendar::updateEvent(). |
146 | mLastModified = getEvenTime(lm); | 146 | mLastModified = getEvenTime(lm); |
147 | //qDebug("IncidenceBase::setLastModified %s ",lm.toString().latin1()); | 147 | //qDebug("IncidenceBase::setLastModified %s ",lm.toString().latin1()); |
148 | } | 148 | } |
149 | 149 | ||
150 | QDateTime IncidenceBase::lastModified() const | 150 | QDateTime IncidenceBase::lastModified() const |
151 | { | 151 | { |
152 | return mLastModified; | 152 | return mLastModified; |
153 | } | 153 | } |
154 | 154 | ||
155 | void IncidenceBase::setOrganizer(const QString &o) | 155 | void IncidenceBase::setOrganizer(const QString &o) |
156 | { | 156 | { |
157 | // we don't check for readonly here, because it is | 157 | // we don't check for readonly here, because it is |
158 | // possible that by setting the organizer we are changing | 158 | // possible that by setting the organizer we are changing |
159 | // the event's readonly status... | 159 | // the event's readonly status... |
160 | mOrganizer = o; | 160 | mOrganizer = o; |
161 | if (mOrganizer.left(7).upper() == "MAILTO:") | 161 | if (mOrganizer.left(7).upper() == "MAILTO:") |
162 | mOrganizer = mOrganizer.remove(0,7); | 162 | mOrganizer = mOrganizer.remove(0,7); |
163 | 163 | ||
164 | updated(); | 164 | updated(); |
165 | } | 165 | } |
166 | 166 | ||
167 | QString IncidenceBase::organizer() const | 167 | QString IncidenceBase::organizer() const |
168 | { | 168 | { |
169 | return mOrganizer; | 169 | return mOrganizer; |
170 | } | 170 | } |
171 | 171 | ||
172 | void IncidenceBase::setReadOnly( bool readOnly ) | 172 | void IncidenceBase::setReadOnly( bool readOnly ) |
173 | { | 173 | { |
174 | mReadOnly = readOnly; | 174 | mReadOnly = readOnly; |
175 | } | 175 | } |
176 | 176 | ||
177 | void IncidenceBase::setDtStart(const QDateTime &dtStart) | 177 | void IncidenceBase::setDtStart(const QDateTime &dtStart) |
178 | { | 178 | { |
179 | // if (mReadOnly) return; | 179 | // if (mReadOnly) return; |
180 | mDtStart = getEvenTime(dtStart); | 180 | mDtStart = getEvenTime(dtStart); |
181 | updated(); | 181 | updated(); |
182 | } | 182 | } |
183 | 183 | ||
184 | QDateTime IncidenceBase::dtStart() const | 184 | QDateTime IncidenceBase::dtStart() const |
185 | { | 185 | { |
186 | return mDtStart; | 186 | return mDtStart; |
187 | } | 187 | } |
188 | 188 | ||
189 | QString IncidenceBase::dtStartTimeStr() const | 189 | QString IncidenceBase::dtStartTimeStr() const |
190 | { | 190 | { |
191 | return KGlobal::locale()->formatTime(dtStart().time()); | 191 | return KGlobal::locale()->formatTime(dtStart().time()); |
192 | } | 192 | } |
193 | 193 | ||
194 | QString IncidenceBase::dtStartDateStr(bool shortfmt) const | 194 | QString IncidenceBase::dtStartDateStr(bool shortfmt) const |
195 | { | 195 | { |
196 | return KGlobal::locale()->formatDate(dtStart().date(),shortfmt); | 196 | return KGlobal::locale()->formatDate(dtStart().date(),shortfmt); |
197 | } | 197 | } |
198 | 198 | ||
199 | QString IncidenceBase::dtStartStr(bool shortfmt) const | 199 | QString IncidenceBase::dtStartStr(bool shortfmt) const |
200 | { | 200 | { |
201 | return KGlobal::locale()->formatDateTime(dtStart(), shortfmt); | 201 | return KGlobal::locale()->formatDateTime(dtStart(), shortfmt); |
202 | } | 202 | } |
203 | 203 | ||
204 | 204 | ||
205 | bool IncidenceBase::doesFloat() const | 205 | bool IncidenceBase::doesFloat() const |
206 | { | 206 | { |
207 | return mFloats; | 207 | return mFloats; |
208 | } | 208 | } |
209 | 209 | ||
210 | void IncidenceBase::setFloats(bool f) | 210 | void IncidenceBase::setFloats(bool f) |
211 | { | 211 | { |
212 | if (mReadOnly) return; | 212 | if (mReadOnly) return; |
213 | mFloats = f; | 213 | mFloats = f; |
214 | updated(); | 214 | updated(); |
215 | } | 215 | } |
216 | 216 | ||
217 | 217 | ||
218 | void IncidenceBase::addAttendee(Attendee *a, bool doupdate) | 218 | void IncidenceBase::addAttendee(Attendee *a, bool doupdate) |
219 | { | 219 | { |
220 | if (mReadOnly) return; | 220 | if (mReadOnly) return; |
221 | if (a->name().left(7).upper() == "MAILTO:") | 221 | if (a->name().left(7).upper() == "MAILTO:") |
222 | a->setName(a->name().remove(0,7)); | 222 | a->setName(a->name().remove(0,7)); |
223 | 223 | ||
224 | mAttendees.append(a); | 224 | mAttendees.append(a); |
225 | if (doupdate) updated(); | 225 | if (doupdate) updated(); |
226 | } | 226 | } |
227 | 227 | ||
228 | #if 0 | 228 | #if 0 |
229 | void IncidenceBase::removeAttendee(Attendee *a) | 229 | void IncidenceBase::removeAttendee(Attendee *a) |
230 | { | 230 | { |
231 | if (mReadOnly) return; | 231 | if (mReadOnly) return; |
232 | mAttendees.removeRef(a); | 232 | mAttendees.removeRef(a); |
233 | updated(); | 233 | updated(); |
234 | } | 234 | } |
235 | 235 | ||
236 | void IncidenceBase::removeAttendee(const char *n) | 236 | void IncidenceBase::removeAttendee(const char *n) |
237 | { | 237 | { |
238 | Attendee *a; | 238 | Attendee *a; |
239 | 239 | ||
240 | if (mReadOnly) return; | 240 | if (mReadOnly) return; |
241 | for (a = mAttendees.first(); a; a = mAttendees.next()) | 241 | for (a = mAttendees.first(); a; a = mAttendees.next()) |
242 | if (a->getName() == n) { | 242 | if (a->getName() == n) { |
243 | mAttendees.remove(); | 243 | mAttendees.remove(); |
244 | break; | 244 | break; |
245 | } | 245 | } |
246 | } | 246 | } |
247 | #endif | 247 | #endif |
248 | 248 | ||
249 | void IncidenceBase::clearAttendees() | 249 | void IncidenceBase::clearAttendees() |
250 | { | 250 | { |
251 | if (mReadOnly) return; | 251 | if (mReadOnly) return; |
252 | mAttendees.clear(); | 252 | mAttendees.clear(); |
253 | } | 253 | } |
254 | 254 | ||
255 | #if 0 | 255 | #if 0 |
256 | Attendee *IncidenceBase::getAttendee(const char *n) const | 256 | Attendee *IncidenceBase::getAttendee(const char *n) const |
257 | { | 257 | { |
258 | QPtrListIterator<Attendee> qli(mAttendees); | 258 | QPtrListIterator<Attendee> qli(mAttendees); |
259 | 259 | ||
260 | qli.toFirst(); | 260 | qli.toFirst(); |
261 | while (qli) { | 261 | while (qli) { |
262 | if (qli.current()->getName() == n) | 262 | if (qli.current()->getName() == n) |
263 | return qli.current(); | 263 | return qli.current(); |
264 | ++qli; | 264 | ++qli; |
265 | } | 265 | } |
266 | return 0L; | 266 | return 0L; |
267 | } | 267 | } |
268 | #endif | 268 | #endif |
269 | 269 | ||
270 | Attendee *IncidenceBase::attendeeByMail(const QString &email) | 270 | Attendee *IncidenceBase::attendeeByMail(const QString &email) |
271 | { | 271 | { |
272 | QPtrListIterator<Attendee> qli(mAttendees); | 272 | QPtrListIterator<Attendee> qli(mAttendees); |
273 | 273 | ||
274 | qli.toFirst(); | 274 | qli.toFirst(); |
275 | while (qli) { | 275 | while (qli) { |
276 | if (qli.current()->email() == email) | 276 | if (qli.current()->email() == email) |
277 | return qli.current(); | 277 | return qli.current(); |
278 | ++qli; | 278 | ++qli; |
279 | } | 279 | } |
280 | return 0L; | 280 | return 0L; |
281 | } | 281 | } |
282 | 282 | ||
283 | Attendee *IncidenceBase::attendeeByMails(const QStringList &emails, const QString& email) | 283 | Attendee *IncidenceBase::attendeeByMails(const QStringList &emails, const QString& email) |
284 | { | 284 | { |
285 | QPtrListIterator<Attendee> qli(mAttendees); | 285 | QPtrListIterator<Attendee> qli(mAttendees); |
286 | 286 | ||
287 | QStringList mails = emails; | 287 | QStringList mails = emails; |
288 | if (!email.isEmpty()) { | 288 | if (!email.isEmpty()) { |
289 | mails.append(email); | 289 | mails.append(email); |
290 | } | 290 | } |
291 | qli.toFirst(); | 291 | qli.toFirst(); |
292 | while (qli) { | 292 | while (qli) { |
293 | for ( QStringList::Iterator it = mails.begin(); it != mails.end(); ++it ) { | 293 | for ( QStringList::Iterator it = mails.begin(); it != mails.end(); ++it ) { |
294 | if (qli.current()->email() == *it) | 294 | if (qli.current()->email() == *it) |
295 | return qli.current(); | 295 | return qli.current(); |
296 | } | 296 | } |
297 | 297 | ||
298 | ++qli; | 298 | ++qli; |
299 | } | 299 | } |
300 | return 0L; | 300 | return 0L; |
301 | } | 301 | } |
302 | 302 | ||
303 | void IncidenceBase::setDuration(int seconds) | 303 | void IncidenceBase::setDuration(int seconds) |
304 | { | 304 | { |
305 | mDuration = seconds; | 305 | mDuration = seconds; |
306 | setHasDuration(true); | 306 | setHasDuration(true); |
307 | } | 307 | } |
308 | 308 | ||
309 | int IncidenceBase::duration() const | 309 | int IncidenceBase::duration() const |
310 | { | 310 | { |
311 | return mDuration; | 311 | return mDuration; |
312 | } | 312 | } |
313 | 313 | ||
314 | void IncidenceBase::setHasDuration(bool b) | 314 | void IncidenceBase::setHasDuration(bool b) |
315 | { | 315 | { |
316 | mHasDuration = b; | 316 | mHasDuration = b; |
317 | } | 317 | } |
318 | 318 | ||
319 | bool IncidenceBase::hasDuration() const | 319 | bool IncidenceBase::hasDuration() const |
320 | { | 320 | { |
321 | return mHasDuration; | 321 | return mHasDuration; |
322 | } | 322 | } |
323 | 323 | ||
324 | void IncidenceBase::setSyncStatus(int stat) | 324 | void IncidenceBase::setSyncStatus(int stat) |
325 | { | 325 | { |
326 | if (mReadOnly) return; | 326 | if (mReadOnly) return; |
327 | mSyncStatus = stat; | 327 | mSyncStatus = stat; |
328 | } | 328 | } |
329 | 329 | ||
330 | int IncidenceBase::syncStatus() const | 330 | int IncidenceBase::syncStatus() const |
331 | { | 331 | { |
332 | return mSyncStatus; | 332 | return mSyncStatus; |
333 | } | 333 | } |
334 | 334 | ||
335 | void IncidenceBase::setPilotId( int id ) | 335 | void IncidenceBase::setPilotId( int id ) |
336 | { | 336 | { |
337 | if (mReadOnly) return; | 337 | if (mReadOnly) return; |
338 | mPilotId = id; | 338 | mPilotId = id; |
339 | } | 339 | } |
340 | 340 | ||
341 | int IncidenceBase::pilotId() const | 341 | int IncidenceBase::pilotId() const |
342 | { | 342 | { |
343 | return mPilotId; | 343 | return mPilotId; |
344 | } | 344 | } |
345 | void IncidenceBase::setZaurusId( int id ) | 345 | void IncidenceBase::setZaurusId( int id ) |
346 | { | 346 | { |
347 | if (mReadOnly) return; | 347 | if (mReadOnly) return; |
348 | mZaurusId = id; | 348 | mZaurusId = id; |
349 | } | 349 | } |
350 | 350 | ||
351 | int IncidenceBase::zaurusId() const | 351 | int IncidenceBase::zaurusId() const |
352 | { | 352 | { |
353 | return mZaurusId; | 353 | return mZaurusId; |
354 | } | 354 | } |
355 | 355 | ||
356 | int IncidenceBase::zaurusUid() const | 356 | int IncidenceBase::zaurusUid() const |
357 | { | 357 | { |
358 | return mZaurusUid; | 358 | return mZaurusUid; |
359 | } | 359 | } |
360 | void IncidenceBase::setZaurusUid( int id ) | 360 | void IncidenceBase::setZaurusUid( int id ) |
361 | { | 361 | { |
362 | if (mReadOnly) return; | 362 | if (mReadOnly) return; |
363 | mZaurusUid = id; | 363 | mZaurusUid = id; |
364 | } | 364 | } |
365 | 365 | ||
366 | int IncidenceBase::tempSyncStat() const | 366 | int IncidenceBase::tempSyncStat() const |
367 | { | 367 | { |
368 | return mTempSyncStat; | 368 | return mTempSyncStat; |
369 | } | 369 | } |
370 | void IncidenceBase::setTempSyncStat( int id ) | 370 | void IncidenceBase::setTempSyncStat( int id ) |
371 | { | 371 | { |
372 | if (mReadOnly) return; | 372 | if (mReadOnly) return; |
373 | mTempSyncStat = id; | 373 | mTempSyncStat = id; |
374 | } | 374 | } |
375 | 375 | ||
376 | void IncidenceBase::setID( const QString & prof , int id ) | 376 | void IncidenceBase::setID( const QString & prof , int id ) |
377 | { | 377 | { |
378 | int num = mExternalId.find( ":"+prof+";" ); | 378 | int num = mExternalId.find( ":"+prof+";" ); |
379 | if ( num >= 0 ) { | 379 | if ( num >= 0 ) { |
380 | int len = prof.length()+2; | 380 | int len = prof.length()+2; |
381 | int end = mExternalId.find( ";", num+len ); | 381 | int end = mExternalId.find( ";", num+len ); |
382 | if ( end > 0 ) { | 382 | if ( end > 0 ) { |
383 | mExternalId = mExternalId.left( num+len ) +QString::number( id)+mExternalId.mid( end ); | 383 | mExternalId = mExternalId.left( num+len ) +QString::number( id)+mExternalId.mid( end ); |
384 | } else | 384 | } else |
385 | qDebug("Error in IncidenceBase::setID "); | 385 | qDebug("Error in IncidenceBase::setID "); |
386 | } else { | 386 | } else { |
387 | mExternalId += prof+";"+QString::number( id) +";0:"; | 387 | mExternalId += prof+";"+QString::number( id) +";0:"; |
388 | } | 388 | } |
389 | qDebug("setID*%s*%d*%s* ", prof.latin1(), id,mExternalId.latin1() ); | ||
389 | } | 390 | } |
390 | int IncidenceBase::getID( const QString & prof) | 391 | int IncidenceBase::getID( const QString & prof) |
391 | { | 392 | { |
392 | int ret = -1; | 393 | int ret = -1; |
393 | int num = mExternalId.find(":"+ prof+";" ); | 394 | int num = mExternalId.find(":"+ prof+";" ); |
394 | if ( num >= 0 ) { | 395 | if ( num >= 0 ) { |
395 | int len = prof.length()+2; | 396 | int len = prof.length()+2; |
396 | int end = mExternalId.find( ";", num+len ); | 397 | int end = mExternalId.find( ";", num+len ); |
397 | if ( end > 0 ) { | 398 | if ( end > 0 ) { |
398 | bool ok; | 399 | bool ok; |
399 | ret = mExternalId.mid ( num + len,end-len-num).toInt( &ok ); | 400 | ret = mExternalId.mid ( num + len,end-len-num).toInt( &ok ); |
400 | if (!ok) | 401 | if (!ok) |
401 | return -1; | 402 | ret = -1; |
402 | } | 403 | } |
403 | } | 404 | } |
404 | return ret; | 405 | qDebug("getID*%s*%d*%s* ", prof.latin1(), ret,mExternalId.latin1() ); |
406 | return ret; | ||
405 | } | 407 | } |
406 | 408 | ||
407 | // example :Sharp_DTM;22;23566:TP;-1;8654:TPP;18;0: | 409 | // example :Sharp_DTM;22;23566:TP;-1;8654:TPP;18;0: |
408 | // format name;III;JJJ: III >= 0, may be -1. JJJ always >= 0 | 410 | // format name;III;JJJ: III >= 0, may be -1. JJJ always >= 0 |
409 | void IncidenceBase::setCsum( const QString & prof , int id ) | 411 | void IncidenceBase::setCsum( const QString & prof , int id ) |
410 | { | 412 | { |
411 | int num = mExternalId.find( ":"+prof+";"); | 413 | int num = mExternalId.find( ":"+prof+";"); |
412 | if ( num >= 0 ) { | 414 | if ( num >= 0 ) { |
413 | int len = prof.length()+2; | 415 | int len = prof.length()+2; |
414 | num = mExternalId.find( ";", num+len ); | 416 | num = mExternalId.find( ";", num+len ); |
415 | int end = mExternalId.find( ":", num+1 ); | 417 | int end = mExternalId.find( ":", num+1 ); |
416 | if ( end > 0 ) { | 418 | if ( end > 0 ) { |
417 | mExternalId = mExternalId.left( num ) +QString::number(id)+mExternalId.mid( end ); | 419 | mExternalId = mExternalId.left( num ) +QString::number(id)+mExternalId.mid( end ); |
418 | } else | 420 | } else |
419 | qDebug("Error in IncidenceBase::setCsum "); | 421 | qDebug("Error in IncidenceBase::setCsum "); |
420 | } else { | 422 | } else { |
421 | mExternalId += prof+";-1;"+QString::number( id) +":"; | 423 | mExternalId += prof+";-1;"+QString::number( id) +":"; |
422 | } | 424 | } |
425 | qDebug("setCsum*%s*%d*%s* ", prof.latin1(), id,mExternalId.latin1() ); | ||
423 | } | 426 | } |
424 | int IncidenceBase::getCsum( const QString & prof) | 427 | int IncidenceBase::getCsum( const QString & prof) |
425 | { | 428 | { |
426 | int ret = -1; | 429 | int ret = -1; |
427 | int num = mExternalId.find( ":"+prof+";" ); | 430 | int num = mExternalId.find( ":"+prof+";" ); |
428 | if ( num >= 0 ) { | 431 | if ( num >= 0 ) { |
429 | int len = prof.length()+2; | 432 | int len = prof.length()+2; |
430 | num = mExternalId.find( ";", num+len ); | 433 | num = mExternalId.find( ";", num+len ); |
431 | int end = mExternalId.find( ":", num+1 ); | 434 | int end = mExternalId.find( ":", num+1 ); |
432 | if ( end > 0 ) { | 435 | if ( end > 0 ) { |
433 | bool ok; | 436 | bool ok; |
434 | ret = mExternalId.mid ( num ,end-num).toInt( &ok ); | 437 | ret = mExternalId.mid ( num ,end-num).toInt( &ok ); |
435 | if (!ok) | 438 | if (!ok) |
436 | return -1; | 439 | ret = -1; |
437 | } | 440 | } |
438 | } | 441 | } |
442 | qDebug("getCsum*%s*%d*%s* ", prof.latin1(), ret,mExternalId.latin1() ); | ||
439 | return ret; | 443 | return ret; |
440 | } | 444 | } |
441 | 445 | ||
442 | void IncidenceBase::setIDStr( const QString & s ) | 446 | void IncidenceBase::setIDStr( const QString & s ) |
443 | { | 447 | { |
444 | if (mReadOnly) return; | 448 | if (mReadOnly) return; |
445 | mExternalId = s; | 449 | mExternalId = s; |
446 | } | 450 | } |
447 | 451 | ||
448 | QString IncidenceBase::IDStr() const | 452 | QString IncidenceBase::IDStr() const |
449 | { | 453 | { |
450 | return mExternalId ; | 454 | return mExternalId ; |
451 | } | 455 | } |
452 | void IncidenceBase::registerObserver( IncidenceBase::Observer *observer ) | 456 | void IncidenceBase::registerObserver( IncidenceBase::Observer *observer ) |
453 | { | 457 | { |
454 | if( !mObservers.contains(observer) ) mObservers.append( observer ); | 458 | if( !mObservers.contains(observer) ) mObservers.append( observer ); |
455 | } | 459 | } |
456 | 460 | ||
457 | void IncidenceBase::unRegisterObserver( IncidenceBase::Observer *observer ) | 461 | void IncidenceBase::unRegisterObserver( IncidenceBase::Observer *observer ) |
458 | { | 462 | { |
459 | mObservers.remove( observer ); | 463 | mObservers.remove( observer ); |
460 | } | 464 | } |
461 | 465 | ||
462 | void IncidenceBase::updated() | 466 | void IncidenceBase::updated() |
463 | { | 467 | { |
464 | QPtrListIterator<Observer> it(mObservers); | 468 | QPtrListIterator<Observer> it(mObservers); |
465 | while( it.current() ) { | 469 | while( it.current() ) { |
466 | Observer *o = it.current(); | 470 | Observer *o = it.current(); |
467 | ++it; | 471 | ++it; |
468 | o->incidenceUpdated( this ); | 472 | o->incidenceUpdated( this ); |
469 | } | 473 | } |
470 | } | 474 | } |