-rw-r--r-- | kabc/addressbook.cpp | 9 | ||||
-rw-r--r-- | kaddressbook/kabcore.cpp | 3 |
2 files changed, 10 insertions, 2 deletions
diff --git a/kabc/addressbook.cpp b/kabc/addressbook.cpp index 3ec0795..d03dea3 100644 --- a/kabc/addressbook.cpp +++ b/kabc/addressbook.cpp | |||
@@ -431,66 +431,71 @@ Ticket *AddressBook::requestSaveTicket( Resource *resource ) | |||
431 | qDebug("AddressBook::requestSaveTicket no resource" ); | 431 | qDebug("AddressBook::requestSaveTicket no resource" ); |
432 | resource = standardResource(); | 432 | resource = standardResource(); |
433 | } | 433 | } |
434 | 434 | ||
435 | KRES::Manager<Resource>::ActiveIterator it; | 435 | KRES::Manager<Resource>::ActiveIterator it; |
436 | for ( it = d->mManager->activeBegin(); it != d->mManager->activeEnd(); ++it ) { | 436 | for ( it = d->mManager->activeBegin(); it != d->mManager->activeEnd(); ++it ) { |
437 | if ( (*it) == resource ) { | 437 | if ( (*it) == resource ) { |
438 | if ( (*it)->readOnly() || !(*it)->isOpen() ) | 438 | if ( (*it)->readOnly() || !(*it)->isOpen() ) |
439 | return 0; | 439 | return 0; |
440 | else | 440 | else |
441 | return (*it)->requestSaveTicket(); | 441 | return (*it)->requestSaveTicket(); |
442 | } | 442 | } |
443 | } | 443 | } |
444 | 444 | ||
445 | return 0; | 445 | return 0; |
446 | } | 446 | } |
447 | 447 | ||
448 | void AddressBook::insertAddressee( const Addressee &a, bool setRev ) | 448 | void AddressBook::insertAddressee( const Addressee &a, bool setRev ) |
449 | { | 449 | { |
450 | Addressee::List::Iterator it; | 450 | Addressee::List::Iterator it; |
451 | for ( it = d->mAddressees.begin(); it != d->mAddressees.end(); ++it ) { | 451 | for ( it = d->mAddressees.begin(); it != d->mAddressees.end(); ++it ) { |
452 | if ( a.uid() == (*it).uid() ) { | 452 | if ( a.uid() == (*it).uid() ) { |
453 | bool changed = false; | 453 | bool changed = false; |
454 | Addressee addr = a; | 454 | Addressee addr = a; |
455 | if ( addr != (*it) ) | 455 | if ( addr != (*it) ) |
456 | changed = true; | 456 | changed = true; |
457 | 457 | ||
458 | (*it) = a; | 458 | (*it) = a; |
459 | if ( (*it).resource() == 0 ) | 459 | if ( (*it).resource() == 0 ) |
460 | (*it).setResource( standardResource() ); | 460 | (*it).setResource( standardResource() ); |
461 | 461 | ||
462 | if ( changed ) { | 462 | if ( changed ) { |
463 | if ( setRev ) | 463 | if ( setRev ) { |
464 | (*it).setRevision( QDateTime::currentDateTime() ); | 464 | // get rid of micro seconds |
465 | QDateTime dt = QDateTime::currentDateTime(); | ||
466 | QTime t = dt.time(); | ||
467 | dt.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | ||
468 | (*it).setRevision( dt ); | ||
469 | } | ||
465 | (*it).setChanged( true ); | 470 | (*it).setChanged( true ); |
466 | } | 471 | } |
467 | 472 | ||
468 | return; | 473 | return; |
469 | } | 474 | } |
470 | } | 475 | } |
471 | d->mAddressees.append( a ); | 476 | d->mAddressees.append( a ); |
472 | Addressee& addr = d->mAddressees.last(); | 477 | Addressee& addr = d->mAddressees.last(); |
473 | if ( addr.resource() == 0 ) | 478 | if ( addr.resource() == 0 ) |
474 | addr.setResource( standardResource() ); | 479 | addr.setResource( standardResource() ); |
475 | 480 | ||
476 | addr.setChanged( true ); | 481 | addr.setChanged( true ); |
477 | } | 482 | } |
478 | 483 | ||
479 | void AddressBook::removeAddressee( const Addressee &a ) | 484 | void AddressBook::removeAddressee( const Addressee &a ) |
480 | { | 485 | { |
481 | Iterator it; | 486 | Iterator it; |
482 | for ( it = begin(); it != end(); ++it ) { | 487 | for ( it = begin(); it != end(); ++it ) { |
483 | if ( a.uid() == (*it).uid() ) { | 488 | if ( a.uid() == (*it).uid() ) { |
484 | removeAddressee( it ); | 489 | removeAddressee( it ); |
485 | return; | 490 | return; |
486 | } | 491 | } |
487 | } | 492 | } |
488 | } | 493 | } |
489 | 494 | ||
490 | void AddressBook::removeAddressee( const Iterator &it ) | 495 | void AddressBook::removeAddressee( const Iterator &it ) |
491 | { | 496 | { |
492 | d->mRemovedAddressees.append( (*it) ); | 497 | d->mRemovedAddressees.append( (*it) ); |
493 | d->mAddressees.remove( it.d->mIt ); | 498 | d->mAddressees.remove( it.d->mIt ); |
494 | } | 499 | } |
495 | 500 | ||
496 | AddressBook::Iterator AddressBook::find( const Addressee &a ) | 501 | AddressBook::Iterator AddressBook::find( const Addressee &a ) |
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp index 226d5e4..215ce83 100644 --- a/kaddressbook/kabcore.cpp +++ b/kaddressbook/kabcore.cpp | |||
@@ -2873,64 +2873,67 @@ bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBo | |||
2873 | inR = inL; | 2873 | inR = inL; |
2874 | inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 2874 | inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
2875 | inR.setResource( 0 ); | 2875 | inR.setResource( 0 ); |
2876 | remote->insertAddressee( inR, false ); | 2876 | remote->insertAddressee( inR, false ); |
2877 | } | 2877 | } |
2878 | } | 2878 | } |
2879 | } else { | 2879 | } else { |
2880 | if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { | 2880 | if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { |
2881 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); | 2881 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); |
2882 | local->removeAddressee( inL ); | 2882 | local->removeAddressee( inL ); |
2883 | ++deletedAddresseeL; | 2883 | ++deletedAddresseeL; |
2884 | } else { | 2884 | } else { |
2885 | if ( ! KABPrefs::instance()->mWriteBackExistingOnly ) { | 2885 | if ( ! KABPrefs::instance()->mWriteBackExistingOnly ) { |
2886 | ++addedAddresseeR; | 2886 | ++addedAddresseeR; |
2887 | inL.setRevision( modifiedCalendar ); | 2887 | inL.setRevision( modifiedCalendar ); |
2888 | local->insertAddressee( inL, false ); | 2888 | local->insertAddressee( inL, false ); |
2889 | inR = inL; | 2889 | inR = inL; |
2890 | inR.setResource( 0 ); | 2890 | inR.setResource( 0 ); |
2891 | remote->insertAddressee( inR, false ); | 2891 | remote->insertAddressee( inR, false ); |
2892 | } | 2892 | } |
2893 | } | 2893 | } |
2894 | } | 2894 | } |
2895 | } | 2895 | } |
2896 | } | 2896 | } |
2897 | ++incCounter; | 2897 | ++incCounter; |
2898 | } | 2898 | } |
2899 | el.clear(); | 2899 | el.clear(); |
2900 | 2900 | ||
2901 | 2901 | ||
2902 | 2902 | ||
2903 | bar.hide(); | 2903 | bar.hide(); |
2904 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); | 2904 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); |
2905 | // get rid of micro seconds | ||
2906 | QTime t = mLastAddressbookSync.time(); | ||
2907 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | ||
2905 | addresseeLSync.setRevision( mLastAddressbookSync ); | 2908 | addresseeLSync.setRevision( mLastAddressbookSync ); |
2906 | addresseeRSync.setRevision( mLastAddressbookSync ); | 2909 | addresseeRSync.setRevision( mLastAddressbookSync ); |
2907 | addresseeRSync.setGivenName( i18n("Remote from: ")+mCurrentSyncName ) ; | 2910 | addresseeRSync.setGivenName( i18n("Remote from: ")+mCurrentSyncName ) ; |
2908 | addresseeLSync.setGivenName(i18n("Local from: ") + mCurrentSyncName ); | 2911 | addresseeLSync.setGivenName(i18n("Local from: ") + mCurrentSyncName ); |
2909 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) | 2912 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) |
2910 | remote->insertAddressee( addresseeRSync, false ); | 2913 | remote->insertAddressee( addresseeRSync, false ); |
2911 | local->insertAddressee( addresseeLSync, false ); | 2914 | local->insertAddressee( addresseeLSync, false ); |
2912 | QString mes; | 2915 | QString mes; |
2913 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR ); | 2916 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR ); |
2914 | if ( KABPrefs::instance()->mShowSyncSummary ) { | 2917 | if ( KABPrefs::instance()->mShowSyncSummary ) { |
2915 | KMessageBox::information(this, mes, i18n("KO/Pi Synchronization") ); | 2918 | KMessageBox::information(this, mes, i18n("KO/Pi Synchronization") ); |
2916 | } | 2919 | } |
2917 | qDebug( mes ); | 2920 | qDebug( mes ); |
2918 | return syncOK; | 2921 | return syncOK; |
2919 | } | 2922 | } |
2920 | 2923 | ||
2921 | bool KABCore::syncAB(QString filename, int mode) | 2924 | bool KABCore::syncAB(QString filename, int mode) |
2922 | { | 2925 | { |
2923 | 2926 | ||
2924 | //pending prepare addresseeview for output | 2927 | //pending prepare addresseeview for output |
2925 | //pending detect, if remote file has REV field. if not switch to external sync | 2928 | //pending detect, if remote file has REV field. if not switch to external sync |
2926 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 2929 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
2927 | AddressBook abLocal(filename,"syncContact"); | 2930 | AddressBook abLocal(filename,"syncContact"); |
2928 | bool syncOK = false; | 2931 | bool syncOK = false; |
2929 | if ( abLocal.load() ) { | 2932 | if ( abLocal.load() ) { |
2930 | qDebug("AB loaded %s mode %d",filename.latin1(), mode ); | 2933 | qDebug("AB loaded %s mode %d",filename.latin1(), mode ); |
2931 | AddressBook::Iterator it; | 2934 | AddressBook::Iterator it; |
2932 | //QStringList vcards; | 2935 | //QStringList vcards; |
2933 | //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { | 2936 | //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { |
2934 | // qDebug("Name %s ", (*it).familyName().latin1()); | 2937 | // qDebug("Name %s ", (*it).familyName().latin1()); |
2935 | //} | 2938 | //} |
2936 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); | 2939 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); |