-rw-r--r-- | libkcal/incidencebase.cpp | 12 |
1 files changed, 0 insertions, 12 deletions
diff --git a/libkcal/incidencebase.cpp b/libkcal/incidencebase.cpp index f1db8b7..5d8785b 100644 --- a/libkcal/incidencebase.cpp +++ b/libkcal/incidencebase.cpp | |||
@@ -1,129 +1,127 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkcal. | 2 | This file is part of libkcal. |
3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This library is free software; you can redistribute it and/or | 5 | This library is free software; you can redistribute it and/or |
6 | modify it under the terms of the GNU Library General Public | 6 | modify it under the terms of the GNU Library General Public |
7 | License as published by the Free Software Foundation; either | 7 | License as published by the Free Software Foundation; either |
8 | version 2 of the License, or (at your option) any later version. | 8 | version 2 of the License, or (at your option) any later version. |
9 | 9 | ||
10 | This library is distributed in the hope that it will be useful, | 10 | This library is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
13 | Library General Public License for more details. | 13 | Library General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU Library General Public License | 15 | You should have received a copy of the GNU Library General Public License |
16 | along with this library; see the file COPYING.LIB. If not, write to | 16 | along with this library; see the file COPYING.LIB. If not, write to |
17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
18 | Boston, MA 02111-1307, USA. | 18 | Boston, MA 02111-1307, USA. |
19 | */ | 19 | */ |
20 | 20 | ||
21 | #include <kglobal.h> | 21 | #include <kglobal.h> |
22 | #include <klocale.h> | 22 | #include <klocale.h> |
23 | #include <kdebug.h> | 23 | #include <kdebug.h> |
24 | 24 | ||
25 | #include "calformat.h" | 25 | #include "calformat.h" |
26 | 26 | ||
27 | #include "incidencebase.h" | 27 | #include "incidencebase.h" |
28 | 28 | ||
29 | using namespace KCal; | 29 | using namespace KCal; |
30 | 30 | ||
31 | IncidenceBase::IncidenceBase() : | 31 | IncidenceBase::IncidenceBase() : |
32 | mReadOnly(false), mFloats(true), mDuration(0), mHasDuration(false), | 32 | mReadOnly(false), mFloats(true), mDuration(0), mHasDuration(false), |
33 | mPilotId(0), mSyncStatus(SYNCMOD) | 33 | mPilotId(0), mSyncStatus(SYNCMOD) |
34 | { | 34 | { |
35 | setUid(CalFormat::createUniqueId()); | 35 | setUid(CalFormat::createUniqueId()); |
36 | mOrganizer = ""; | 36 | mOrganizer = ""; |
37 | mFloats = false; | 37 | mFloats = false; |
38 | mDuration = 0; | 38 | mDuration = 0; |
39 | mHasDuration = false; | 39 | mHasDuration = false; |
40 | mPilotId = 0; | 40 | mPilotId = 0; |
41 | mZaurusId = -1; | ||
42 | mZaurusUid = 0; | 41 | mZaurusUid = 0; |
43 | mExternalId = ":"; | 42 | mExternalId = ":"; |
44 | mTempSyncStat = 0; | 43 | mTempSyncStat = 0; |
45 | mSyncStatus = 0; | 44 | mSyncStatus = 0; |
46 | mAttendees.setAutoDelete( true ); | 45 | mAttendees.setAutoDelete( true ); |
47 | } | 46 | } |
48 | 47 | ||
49 | IncidenceBase::IncidenceBase(const IncidenceBase &i) : | 48 | IncidenceBase::IncidenceBase(const IncidenceBase &i) : |
50 | CustomProperties( i ) | 49 | CustomProperties( i ) |
51 | { | 50 | { |
52 | mReadOnly = i.mReadOnly; | 51 | mReadOnly = i.mReadOnly; |
53 | mDtStart = i.mDtStart; | 52 | mDtStart = i.mDtStart; |
54 | mDuration = i.mDuration; | 53 | mDuration = i.mDuration; |
55 | mHasDuration = i.mHasDuration; | 54 | mHasDuration = i.mHasDuration; |
56 | mOrganizer = i.mOrganizer; | 55 | mOrganizer = i.mOrganizer; |
57 | mUid = i.mUid; | 56 | mUid = i.mUid; |
58 | QPtrList<Attendee> attendees = i.attendees(); | 57 | QPtrList<Attendee> attendees = i.attendees(); |
59 | for( Attendee *a = attendees.first(); a; a = attendees.next() ) { | 58 | for( Attendee *a = attendees.first(); a; a = attendees.next() ) { |
60 | mAttendees.append( new Attendee( *a ) ); | 59 | mAttendees.append( new Attendee( *a ) ); |
61 | } | 60 | } |
62 | mFloats = i.mFloats; | 61 | mFloats = i.mFloats; |
63 | mLastModified = i.mLastModified; | 62 | mLastModified = i.mLastModified; |
64 | mPilotId = i.mPilotId; | 63 | mPilotId = i.mPilotId; |
65 | mZaurusId = i.mZaurusId; | ||
66 | mZaurusUid = i.mZaurusUid; | 64 | mZaurusUid = i.mZaurusUid; |
67 | mTempSyncStat = i.mTempSyncStat; | 65 | mTempSyncStat = i.mTempSyncStat; |
68 | mSyncStatus = i.mSyncStatus; | 66 | mSyncStatus = i.mSyncStatus; |
69 | mExternalId = i.mExternalId; | 67 | mExternalId = i.mExternalId; |
70 | // The copied object is a new one, so it isn't observed by the observer | 68 | // The copied object is a new one, so it isn't observed by the observer |
71 | // of the original object. | 69 | // of the original object. |
72 | mObservers.clear(); | 70 | mObservers.clear(); |
73 | 71 | ||
74 | mAttendees.setAutoDelete( true ); | 72 | mAttendees.setAutoDelete( true ); |
75 | } | 73 | } |
76 | 74 | ||
77 | IncidenceBase::~IncidenceBase() | 75 | IncidenceBase::~IncidenceBase() |
78 | { | 76 | { |
79 | } | 77 | } |
80 | 78 | ||
81 | 79 | ||
82 | bool KCal::operator==( const IncidenceBase& i1, const IncidenceBase& i2 ) | 80 | bool KCal::operator==( const IncidenceBase& i1, const IncidenceBase& i2 ) |
83 | { | 81 | { |
84 | // do not compare mSyncStatus and mExternalId | 82 | // do not compare mSyncStatus and mExternalId |
85 | if( i1.attendees().count() != i2.attendees().count() ) { | 83 | if( i1.attendees().count() != i2.attendees().count() ) { |
86 | return false; // no need to check further | 84 | return false; // no need to check further |
87 | } | 85 | } |
88 | if ( i1.attendees().count() > 0 ) { | 86 | if ( i1.attendees().count() > 0 ) { |
89 | Attendee * a1 = i1.attendees().first(), *a2 =i2.attendees().first() ; | 87 | Attendee * a1 = i1.attendees().first(), *a2 =i2.attendees().first() ; |
90 | while ( a1 ) { | 88 | while ( a1 ) { |
91 | if ( !( (*a1) == (*a2)) ) | 89 | if ( !( (*a1) == (*a2)) ) |
92 | { | 90 | { |
93 | //qDebug("Attendee not equal "); | 91 | //qDebug("Attendee not equal "); |
94 | return false; | 92 | return false; |
95 | } | 93 | } |
96 | a1 = i1.attendees().next(); | 94 | a1 = i1.attendees().next(); |
97 | a2 = i2.attendees().next(); | 95 | a2 = i2.attendees().next(); |
98 | } | 96 | } |
99 | } | 97 | } |
100 | //if ( i1.dtStart() != i2.dtStart() ) | 98 | //if ( i1.dtStart() != i2.dtStart() ) |
101 | // return false; | 99 | // return false; |
102 | #if 0 | 100 | #if 0 |
103 | qDebug("1 %d ",i1.doesFloat() == i2.doesFloat() ); | 101 | qDebug("1 %d ",i1.doesFloat() == i2.doesFloat() ); |
104 | qDebug("1 %d ",i1.duration() == i2.duration() ); | 102 | qDebug("1 %d ",i1.duration() == i2.duration() ); |
105 | qDebug("3 %d ",i1.hasDuration() == i2.hasDuration() ); | 103 | qDebug("3 %d ",i1.hasDuration() == i2.hasDuration() ); |
106 | qDebug("1 %d ",i1.pilotId() == i2.pilotId() ); | 104 | qDebug("1 %d ",i1.pilotId() == i2.pilotId() ); |
107 | qDebug("1 %d %d %d",i1.syncStatus() == i2.syncStatus() , i1.syncStatus(),i2.syncStatus() ); | 105 | qDebug("1 %d %d %d",i1.syncStatus() == i2.syncStatus() , i1.syncStatus(),i2.syncStatus() ); |
108 | qDebug("6 %d ",i1.organizer() == i2.organizer() ); | 106 | qDebug("6 %d ",i1.organizer() == i2.organizer() ); |
109 | 107 | ||
110 | #endif | 108 | #endif |
111 | return ( i1.organizer() == i2.organizer() && | 109 | return ( i1.organizer() == i2.organizer() && |
112 | // i1.uid() == i2.uid() && | 110 | // i1.uid() == i2.uid() && |
113 | // Don't compare lastModified, otherwise the operator is not | 111 | // Don't compare lastModified, otherwise the operator is not |
114 | // of much use. We are not comparing for identity, after all. | 112 | // of much use. We are not comparing for identity, after all. |
115 | i1.doesFloat() == i2.doesFloat() && | 113 | i1.doesFloat() == i2.doesFloat() && |
116 | i1.duration() == i2.duration() && | 114 | i1.duration() == i2.duration() && |
117 | i1.hasDuration() == i2.hasDuration() && | 115 | i1.hasDuration() == i2.hasDuration() && |
118 | i1.pilotId() == i2.pilotId() );// && i1.syncStatus() == i2.syncStatus() ); | 116 | i1.pilotId() == i2.pilotId() );// && i1.syncStatus() == i2.syncStatus() ); |
119 | // no need to compare mObserver | 117 | // no need to compare mObserver |
120 | } | 118 | } |
121 | 119 | ||
122 | 120 | ||
123 | QDateTime IncidenceBase::getEvenTime( QDateTime dt ) | 121 | QDateTime IncidenceBase::getEvenTime( QDateTime dt ) |
124 | { | 122 | { |
125 | QTime t = dt.time(); | 123 | QTime t = dt.time(); |
126 | dt.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | 124 | dt.setTime( QTime (t.hour (), t.minute (), t.second () ) ); |
127 | return dt; | 125 | return dt; |
128 | } | 126 | } |
129 | 127 | ||
@@ -281,138 +279,128 @@ Attendee *IncidenceBase::attendeeByMail(const QString &email) | |||
281 | } | 279 | } |
282 | 280 | ||
283 | Attendee *IncidenceBase::attendeeByMails(const QStringList &emails, const QString& email) | 281 | Attendee *IncidenceBase::attendeeByMails(const QStringList &emails, const QString& email) |
284 | { | 282 | { |
285 | QPtrListIterator<Attendee> qli(mAttendees); | 283 | QPtrListIterator<Attendee> qli(mAttendees); |
286 | 284 | ||
287 | QStringList mails = emails; | 285 | QStringList mails = emails; |
288 | if (!email.isEmpty()) { | 286 | if (!email.isEmpty()) { |
289 | mails.append(email); | 287 | mails.append(email); |
290 | } | 288 | } |
291 | qli.toFirst(); | 289 | qli.toFirst(); |
292 | while (qli) { | 290 | while (qli) { |
293 | for ( QStringList::Iterator it = mails.begin(); it != mails.end(); ++it ) { | 291 | for ( QStringList::Iterator it = mails.begin(); it != mails.end(); ++it ) { |
294 | if (qli.current()->email() == *it) | 292 | if (qli.current()->email() == *it) |
295 | return qli.current(); | 293 | return qli.current(); |
296 | } | 294 | } |
297 | 295 | ||
298 | ++qli; | 296 | ++qli; |
299 | } | 297 | } |
300 | return 0L; | 298 | return 0L; |
301 | } | 299 | } |
302 | 300 | ||
303 | void IncidenceBase::setDuration(int seconds) | 301 | void IncidenceBase::setDuration(int seconds) |
304 | { | 302 | { |
305 | mDuration = seconds; | 303 | mDuration = seconds; |
306 | setHasDuration(true); | 304 | setHasDuration(true); |
307 | } | 305 | } |
308 | 306 | ||
309 | int IncidenceBase::duration() const | 307 | int IncidenceBase::duration() const |
310 | { | 308 | { |
311 | return mDuration; | 309 | return mDuration; |
312 | } | 310 | } |
313 | 311 | ||
314 | void IncidenceBase::setHasDuration(bool b) | 312 | void IncidenceBase::setHasDuration(bool b) |
315 | { | 313 | { |
316 | mHasDuration = b; | 314 | mHasDuration = b; |
317 | } | 315 | } |
318 | 316 | ||
319 | bool IncidenceBase::hasDuration() const | 317 | bool IncidenceBase::hasDuration() const |
320 | { | 318 | { |
321 | return mHasDuration; | 319 | return mHasDuration; |
322 | } | 320 | } |
323 | 321 | ||
324 | void IncidenceBase::setSyncStatus(int stat) | 322 | void IncidenceBase::setSyncStatus(int stat) |
325 | { | 323 | { |
326 | if (mReadOnly) return; | 324 | if (mReadOnly) return; |
327 | mSyncStatus = stat; | 325 | mSyncStatus = stat; |
328 | } | 326 | } |
329 | 327 | ||
330 | int IncidenceBase::syncStatus() const | 328 | int IncidenceBase::syncStatus() const |
331 | { | 329 | { |
332 | return mSyncStatus; | 330 | return mSyncStatus; |
333 | } | 331 | } |
334 | 332 | ||
335 | void IncidenceBase::setPilotId( int id ) | 333 | void IncidenceBase::setPilotId( int id ) |
336 | { | 334 | { |
337 | if (mReadOnly) return; | 335 | if (mReadOnly) return; |
338 | mPilotId = id; | 336 | mPilotId = id; |
339 | } | 337 | } |
340 | 338 | ||
341 | int IncidenceBase::pilotId() const | 339 | int IncidenceBase::pilotId() const |
342 | { | 340 | { |
343 | return mPilotId; | 341 | return mPilotId; |
344 | } | 342 | } |
345 | void IncidenceBase::setZaurusId( int id ) | ||
346 | { | ||
347 | if (mReadOnly) return; | ||
348 | mZaurusId = id; | ||
349 | } | ||
350 | |||
351 | int IncidenceBase::zaurusId() const | ||
352 | { | ||
353 | return mZaurusId; | ||
354 | } | ||
355 | 343 | ||
356 | int IncidenceBase::zaurusUid() const | 344 | int IncidenceBase::zaurusUid() const |
357 | { | 345 | { |
358 | return mZaurusUid; | 346 | return mZaurusUid; |
359 | } | 347 | } |
360 | void IncidenceBase::setZaurusUid( int id ) | 348 | void IncidenceBase::setZaurusUid( int id ) |
361 | { | 349 | { |
362 | if (mReadOnly) return; | 350 | if (mReadOnly) return; |
363 | mZaurusUid = id; | 351 | mZaurusUid = id; |
364 | } | 352 | } |
365 | 353 | ||
366 | int IncidenceBase::tempSyncStat() const | 354 | int IncidenceBase::tempSyncStat() const |
367 | { | 355 | { |
368 | return mTempSyncStat; | 356 | return mTempSyncStat; |
369 | } | 357 | } |
370 | void IncidenceBase::setTempSyncStat( int id ) | 358 | void IncidenceBase::setTempSyncStat( int id ) |
371 | { | 359 | { |
372 | if (mReadOnly) return; | 360 | if (mReadOnly) return; |
373 | mTempSyncStat = id; | 361 | mTempSyncStat = id; |
374 | } | 362 | } |
375 | 363 | ||
376 | void IncidenceBase::setID( const QString & prof , int id ) | 364 | void IncidenceBase::setID( const QString & prof , int id ) |
377 | { | 365 | { |
378 | int num = mExternalId.find( ":"+prof+";" ); | 366 | int num = mExternalId.find( ":"+prof+";" ); |
379 | if ( num >= 0 ) { | 367 | if ( num >= 0 ) { |
380 | int len = prof.length()+2; | 368 | int len = prof.length()+2; |
381 | int end = mExternalId.find( ";", num+len ); | 369 | int end = mExternalId.find( ";", num+len ); |
382 | if ( end > 0 ) { | 370 | if ( end > 0 ) { |
383 | mExternalId = mExternalId.left( num+len ) +QString::number( id)+mExternalId.mid( end ); | 371 | mExternalId = mExternalId.left( num+len ) +QString::number( id)+mExternalId.mid( end ); |
384 | } else | 372 | } else |
385 | qDebug("Error in IncidenceBase::setID "); | 373 | qDebug("Error in IncidenceBase::setID "); |
386 | } else { | 374 | } else { |
387 | mExternalId += prof+";"+QString::number( id) +";0:"; | 375 | mExternalId += prof+";"+QString::number( id) +";0:"; |
388 | } | 376 | } |
389 | qDebug("setID*%s*%d*%s* ", prof.latin1(), id,mExternalId.latin1() ); | 377 | qDebug("setID*%s*%d*%s* ", prof.latin1(), id,mExternalId.latin1() ); |
390 | } | 378 | } |
391 | int IncidenceBase::getID( const QString & prof) | 379 | int IncidenceBase::getID( const QString & prof) |
392 | { | 380 | { |
393 | int ret = -1; | 381 | int ret = -1; |
394 | int num = mExternalId.find(":"+ prof+";" ); | 382 | int num = mExternalId.find(":"+ prof+";" ); |
395 | if ( num >= 0 ) { | 383 | if ( num >= 0 ) { |
396 | int len = prof.length()+2; | 384 | int len = prof.length()+2; |
397 | int end = mExternalId.find( ";", num+len ); | 385 | int end = mExternalId.find( ";", num+len ); |
398 | if ( end > 0 ) { | 386 | if ( end > 0 ) { |
399 | bool ok; | 387 | bool ok; |
400 | ret = mExternalId.mid ( num + len,end-len-num).toInt( &ok ); | 388 | ret = mExternalId.mid ( num + len,end-len-num).toInt( &ok ); |
401 | if (!ok) | 389 | if (!ok) |
402 | ret = -1; | 390 | ret = -1; |
403 | } | 391 | } |
404 | } | 392 | } |
405 | qDebug("getID*%s*%d*%s* ", prof.latin1(), ret,mExternalId.latin1() ); | 393 | qDebug("getID*%s*%d*%s* ", prof.latin1(), ret,mExternalId.latin1() ); |
406 | return ret; | 394 | return ret; |
407 | } | 395 | } |
408 | 396 | ||
409 | // example :Sharp_DTM;22;23566:TP;-1;8654:TPP;18;0: | 397 | // example :Sharp_DTM;22;23566:TP;-1;8654:TPP;18;0: |
410 | // format name;III;JJJ: III >= 0, may be -1. JJJ always >= 0 | 398 | // format name;III;JJJ: III >= 0, may be -1. JJJ always >= 0 |
411 | void IncidenceBase::setCsum( const QString & prof , int id ) | 399 | void IncidenceBase::setCsum( const QString & prof , int id ) |
412 | { | 400 | { |
413 | int num = mExternalId.find( ":"+prof+";"); | 401 | int num = mExternalId.find( ":"+prof+";"); |
414 | if ( num >= 0 ) { | 402 | if ( num >= 0 ) { |
415 | int len = prof.length()+2; | 403 | int len = prof.length()+2; |
416 | num = mExternalId.find( ";", num+len ); | 404 | num = mExternalId.find( ";", num+len ); |
417 | int end = mExternalId.find( ":", num+1 ); | 405 | int end = mExternalId.find( ":", num+1 ); |
418 | if ( end > 0 ) { | 406 | if ( end > 0 ) { |