summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiepim/backend/otodoaccessxml.cpp34
1 files changed, 17 insertions, 17 deletions
diff --git a/libopie2/opiepim/backend/otodoaccessxml.cpp b/libopie2/opiepim/backend/otodoaccessxml.cpp
index ab50604..7a08f12 100644
--- a/libopie2/opiepim/backend/otodoaccessxml.cpp
+++ b/libopie2/opiepim/backend/otodoaccessxml.cpp
@@ -162,556 +162,556 @@ bool OPimTodoAccessXML::load() {
162 if ( fd < 0 ) return false; 162 if ( fd < 0 ) return false;
163 163
164 if ( fstat(fd, &attribut ) == -1 ) { 164 if ( fstat(fd, &attribut ) == -1 ) {
165 ::close( fd ); 165 ::close( fd );
166 return false; 166 return false;
167 } 167 }
168 void* map_addr = ::mmap(NULL, attribut.st_size, PROT_READ, MAP_SHARED, fd, 0 ); 168 void* map_addr = ::mmap(NULL, attribut.st_size, PROT_READ, MAP_SHARED, fd, 0 );
169 if ( map_addr == ( (caddr_t)-1) ) { 169 if ( map_addr == ( (caddr_t)-1) ) {
170 ::close(fd ); 170 ::close(fd );
171 return false; 171 return false;
172 } 172 }
173 /* advise the kernel who we want to read it */ 173 /* advise the kernel who we want to read it */
174 ::madvise( map_addr, attribut.st_size, MADV_SEQUENTIAL ); 174 ::madvise( map_addr, attribut.st_size, MADV_SEQUENTIAL );
175 /* we do not the file any more */ 175 /* we do not the file any more */
176 ::close( fd ); 176 ::close( fd );
177 177
178 char* dt = (char*)map_addr; 178 char* dt = (char*)map_addr;
179 int len = attribut.st_size; 179 int len = attribut.st_size;
180 int i = 0; 180 int i = 0;
181 char *point; 181 char *point;
182 const char* collectionString = "<Task "; 182 const char* collectionString = "<Task ";
183 int strLen = strlen(collectionString); 183 int strLen = strlen(collectionString);
184 while ( ( point = strstrlen( dt+i, len -i, collectionString, strLen ) ) != 0l ) { 184 while ( ( point = strstrlen( dt+i, len -i, collectionString, strLen ) ) != 0l ) {
185 i = point -dt; 185 i = point -dt;
186 i+= strLen; 186 i+= strLen;
187 187
188 OPimTodo ev; 188 OPimTodo ev;
189 m_year = m_month = m_day = 0; 189 m_year = m_month = m_day = 0;
190 190
191 while ( TRUE ) { 191 while ( TRUE ) {
192 while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') ) 192 while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') )
193 ++i; 193 ++i;
194 if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') ) 194 if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') )
195 break; 195 break;
196 196
197 // we have another attribute, read it. 197 // we have another attribute, read it.
198 int j = i; 198 int j = i;
199 while ( j < len && dt[j] != '=' ) 199 while ( j < len && dt[j] != '=' )
200 ++j; 200 ++j;
201 QCString attr( dt+i, j-i+1); 201 QCString attr( dt+i, j-i+1);
202 202
203 i = ++j; // skip = 203 i = ++j; // skip =
204 204
205 // find the start of quotes 205 // find the start of quotes
206 while ( i < len && dt[i] != '"' ) 206 while ( i < len && dt[i] != '"' )
207 ++i; 207 ++i;
208 j = ++i; 208 j = ++i;
209 209
210 bool haveUtf = FALSE; 210 bool haveUtf = FALSE;
211 bool haveEnt = FALSE; 211 bool haveEnt = FALSE;
212 while ( j < len && dt[j] != '"' ) { 212 while ( j < len && dt[j] != '"' ) {
213 if ( ((unsigned char)dt[j]) > 0x7f ) 213 if ( ((unsigned char)dt[j]) > 0x7f )
214 haveUtf = TRUE; 214 haveUtf = TRUE;
215 if ( dt[j] == '&' ) 215 if ( dt[j] == '&' )
216 haveEnt = TRUE; 216 haveEnt = TRUE;
217 ++j; 217 ++j;
218 } 218 }
219 if ( i == j ) { 219 if ( i == j ) {
220 // empty value 220 // empty value
221 i = j + 1; 221 i = j + 1;
222 continue; 222 continue;
223 } 223 }
224 224
225 QCString value( dt+i, j-i+1 ); 225 QCString value( dt+i, j-i+1 );
226 i = j + 1; 226 i = j + 1;
227 227
228 QString str = (haveUtf ? QString::fromUtf8( value ) 228 QString str = (haveUtf ? QString::fromUtf8( value )
229 : QString::fromLatin1( value ) ); 229 : QString::fromLatin1( value ) );
230 if ( haveEnt ) 230 if ( haveEnt )
231 str = Qtopia::plainString( str ); 231 str = Qtopia::plainString( str );
232 232
233 /* 233 /*
234 * add key + value 234 * add key + value
235 */ 235 */
236 todo( &dict, ev, attr, str ); 236 todo( &dict, ev, attr, str );
237 237
238 } 238 }
239 /* 239 /*
240 * now add it 240 * now add it
241 */ 241 */
242 if (m_events.contains( ev.uid() ) || ev.uid() == 0) { 242 if (m_events.contains( ev.uid() ) || ev.uid() == 0) {
243 ev.setUid( 1 ); 243 ev.setUid( 1 );
244 m_changed = true; 244 m_changed = true;
245 } 245 }
246 if ( ev.hasDueDate() ) { 246 if ( ev.hasDueDate() ) {
247 ev.setDueDate( QDate(m_year, m_month, m_day) ); 247 ev.setDueDate( QDate(m_year, m_month, m_day) );
248 } 248 }
249 if ( rec && rec->doesRecur() ) { 249 if ( rec && rec->doesRecur() ) {
250 OPimTimeZone utc = OPimTimeZone::utc(); 250 OPimTimeZone utc = OPimTimeZone::utc();
251 OPimRecurrence recu( *rec ); // call copy c'tor 251 OPimRecurrence recu( *rec ); // call copy c'tor
252 recu.setEndDate( utc.fromUTCDateTime( rp_end ).date() ); 252 recu.setEndDate( utc.fromUTCDateTime( rp_end ).date() );
253 recu.setStart( ev.dueDate() ); 253 recu.setStart( ev.dueDate() );
254 ev.setRecurrence( recu ); 254 ev.setRecurrence( recu );
255 } 255 }
256 m_events.insert(ev.uid(), ev ); 256 m_events.insert(ev.uid(), ev );
257 m_year = m_month = m_day = -1; 257 m_year = m_month = m_day = -1;
258 delete rec; 258 delete rec;
259 rec = 0; 259 rec = 0;
260 } 260 }
261 261
262 munmap(map_addr, attribut.st_size ); 262 munmap(map_addr, attribut.st_size );
263 263
264 return true; 264 return true;
265} 265}
266bool OPimTodoAccessXML::reload() { 266bool OPimTodoAccessXML::reload() {
267 m_events.clear(); 267 m_events.clear();
268 return load(); 268 return load();
269} 269}
270bool OPimTodoAccessXML::save() { 270bool OPimTodoAccessXML::save() {
271 if (!m_opened || !m_changed ) { 271 if (!m_opened || !m_changed ) {
272 return true; 272 return true;
273 } 273 }
274 QString strNewFile = m_file + ".new"; 274 QString strNewFile = m_file + ".new";
275 QFile f( strNewFile ); 275 QFile f( strNewFile );
276 if (!f.open( IO_WriteOnly|IO_Raw ) ) 276 if (!f.open( IO_WriteOnly|IO_Raw ) )
277 return false; 277 return false;
278 278
279 int written; 279 int written;
280 QString out; 280 QString out;
281 out = "<!DOCTYPE Tasks>\n<Tasks>\n"; 281 out = "<!DOCTYPE Tasks>\n<Tasks>\n";
282 282
283 // for all todos 283 // for all todos
284 QMap<int, OPimTodo>::Iterator it; 284 QMap<int, OPimTodo>::Iterator it;
285 for (it = m_events.begin(); it != m_events.end(); ++it ) { 285 for (it = m_events.begin(); it != m_events.end(); ++it ) {
286 out+= "<Task " + toString( (*it) ) + " />\n"; 286 out+= "<Task " + toString( (*it) ) + " />\n";
287 QCString cstr = out.utf8(); 287 QCString cstr = out.utf8();
288 written = f.writeBlock( cstr.data(), cstr.length() ); 288 written = f.writeBlock( cstr.data(), cstr.length() );
289 289
290 /* less written then we wanted */ 290 /* less written then we wanted */
291 if ( written != (int)cstr.length() ) { 291 if ( written != (int)cstr.length() ) {
292 f.close(); 292 f.close();
293 QFile::remove( strNewFile ); 293 QFile::remove( strNewFile );
294 return false; 294 return false;
295 } 295 }
296 out = QString::null; 296 out = QString::null;
297 } 297 }
298 298
299 out += "</Tasks>"; 299 out += "</Tasks>";
300 QCString cstr = out.utf8(); 300 QCString cstr = out.utf8();
301 written = f.writeBlock( cstr.data(), cstr.length() ); 301 written = f.writeBlock( cstr.data(), cstr.length() );
302 302
303 if ( written != (int)cstr.length() ) { 303 if ( written != (int)cstr.length() ) {
304 f.close(); 304 f.close();
305 QFile::remove( strNewFile ); 305 QFile::remove( strNewFile );
306 return false; 306 return false;
307 } 307 }
308 /* flush before renaming */ 308 /* flush before renaming */
309 f.close(); 309 f.close();
310 310
311 if( ::rename( strNewFile.latin1(), m_file.latin1() ) < 0 ) { 311 if( ::rename( strNewFile.latin1(), m_file.latin1() ) < 0 ) {
312 QFile::remove( strNewFile ); 312 QFile::remove( strNewFile );
313 } 313 }
314 314
315 m_changed = false; 315 m_changed = false;
316 return true; 316 return true;
317} 317}
318QArray<int> OPimTodoAccessXML::allRecords()const { 318QArray<int> OPimTodoAccessXML::allRecords()const {
319 QArray<int> ids( m_events.count() ); 319 QArray<int> ids( m_events.count() );
320 QMap<int, OPimTodo>::ConstIterator it; 320 QMap<int, OPimTodo>::ConstIterator it;
321 int i = 0; 321 int i = 0;
322 322
323 for ( it = m_events.begin(); it != m_events.end(); ++it ) 323 for ( it = m_events.begin(); it != m_events.end(); ++it )
324 ids[i++] = it.key(); 324 ids[i++] = it.key();
325 325
326 326
327 return ids; 327 return ids;
328} 328}
329 329
330OPimTodo OPimTodoAccessXML::find( int uid )const { 330OPimTodo OPimTodoAccessXML::find( int uid )const {
331 OPimTodo todo; 331 OPimTodo todo;
332 todo.setUid( 0 ); // isEmpty() 332 todo.setUid( 0 ); // isEmpty()
333 QMap<int, OPimTodo>::ConstIterator it = m_events.find( uid ); 333 QMap<int, OPimTodo>::ConstIterator it = m_events.find( uid );
334 if ( it != m_events.end() ) 334 if ( it != m_events.end() )
335 todo = it.data(); 335 todo = it.data();
336 336
337 return todo; 337 return todo;
338} 338}
339void OPimTodoAccessXML::clear() { 339void OPimTodoAccessXML::clear() {
340 if (m_opened ) 340 if (m_opened )
341 m_changed = true; 341 m_changed = true;
342 342
343 m_events.clear(); 343 m_events.clear();
344} 344}
345bool OPimTodoAccessXML::add( const OPimTodo& todo ) { 345bool OPimTodoAccessXML::add( const OPimTodo& todo ) {
346 m_changed = true; 346 m_changed = true;
347 m_events.insert( todo.uid(), todo ); 347 m_events.insert( todo.uid(), todo );
348 348
349 return true; 349 return true;
350} 350}
351bool OPimTodoAccessXML::remove( int uid ) { 351bool OPimTodoAccessXML::remove( int uid ) {
352 m_changed = true; 352 m_changed = true;
353 m_events.remove( uid ); 353 m_events.remove( uid );
354 354
355 return true; 355 return true;
356} 356}
357bool OPimTodoAccessXML::replace( const OPimTodo& todo) { 357bool OPimTodoAccessXML::replace( const OPimTodo& todo) {
358 m_changed = true; 358 m_changed = true;
359 m_events.replace( todo.uid(), todo ); 359 m_events.replace( todo.uid(), todo );
360 360
361 return true; 361 return true;
362} 362}
363QArray<int> OPimTodoAccessXML::effectiveToDos( const QDate& start, 363QArray<int> OPimTodoAccessXML::effectiveToDos( const QDate& start,
364 const QDate& end, 364 const QDate& end,
365 bool includeNoDates )const { 365 bool includeNoDates )const {
366 QArray<int> ids( m_events.count() ); 366 QArray<int> ids( m_events.count() );
367 QMap<int, OPimTodo>::ConstIterator it; 367 QMap<int, OPimTodo>::ConstIterator it;
368 368
369 int i = 0; 369 int i = 0;
370 for ( it = m_events.begin(); it != m_events.end(); ++it ) { 370 for ( it = m_events.begin(); it != m_events.end(); ++it ) {
371 if ( !it.data().hasDueDate() && includeNoDates) { 371 if ( !it.data().hasDueDate() && includeNoDates) {
372 ids[i++] = it.key(); 372 ids[i++] = it.key();
373 }else if ( it.data().dueDate() >= start && 373 }else if ( it.data().dueDate() >= start &&
374 it.data().dueDate() <= end ) { 374 it.data().dueDate() <= end ) {
375 ids[i++] = it.key(); 375 ids[i++] = it.key();
376 } 376 }
377 } 377 }
378 ids.resize( i ); 378 ids.resize( i );
379 return ids; 379 return ids;
380} 380}
381QArray<int> OPimTodoAccessXML::overDue()const { 381QArray<int> OPimTodoAccessXML::overDue()const {
382 QArray<int> ids( m_events.count() ); 382 QArray<int> ids( m_events.count() );
383 int i = 0; 383 int i = 0;
384 384
385 QMap<int, OPimTodo>::ConstIterator it; 385 QMap<int, OPimTodo>::ConstIterator it;
386 for ( it = m_events.begin(); it != m_events.end(); ++it ) { 386 for ( it = m_events.begin(); it != m_events.end(); ++it ) {
387 if ( it.data().isOverdue() ) { 387 if ( it.data().isOverdue() ) {
388 ids[i] = it.key(); 388 ids[i] = it.key();
389 i++; 389 i++;
390 } 390 }
391 } 391 }
392 ids.resize( i ); 392 ids.resize( i );
393 return ids; 393 return ids;
394} 394}
395 395
396 396
397/* private */ 397/* private */
398void OPimTodoAccessXML::todo( QAsciiDict<int>* dict, OPimTodo& ev, 398void OPimTodoAccessXML::todo( QAsciiDict<int>* dict, OPimTodo& ev,
399 const QCString& attr, const QString& val) { 399 const QCString& attr, const QString& val) {
400 400
401 int *find=0; 401 int *find=0;
402 402
403 find = (*dict)[ attr.data() ]; 403 find = (*dict)[ attr.data() ];
404 if (!find ) { 404 if (!find ) {
405 ev.setCustomField( attr, val ); 405 ev.setCustomField( attr, val );
406 return; 406 return;
407 } 407 }
408 408
409 switch( *find ) { 409 switch( *find ) {
410 case OPimTodo::Uid: 410 case OPimTodo::Uid:
411 ev.setUid( val.toInt() ); 411 ev.setUid( val.toInt() );
412 break; 412 break;
413 case OPimTodo::Category: 413 case OPimTodo::Category:
414 ev.setCategories( ev.idsFromString( val ) ); 414 ev.setCategories( ev.idsFromString( val ) );
415 break; 415 break;
416 case OPimTodo::HasDate: 416 case OPimTodo::HasDate:
417 ev.setHasDueDate( val.toInt() ); 417 ev.setHasDueDate( val.toInt() );
418 break; 418 break;
419 case OPimTodo::Completed: 419 case OPimTodo::Completed:
420 ev.setCompleted( val.toInt() ); 420 ev.setCompleted( val.toInt() );
421 break; 421 break;
422 case OPimTodo::Description: 422 case OPimTodo::Description:
423 ev.setDescription( val ); 423 ev.setDescription( val );
424 break; 424 break;
425 case OPimTodo::Summary: 425 case OPimTodo::Summary:
426 ev.setSummary( val ); 426 ev.setSummary( val );
427 break; 427 break;
428 case OPimTodo::Priority: 428 case OPimTodo::Priority:
429 ev.setPriority( val.toInt() ); 429 ev.setPriority( val.toInt() );
430 break; 430 break;
431 case OPimTodo::DateDay: 431 case OPimTodo::DateDay:
432 m_day = val.toInt(); 432 m_day = val.toInt();
433 break; 433 break;
434 case OPimTodo::DateMonth: 434 case OPimTodo::DateMonth:
435 m_month = val.toInt(); 435 m_month = val.toInt();
436 break; 436 break;
437 case OPimTodo::DateYear: 437 case OPimTodo::DateYear:
438 m_year = val.toInt(); 438 m_year = val.toInt();
439 break; 439 break;
440 case OPimTodo::Progress: 440 case OPimTodo::Progress:
441 ev.setProgress( val.toInt() ); 441 ev.setProgress( val.toInt() );
442 break; 442 break;
443 case OPimTodo::CompletedDate: 443 case OPimTodo::CompletedDate:
444 ev.setCompletedDate( OPimDateConversion::dateFromString( val ) ); 444 ev.setCompletedDate( OPimDateConversion::dateFromString( val ) );
445 break; 445 break;
446 case OPimTodo::StartDate: 446 case OPimTodo::StartDate:
447 ev.setStartDate( OPimDateConversion::dateFromString( val ) ); 447 ev.setStartDate( OPimDateConversion::dateFromString( val ) );
448 break; 448 break;
449 case OPimTodo::State: 449 case OPimTodo::State:
450 ev.setState( val.toInt() ); 450 ev.setState( val.toInt() );
451 break; 451 break;
452 case OPimTodo::Alarms:{ 452 case OPimTodo::Alarms:{
453 OPimNotifyManager &manager = ev.notifiers(); 453 OPimNotifyManager &manager = ev.notifiers();
454 QStringList als = QStringList::split(";", val ); 454 QStringList als = QStringList::split(";", val );
455 for (QStringList::Iterator it = als.begin(); it != als.end(); ++it ) { 455 for (QStringList::Iterator it = als.begin(); it != als.end(); ++it ) {
456 QStringList alarm = QStringList::split(":", (*it), TRUE ); // allow empty 456 QStringList alarm = QStringList::split(":", (*it), TRUE ); // allow empty
457 OPimAlarm al( alarm[2].toInt(), OPimDateConversion::dateTimeFromString( alarm[0] ), alarm[1].toInt() ); 457 OPimAlarm al( alarm[2].toInt(), OPimDateConversion::dateTimeFromString( alarm[0] ), alarm[1].toInt() );
458 manager.add( al ); 458 manager.add( al );
459 } 459 }
460 } 460 }
461 break; 461 break;
462 case OPimTodo::Reminders:{ 462 case OPimTodo::Reminders:{
463 OPimNotifyManager &manager = ev.notifiers(); 463 OPimNotifyManager &manager = ev.notifiers();
464 QStringList rems = QStringList::split(";", val ); 464 QStringList rems = QStringList::split(";", val );
465 for (QStringList::Iterator it = rems.begin(); it != rems.end(); ++it ) { 465 for (QStringList::Iterator it = rems.begin(); it != rems.end(); ++it ) {
466 OPimReminder rem( (*it).toInt() ); 466 OPimReminder rem( (*it).toInt() );
467 manager.add( rem ); 467 manager.add( rem );
468 } 468 }
469 } 469 }
470 break; 470 break;
471 case OPimTodo::CrossReference: 471 case OPimTodo::CrossReference:
472 { 472 {
473 /* 473 /*
474 * A cross refernce looks like 474 * A cross refernce looks like
475 * appname,id;appname,id 475 * appname,id;appname,id
476 * we need to split it up 476 * we need to split it up
477 */ 477 */
478 QStringList refs = QStringList::split(';', val ); 478 QStringList refs = QStringList::split(';', val );
479 QStringList::Iterator strIt; 479 QStringList::Iterator strIt;
480 for (strIt = refs.begin(); strIt != refs.end(); ++strIt ) { 480 for (strIt = refs.begin(); strIt != refs.end(); ++strIt ) {
481 int pos = (*strIt).find(','); 481 int pos = (*strIt).find(',');
482 if ( pos > -1 ) 482 if ( pos > -1 )
483 ; // ev.addRelation( (*strIt).left(pos), (*strIt).mid(pos+1).toInt() ); 483 ; // ev.addRelation( (*strIt).left(pos), (*strIt).mid(pos+1).toInt() );
484 484
485 } 485 }
486 break; 486 break;
487 } 487 }
488 /* Recurrence stuff below + post processing later */ 488 /* Recurrence stuff below + post processing later */
489 case FRType: 489 case FRType:
490 if ( val == "Daily" ) 490 if ( val == "Daily" )
491 recur()->setType( OPimRecurrence::Daily ); 491 recur()->setType( OPimRecurrence::Daily );
492 else if ( val == "Weekly" ) 492 else if ( val == "Weekly" )
493 recur()->setType( OPimRecurrence::Weekly); 493 recur()->setType( OPimRecurrence::Weekly);
494 else if ( val == "MonthlyDay" ) 494 else if ( val == "MonthlyDay" )
495 recur()->setType( OPimRecurrence::MonthlyDay ); 495 recur()->setType( OPimRecurrence::MonthlyDay );
496 else if ( val == "MonthlyDate" ) 496 else if ( val == "MonthlyDate" )
497 recur()->setType( OPimRecurrence::MonthlyDate ); 497 recur()->setType( OPimRecurrence::MonthlyDate );
498 else if ( val == "Yearly" ) 498 else if ( val == "Yearly" )
499 recur()->setType( OPimRecurrence::Yearly ); 499 recur()->setType( OPimRecurrence::Yearly );
500 else 500 else
501 recur()->setType( OPimRecurrence::NoRepeat ); 501 recur()->setType( OPimRecurrence::NoRepeat );
502 break; 502 break;
503 case FRWeekdays: 503 case FRWeekdays:
504 recur()->setDays( val.toInt() ); 504 recur()->setDays( val.toInt() );
505 break; 505 break;
506 case FRPosition: 506 case FRPosition:
507 recur()->setPosition( val.toInt() ); 507 recur()->setPosition( val.toInt() );
508 break; 508 break;
509 case FRFreq: 509 case FRFreq:
510 recur()->setFrequency( val.toInt() ); 510 recur()->setFrequency( val.toInt() );
511 break; 511 break;
512 case FRHasEndDate: 512 case FRHasEndDate:
513 recur()->setHasEndDate( val.toInt() ); 513 recur()->setHasEndDate( val.toInt() );
514 break; 514 break;
515 case FREndDate: { 515 case FREndDate: {
516 rp_end = (time_t) val.toLong(); 516 rp_end = (time_t) val.toLong();
517 break; 517 break;
518 } 518 }
519 default: 519 default:
520 ev.setCustomField( attr, val ); 520 ev.setCustomField( attr, val );
521 break; 521 break;
522 } 522 }
523} 523}
524 524
525// from PalmtopRecord... GPL ### FIXME 525// from PalmtopRecord... GPL ### FIXME
526namespace { 526namespace {
527QString customToXml(const QMap<QString, QString>& customMap ) 527QString customToXml(const QMap<QString, QString>& customMap )
528{ 528{
529 QString buf(" "); 529 QString buf(" ");
530 for ( QMap<QString, QString>::ConstIterator cit = customMap.begin(); 530 for ( QMap<QString, QString>::ConstIterator cit = customMap.begin();
531 cit != customMap.end(); ++cit) { 531 cit != customMap.end(); ++cit) {
532 buf += cit.key(); 532 buf += cit.key();
533 buf += "=\""; 533 buf += "=\"";
534 buf += Qtopia::escapeString(cit.data()); 534 buf += Qtopia::escapeString(cit.data());
535 buf += "\" "; 535 buf += "\" ";
536 } 536 }
537 return buf; 537 return buf;
538} 538}
539 539
540 540
541} 541}
542 542
543QString OPimTodoAccessXML::toString( const OPimTodo& ev )const { 543QString OPimTodoAccessXML::toString( const OPimTodo& ev )const {
544 QString str; 544 QString str;
545 545
546 str += "Completed=\"" + QString::number( ev.isCompleted() ) + "\" "; 546 str += "Completed=\"" + QString::number( ev.isCompleted() ) + "\"";
547 str += "HasDate=\"" + QString::number( ev.hasDueDate() ) + "\" "; 547 str += " HasDate=\"" + QString::number( ev.hasDueDate() ) + "\"";
548 str += "Priority=\"" + QString::number( ev.priority() ) + "\" "; 548 str += " Priority=\"" + QString::number( ev.priority() ) + "\"";
549 str += "Progress=\"" + QString::number(ev.progress() ) + "\" "; 549 str += " Progress=\"" + QString::number(ev.progress() ) + "\"";
550 550
551 str += "Categories=\"" + toString( ev.categories() ) + "\" "; 551 str += " Categories=\"" + toString( ev.categories() ) + "\"";
552 str += "Description=\"" + Qtopia::escapeString( ev.description() ) + "\" "; 552 str += " Description=\"" + Qtopia::escapeString( ev.description() ) + "\"";
553 str += "Summary=\"" + Qtopia::escapeString( ev.summary() ) + "\" "; 553 str += " Summary=\"" + Qtopia::escapeString( ev.summary() ) + "\"";
554 554
555 if ( ev.hasDueDate() ) { 555 if ( ev.hasDueDate() ) {
556 str += "DateYear=\"" + QString::number( ev.dueDate().year() ) + "\" "; 556 str += " DateYear=\"" + QString::number( ev.dueDate().year() ) + "\"";
557 str += "DateMonth=\"" + QString::number( ev.dueDate().month() ) + "\" "; 557 str += " DateMonth=\"" + QString::number( ev.dueDate().month() ) + "\"";
558 str += "DateDay=\"" + QString::number( ev.dueDate().day() ) + "\" "; 558 str += " DateDay=\"" + QString::number( ev.dueDate().day() ) + "\"";
559 } 559 }
560 str += "Uid=\"" + QString::number( ev.uid() ) + "\" "; 560 str += " Uid=\"" + QString::number( ev.uid() ) + "\"";
561 561
562// append the extra options 562// append the extra options
563 /* FIXME Qtopia::Record this is currently not 563 /* FIXME Qtopia::Record this is currently not
564 * possible you can set custom fields 564 * possible you can set custom fields
565 * but don' iterate over the list 565 * but don' iterate over the list
566 * I may do #define private protected 566 * I may do #define private protected
567 * for this case - cough --zecke 567 * for this case - cough --zecke
568 */ 568 */
569 /* 569 /*
570 QMap<QString, QString> extras = ev.extras(); 570 QMap<QString, QString> extras = ev.extras();
571 QMap<QString, QString>::Iterator extIt; 571 QMap<QString, QString>::Iterator extIt;
572 for (extIt = extras.begin(); extIt != extras.end(); ++extIt ) 572 for (extIt = extras.begin(); extIt != extras.end(); ++extIt )
573 str += extIt.key() + "=\"" + extIt.data() + "\" "; 573 str += " " + extIt.key() + "=\"" + extIt.data() + "\"";
574 */ 574 */
575 // cross refernce 575 // cross refernce
576 if ( ev.hasRecurrence() ) { 576 if ( ev.hasRecurrence() ) {
577 str += ev.recurrence().toString(); 577 str += ev.recurrence().toString();
578 } 578 }
579 if ( ev.hasStartDate() ) 579 if ( ev.hasStartDate() )
580 str += "StartDate=\""+ OPimDateConversion::dateToString( ev.startDate() ) +"\" "; 580 str += " StartDate=\""+ OPimDateConversion::dateToString( ev.startDate() ) +"\"";
581 if ( ev.hasCompletedDate() ) 581 if ( ev.hasCompletedDate() )
582 str += "CompletedDate=\""+ OPimDateConversion::dateToString( ev.completedDate() ) +"\" "; 582 str += " CompletedDate=\""+ OPimDateConversion::dateToString( ev.completedDate() ) +"\"";
583 if ( ev.hasState() ) 583 if ( ev.hasState() )
584 str += "State=\""+QString::number( ev.state().state() )+"\" "; 584 str += " State=\""+QString::number( ev.state().state() )+"\"";
585 585
586 /* 586 /*
587 * save reminders and notifiers! 587 * save reminders and notifiers!
588 * DATE_TIME:DURATION:SOUND:NOT_USED_YET;OTHER_DATE_TIME:OTHER_DURATION:SOUND:.... 588 * DATE_TIME:DURATION:SOUND:NOT_USED_YET;OTHER_DATE_TIME:OTHER_DURATION:SOUND:....
589 */ 589 */
590 if ( ev.hasNotifiers() ) { 590 if ( ev.hasNotifiers() ) {
591 OPimNotifyManager manager = ev.notifiers(); 591 OPimNotifyManager manager = ev.notifiers();
592 OPimNotifyManager::Alarms alarms = manager.alarms(); 592 OPimNotifyManager::Alarms alarms = manager.alarms();
593 if (!alarms.isEmpty() ) { 593 if (!alarms.isEmpty() ) {
594 QStringList als; 594 QStringList als;
595 OPimNotifyManager::Alarms::Iterator it = alarms.begin(); 595 OPimNotifyManager::Alarms::Iterator it = alarms.begin();
596 for ( ; it != alarms.end(); ++it ) { 596 for ( ; it != alarms.end(); ++it ) {
597 /* only if time is valid */ 597 /* only if time is valid */
598 if ( (*it).dateTime().isValid() ) { 598 if ( (*it).dateTime().isValid() ) {
599 als << OPimDateConversion::dateTimeToString( (*it).dateTime() ) 599 als << OPimDateConversion::dateTimeToString( (*it).dateTime() )
600 + ":" + QString::number( (*it).duration() ) 600 + ":" + QString::number( (*it).duration() )
601 + ":" + QString::number( (*it).sound() ) 601 + ":" + QString::number( (*it).sound() )
602 + ":"; 602 + ":";
603 } 603 }
604 } 604 }
605 // now write the list 605 // now write the list
606 str += "Alarms=\""+als.join(";") +"\" "; 606 str += " Alarms=\""+als.join(";") +"\"";
607 } 607 }
608 608
609 /* 609 /*
610 * now the same for reminders but more easy. We just save the uid of the OPimEvent. 610 * now the same for reminders but more easy. We just save the uid of the OPimEvent.
611 */ 611 */
612 OPimNotifyManager::Reminders reminders = manager.reminders(); 612 OPimNotifyManager::Reminders reminders = manager.reminders();
613 if (!reminders.isEmpty() ) { 613 if (!reminders.isEmpty() ) {
614 OPimNotifyManager::Reminders::Iterator it = reminders.begin(); 614 OPimNotifyManager::Reminders::Iterator it = reminders.begin();
615 QStringList records; 615 QStringList records;
616 for ( ; it != reminders.end(); ++it ) { 616 for ( ; it != reminders.end(); ++it ) {
617 records << QString::number( (*it).recordUid() ); 617 records << QString::number( (*it).recordUid() );
618 } 618 }
619 str += "Reminders=\""+ records.join(";") +"\" "; 619 str += " Reminders=\""+ records.join(";") +"\"";
620 } 620 }
621 } 621 }
622 str += customToXml( ev.toExtraMap() ); 622 str += customToXml( ev.toExtraMap() );
623 623
624 624
625 return str; 625 return str;
626} 626}
627QString OPimTodoAccessXML::toString( const QArray<int>& ints ) const { 627QString OPimTodoAccessXML::toString( const QArray<int>& ints ) const {
628 return Qtopia::Record::idsToString( ints ); 628 return Qtopia::Record::idsToString( ints );
629} 629}
630 630
631 631
632QArray<int> OPimTodoAccessXML::sorted( const UIDArray& events, bool asc, 632QArray<int> OPimTodoAccessXML::sorted( const UIDArray& events, bool asc,
633 int sortOrder,int sortFilter, 633 int sortOrder,int sortFilter,
634 const QArray<int>& categories )const { 634 const QArray<int>& categories )const {
635 Internal::OPimTodoSortVector vector(events.count(), asc,sortOrder ); 635 Internal::OPimTodoSortVector vector(events.count(), asc,sortOrder );
636 int item = 0; 636 int item = 0;
637 637
638 bool bCat = sortFilter & OPimTodoAccess::FilterCategory ? true : false; 638 bool bCat = sortFilter & OPimTodoAccess::FilterCategory ? true : false;
639 bool bOnly = sortFilter & OPimTodoAccess::OnlyOverDue ? true : false; 639 bool bOnly = sortFilter & OPimTodoAccess::OnlyOverDue ? true : false;
640 bool comp = sortFilter & OPimTodoAccess::DoNotShowCompleted ? true : false; 640 bool comp = sortFilter & OPimTodoAccess::DoNotShowCompleted ? true : false;
641 bool catPassed = false; 641 bool catPassed = false;
642 int cat; 642 int cat;
643 643
644 for ( uint i = 0; i < events.count(); ++i ) { 644 for ( uint i = 0; i < events.count(); ++i ) {
645 /* Guard against creating a new item... */ 645 /* Guard against creating a new item... */
646 if ( !m_events.contains( events[i] ) ) 646 if ( !m_events.contains( events[i] ) )
647 continue; 647 continue;
648 648
649 OPimTodo todo = m_events[events[i]]; 649 OPimTodo todo = m_events[events[i]];
650 650
651 /* show category */ 651 /* show category */
652 /* -1 == unfiled */ 652 /* -1 == unfiled */
653 catPassed = false; 653 catPassed = false;
654 for ( uint cat_nu = 0; cat_nu < categories.count(); ++cat_nu ) { 654 for ( uint cat_nu = 0; cat_nu < categories.count(); ++cat_nu ) {
655 cat = categories[cat_nu]; 655 cat = categories[cat_nu];
656 if ( bCat && cat == -1 ) { 656 if ( bCat && cat == -1 ) {
657 if(!todo.categories().isEmpty() ) 657 if(!todo.categories().isEmpty() )
658 continue; 658 continue;
659 } else if ( bCat && cat != 0) 659 } else if ( bCat && cat != 0)
660 if (!todo.categories().contains( cat ) ) 660 if (!todo.categories().contains( cat ) )
661 continue; 661 continue;
662 catPassed = true; 662 catPassed = true;
663 break; 663 break;
664 } 664 }
665 665
666 /* 666 /*
667 * If none of the Categories matched 667 * If none of the Categories matched
668 * continue 668 * continue
669 */ 669 */
670 if ( !catPassed ) 670 if ( !catPassed )
671 continue; 671 continue;
672 if ( !todo.isOverdue() && bOnly ) 672 if ( !todo.isOverdue() && bOnly )
673 continue; 673 continue;
674 if (todo.isCompleted() && comp ) 674 if (todo.isCompleted() && comp )
675 continue; 675 continue;
676 676
677 vector.insert(item++, todo ); 677 vector.insert(item++, todo );
678 } 678 }
679 679
680 vector.resize( item ); 680 vector.resize( item );
681 /* sort it now */ 681 /* sort it now */
682 vector.sort(); 682 vector.sort();
683 /* now get the uids */ 683 /* now get the uids */
684 UIDArray array( vector.count() ); 684 UIDArray array( vector.count() );
685 for (uint i= 0; i < vector.count(); i++ ) 685 for (uint i= 0; i < vector.count(); i++ )
686 array[i] = vector.uidAt( i ); 686 array[i] = vector.uidAt( i );
687 687
688 return array; 688 return array;
689} 689}
690 690
691void OPimTodoAccessXML::removeAllCompleted() { 691void OPimTodoAccessXML::removeAllCompleted() {
692 QMap<int, OPimTodo> events = m_events; 692 QMap<int, OPimTodo> events = m_events;
693 for ( QMap<int, OPimTodo>::Iterator it = m_events.begin(); it != m_events.end(); ++it ) { 693 for ( QMap<int, OPimTodo>::Iterator it = m_events.begin(); it != m_events.end(); ++it ) {
694 if ( (*it).isCompleted() ) 694 if ( (*it).isCompleted() )
695 events.remove( it.key() ); 695 events.remove( it.key() );
696 } 696 }
697 m_events = events; 697 m_events = events;
698} 698}
699 699
700QArray<int> OPimTodoAccessXML::matchRegexp( const QRegExp &r ) const 700QArray<int> OPimTodoAccessXML::matchRegexp( const QRegExp &r ) const
701{ 701{
702 QArray<int> currentQuery( m_events.count() ); 702 QArray<int> currentQuery( m_events.count() );
703 uint arraycounter = 0; 703 uint arraycounter = 0;
704 704
705 QMap<int, OPimTodo>::ConstIterator it; 705 QMap<int, OPimTodo>::ConstIterator it;
706 for (it = m_events.begin(); it != m_events.end(); ++it ) { 706 for (it = m_events.begin(); it != m_events.end(); ++it ) {
707 if ( it.data().match( r ) ) 707 if ( it.data().match( r ) )
708 currentQuery[arraycounter++] = it.data().uid(); 708 currentQuery[arraycounter++] = it.data().uid();
709 709
710 } 710 }
711 // Shrink to fit.. 711 // Shrink to fit..
712 currentQuery.resize(arraycounter); 712 currentQuery.resize(arraycounter);
713 713
714 return currentQuery; 714 return currentQuery;
715} 715}
716 716
717} 717}