-rw-r--r-- | kabc/addressbook.cpp | 9 | ||||
-rw-r--r-- | kaddressbook/kabcore.cpp | 20 |
2 files changed, 18 insertions, 11 deletions
diff --git a/kabc/addressbook.cpp b/kabc/addressbook.cpp index d03dea3..16e1653 100644 --- a/kabc/addressbook.cpp +++ b/kabc/addressbook.cpp | |||
@@ -441,35 +441,39 @@ Ticket *AddressBook::requestSaveTicket( Resource *resource ) | |||
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 | if ( setRev && (*it).uid().left( 19 ) == QString("last-syncAddressee-") ) { | ||
454 | return; | ||
455 | } | ||
453 | bool changed = false; | 456 | bool changed = false; |
454 | Addressee addr = a; | 457 | Addressee addr = a; |
455 | if ( addr != (*it) ) | 458 | if ( addr != (*it) ) |
456 | changed = true; | 459 | changed = true; |
457 | 460 | ||
458 | (*it) = a; | 461 | (*it) = a; |
459 | if ( (*it).resource() == 0 ) | 462 | if ( (*it).resource() == 0 ) |
460 | (*it).setResource( standardResource() ); | 463 | (*it).setResource( standardResource() ); |
461 | 464 | ||
462 | if ( changed ) { | 465 | if ( changed ) { |
463 | if ( setRev ) { | 466 | if ( setRev ) { |
467 | |||
464 | // get rid of micro seconds | 468 | // get rid of micro seconds |
465 | QDateTime dt = QDateTime::currentDateTime(); | 469 | QDateTime dt = QDateTime::currentDateTime(); |
466 | QTime t = dt.time(); | 470 | QTime t = dt.time(); |
467 | dt.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | 471 | dt.setTime( QTime (t.hour (), t.minute (), t.second () ) ); |
468 | (*it).setRevision( dt ); | 472 | (*it).setRevision( dt ); |
469 | } | 473 | } |
470 | (*it).setChanged( true ); | 474 | (*it).setChanged( true ); |
471 | } | 475 | } |
472 | 476 | ||
473 | return; | 477 | return; |
474 | } | 478 | } |
475 | } | 479 | } |
@@ -516,25 +520,25 @@ Addressee AddressBook::findByUid( const QString &uid ) | |||
516 | if ( uid == (*it).uid() ) { | 520 | if ( uid == (*it).uid() ) { |
517 | return *it; | 521 | return *it; |
518 | } | 522 | } |
519 | } | 523 | } |
520 | return Addressee(); | 524 | return Addressee(); |
521 | } | 525 | } |
522 | Addressee::List AddressBook::getExternLastSyncAddressees() | 526 | Addressee::List AddressBook::getExternLastSyncAddressees() |
523 | { | 527 | { |
524 | Addressee::List results; | 528 | Addressee::List results; |
525 | 529 | ||
526 | Iterator it; | 530 | Iterator it; |
527 | for ( it = begin(); it != end(); ++it ) { | 531 | for ( it = begin(); it != end(); ++it ) { |
528 | if ( (*it).uid().left( 20 ) == "last-syncAddressee-" ) { | 532 | if ( (*it).uid().left( 19 ) == "last-syncAddressee-" ) { |
529 | if ( (*it).familyName().left(3) == "E: " ) | 533 | if ( (*it).familyName().left(3) == "E: " ) |
530 | results.append( *it ); | 534 | results.append( *it ); |
531 | } | 535 | } |
532 | } | 536 | } |
533 | 537 | ||
534 | return results; | 538 | return results; |
535 | } | 539 | } |
536 | void AddressBook::resetTempSyncStat() | 540 | void AddressBook::resetTempSyncStat() |
537 | { | 541 | { |
538 | Iterator it; | 542 | Iterator it; |
539 | for ( it = begin(); it != end(); ++it ) { | 543 | for ( it = begin(); it != end(); ++it ) { |
540 | (*it).setTempSyncStat ( SYNC_TEMPSTATE_INITIAL ); | 544 | (*it).setTempSyncStat ( SYNC_TEMPSTATE_INITIAL ); |
@@ -546,25 +550,26 @@ QStringList AddressBook:: uidList() | |||
546 | { | 550 | { |
547 | QStringList results; | 551 | QStringList results; |
548 | Iterator it; | 552 | Iterator it; |
549 | for ( it = begin(); it != end(); ++it ) { | 553 | for ( it = begin(); it != end(); ++it ) { |
550 | results.append( (*it).uid() ); | 554 | results.append( (*it).uid() ); |
551 | } | 555 | } |
552 | return results; | 556 | return results; |
553 | } | 557 | } |
554 | 558 | ||
555 | 559 | ||
556 | Addressee::List AddressBook::allAddressees() | 560 | Addressee::List AddressBook::allAddressees() |
557 | { | 561 | { |
558 | return d->mAddressees; | 562 | return d->mAddressees; |
563 | |||
559 | } | 564 | } |
560 | 565 | ||
561 | Addressee::List AddressBook::findByName( const QString &name ) | 566 | Addressee::List AddressBook::findByName( const QString &name ) |
562 | { | 567 | { |
563 | Addressee::List results; | 568 | Addressee::List results; |
564 | 569 | ||
565 | Iterator it; | 570 | Iterator it; |
566 | for ( it = begin(); it != end(); ++it ) { | 571 | for ( it = begin(); it != end(); ++it ) { |
567 | if ( name == (*it).realName() ) { | 572 | if ( name == (*it).realName() ) { |
568 | results.append( *it ); | 573 | results.append( *it ); |
569 | } | 574 | } |
570 | } | 575 | } |
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp index 215ce83..74c10d2 100644 --- a/kaddressbook/kabcore.cpp +++ b/kaddressbook/kabcore.cpp | |||
@@ -2519,25 +2519,25 @@ QString KABCore::getPassword( ) | |||
2519 | 2519 | ||
2520 | KABC::Addressee KABCore::getLastSyncAddressee() | 2520 | KABC::Addressee KABCore::getLastSyncAddressee() |
2521 | { | 2521 | { |
2522 | Addressee lse; | 2522 | Addressee lse; |
2523 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); | 2523 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); |
2524 | lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); | 2524 | lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); |
2525 | if (lse.isEmpty()) { | 2525 | if (lse.isEmpty()) { |
2526 | qDebug("Creating new last-syncAddressee "); | 2526 | qDebug("Creating new last-syncAddressee "); |
2527 | lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); | 2527 | lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); |
2528 | QString sum = ""; | 2528 | QString sum = ""; |
2529 | if ( KABPrefs::instance()->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) | 2529 | if ( KABPrefs::instance()->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) |
2530 | sum = "E: "; | 2530 | sum = "E: "; |
2531 | lse.setFamilyName(sum+mCurrentSyncDevice + i18n(" - sync event")); | 2531 | lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); |
2532 | lse.setRevision( mLastAddressbookSync ); | 2532 | lse.setRevision( mLastAddressbookSync ); |
2533 | lse.setCategories( i18n("SyncEvent") ); | 2533 | lse.setCategories( i18n("SyncEvent") ); |
2534 | mAddressBook->insertAddressee( lse ); | 2534 | mAddressBook->insertAddressee( lse ); |
2535 | } | 2535 | } |
2536 | return lse; | 2536 | return lse; |
2537 | } | 2537 | } |
2538 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) | 2538 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) |
2539 | { | 2539 | { |
2540 | 2540 | ||
2541 | //void setZaurusId(int id); | 2541 | //void setZaurusId(int id); |
2542 | // int zaurusId() const; | 2542 | // int zaurusId() const; |
2543 | // void setZaurusUid(int id); | 2543 | // void setZaurusUid(int id); |
@@ -2754,25 +2754,25 @@ bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBo | |||
2754 | int dh = QApplication::desktop()->height(); | 2754 | int dh = QApplication::desktop()->height(); |
2755 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 2755 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
2756 | bar.show(); | 2756 | bar.show(); |
2757 | int modulo = (er.count()/10)+1; | 2757 | int modulo = (er.count()/10)+1; |
2758 | int incCounter = 0; | 2758 | int incCounter = 0; |
2759 | while ( incCounter < er.count()) { | 2759 | while ( incCounter < er.count()) { |
2760 | if ( ! bar.isVisible() ) | 2760 | if ( ! bar.isVisible() ) |
2761 | return false; | 2761 | return false; |
2762 | if ( incCounter % modulo == 0 ) | 2762 | if ( incCounter % modulo == 0 ) |
2763 | bar.setProgress( incCounter ); | 2763 | bar.setProgress( incCounter ); |
2764 | uid = er[ incCounter ]; | 2764 | uid = er[ incCounter ]; |
2765 | bool skipIncidence = false; | 2765 | bool skipIncidence = false; |
2766 | if ( uid.left(20) == QString("last-syncAddressee-") ) | 2766 | if ( uid.left(19) == QString("last-syncAddressee-") ) |
2767 | skipIncidence = true; | 2767 | skipIncidence = true; |
2768 | QString idS; | 2768 | QString idS; |
2769 | qApp->processEvents(); | 2769 | qApp->processEvents(); |
2770 | if ( !skipIncidence ) { | 2770 | if ( !skipIncidence ) { |
2771 | inL = local->findByUid( uid ); | 2771 | inL = local->findByUid( uid ); |
2772 | inR = remote->findByUid( uid ); | 2772 | inR = remote->findByUid( uid ); |
2773 | //inL.setResource( 0 ); | 2773 | //inL.setResource( 0 ); |
2774 | //inR.setResource( 0 ); | 2774 | //inR.setResource( 0 ); |
2775 | if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars | 2775 | if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars |
2776 | if ( take = takeAddressee( &inL, &inR, mode, fullDateRange ) ) { | 2776 | if ( take = takeAddressee( &inL, &inR, mode, fullDateRange ) ) { |
2777 | //qDebug("take %d %s ", take, inL.summary().latin1()); | 2777 | //qDebug("take %d %s ", take, inL.summary().latin1()); |
2778 | if ( take == 3 ) | 2778 | if ( take == 3 ) |
@@ -2841,25 +2841,25 @@ bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBo | |||
2841 | bar.setTotalSteps ( el.count() ) ; | 2841 | bar.setTotalSteps ( el.count() ) ; |
2842 | bar.show(); | 2842 | bar.show(); |
2843 | incCounter = 0; | 2843 | incCounter = 0; |
2844 | while ( incCounter < el.count()) { | 2844 | while ( incCounter < el.count()) { |
2845 | 2845 | ||
2846 | qApp->processEvents(); | 2846 | qApp->processEvents(); |
2847 | if ( ! bar.isVisible() ) | 2847 | if ( ! bar.isVisible() ) |
2848 | return false; | 2848 | return false; |
2849 | if ( incCounter % modulo == 0 ) | 2849 | if ( incCounter % modulo == 0 ) |
2850 | bar.setProgress( incCounter ); | 2850 | bar.setProgress( incCounter ); |
2851 | uid = el[ incCounter ]; | 2851 | uid = el[ incCounter ]; |
2852 | bool skipIncidence = false; | 2852 | bool skipIncidence = false; |
2853 | if ( uid.left(20) == QString("last-syncAddressee-") ) | 2853 | if ( uid.left(19) == QString("last-syncAddressee-") ) |
2854 | skipIncidence = true; | 2854 | skipIncidence = true; |
2855 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 2855 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
2856 | skipIncidence = true; | 2856 | skipIncidence = true; |
2857 | if ( !skipIncidence ) { | 2857 | if ( !skipIncidence ) { |
2858 | inL = local->findByUid( uid ); | 2858 | inL = local->findByUid( uid ); |
2859 | inR = remote->findByUid( uid ); | 2859 | inR = remote->findByUid( uid ); |
2860 | if ( inR.isEmpty() ) { | 2860 | if ( inR.isEmpty() ) { |
2861 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2861 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2862 | if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 2862 | if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
2863 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); | 2863 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); |
2864 | local->removeAddressee( inL ); | 2864 | local->removeAddressee( inL ); |
2865 | ++deletedAddresseeL; | 2865 | ++deletedAddresseeL; |
@@ -2888,43 +2888,45 @@ bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBo | |||
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 | |||
2901 | |||
2902 | |||
2903 | bar.hide(); | 2900 | bar.hide(); |
2904 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); | 2901 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); |
2905 | // get rid of micro seconds | 2902 | // get rid of micro seconds |
2906 | QTime t = mLastAddressbookSync.time(); | 2903 | QTime t = mLastAddressbookSync.time(); |
2907 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | 2904 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); |
2908 | addresseeLSync.setRevision( mLastAddressbookSync ); | 2905 | addresseeLSync.setRevision( mLastAddressbookSync ); |
2909 | addresseeRSync.setRevision( mLastAddressbookSync ); | 2906 | addresseeRSync.setRevision( mLastAddressbookSync ); |
2910 | addresseeRSync.setGivenName( i18n("Remote from: ")+mCurrentSyncName ) ; | 2907 | addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; |
2911 | addresseeLSync.setGivenName(i18n("Local from: ") + mCurrentSyncName ); | 2908 | addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); |
2909 | addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; | ||
2910 | addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); | ||
2911 | addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; | ||
2912 | addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); | ||
2913 | |||
2912 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) | 2914 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) |
2913 | remote->insertAddressee( addresseeRSync, false ); | 2915 | remote->insertAddressee( addresseeRSync, false ); |
2914 | local->insertAddressee( addresseeLSync, false ); | 2916 | local->insertAddressee( addresseeLSync, false ); |
2915 | QString mes; | 2917 | QString mes; |
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 ); | 2918 | 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 ); |
2917 | if ( KABPrefs::instance()->mShowSyncSummary ) { | 2919 | if ( KABPrefs::instance()->mShowSyncSummary ) { |
2918 | KMessageBox::information(this, mes, i18n("KO/Pi Synchronization") ); | 2920 | KMessageBox::information(this, mes, i18n("KA/Pi Synchronization") ); |
2919 | } | 2921 | } |
2920 | qDebug( mes ); | 2922 | qDebug( mes ); |
2921 | return syncOK; | 2923 | return syncOK; |
2922 | } | 2924 | } |
2923 | 2925 | ||
2924 | bool KABCore::syncAB(QString filename, int mode) | 2926 | bool KABCore::syncAB(QString filename, int mode) |
2925 | { | 2927 | { |
2926 | 2928 | ||
2927 | //pending prepare addresseeview for output | 2929 | //pending prepare addresseeview for output |
2928 | //pending detect, if remote file has REV field. if not switch to external sync | 2930 | //pending detect, if remote file has REV field. if not switch to external sync |
2929 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 2931 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
2930 | AddressBook abLocal(filename,"syncContact"); | 2932 | AddressBook abLocal(filename,"syncContact"); |