author | zautrix <zautrix> | 2005-11-28 03:27:16 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-11-28 03:27:16 (UTC) |
commit | b7522a13b64225bb91bdab4a21b44282f8c3e3b4 (patch) (unidiff) | |
tree | 3aa005036dd83f3d0e5f57dd398dc260666daea1 /korganizer | |
parent | 084180efc1bccba341bf3f2f718fd10cdfdaf18e (diff) | |
download | kdepimpi-b7522a13b64225bb91bdab4a21b44282f8c3e3b4.zip kdepimpi-b7522a13b64225bb91bdab4a21b44282f8c3e3b4.tar.gz kdepimpi-b7522a13b64225bb91bdab4a21b44282f8c3e3b4.tar.bz2 |
sync
-rw-r--r-- | korganizer/calendarview.cpp | 44 |
1 files changed, 23 insertions, 21 deletions
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index 1800cf2..8385bcc 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -1606,305 +1606,311 @@ void CalendarView::checkExternalId( Incidence * inc ) | |||
1606 | } | 1606 | } |
1607 | // SSSSSSSSSSSSSSSSSSSSSS | 1607 | // SSSSSSSSSSSSSSSSSSSSSS |
1608 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) | 1608 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) |
1609 | { | 1609 | { |
1610 | 1610 | ||
1611 | bool syncOK = true; | 1611 | bool syncOK = true; |
1612 | int addedEvent = 0; | 1612 | int addedEvent = 0; |
1613 | int addedEventR = 0; | 1613 | int addedEventR = 0; |
1614 | int deletedEventR = 0; | 1614 | int deletedEventR = 0; |
1615 | int deletedEventL = 0; | 1615 | int deletedEventL = 0; |
1616 | int changedLocal = 0; | 1616 | int changedLocal = 0; |
1617 | int changedRemote = 0; | 1617 | int changedRemote = 0; |
1618 | int filteredIN = 0; | 1618 | int filteredIN = 0; |
1619 | int filteredOUT = 0; | 1619 | int filteredOUT = 0; |
1620 | //QPtrList<Event> el = local->rawEvents(); | 1620 | //QPtrList<Event> el = local->rawEvents(); |
1621 | Event* eventR; | 1621 | Event* eventR; |
1622 | QString uid; | 1622 | QString uid; |
1623 | int take; | 1623 | int take; |
1624 | Event* eventRSync; | 1624 | Event* eventRSync; |
1625 | Event* eventLSync; | 1625 | Event* eventLSync; |
1626 | clearAllViews(); | 1626 | clearAllViews(); |
1627 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); | 1627 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); |
1628 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); | 1628 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); |
1629 | bool fullDateRange = false; | 1629 | bool fullDateRange = false; |
1630 | local->resetTempSyncStat(); | 1630 | local->resetTempSyncStat(); |
1631 | mLastCalendarSync = QDateTime::currentDateTime(); | 1631 | mLastCalendarSync = QDateTime::currentDateTime(); |
1632 | if ( mSyncManager->syncWithDesktop() ) { | 1632 | if ( mSyncManager->syncWithDesktop() ) { |
1633 | remote->resetPilotStat(1); | 1633 | remote->resetPilotStat(1); |
1634 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { | 1634 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { |
1635 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; | 1635 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; |
1636 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); | 1636 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); |
1637 | } else { | 1637 | } else { |
1638 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); | 1638 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); |
1639 | } | 1639 | } |
1640 | } | 1640 | } |
1641 | QDateTime modifiedCalendar = mLastCalendarSync; | 1641 | QDateTime modifiedCalendar = mLastCalendarSync; |
1642 | eventLSync = getLastSyncEvent(); | 1642 | eventLSync = getLastSyncEvent(); |
1643 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); | 1643 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); |
1644 | if ( eventR ) { | 1644 | if ( eventR ) { |
1645 | qDebug("KO: Last-syncEvent on remote found "); | 1645 | qDebug("KO: Last-syncEvent on remote found "); |
1646 | eventRSync = (Event*) eventR->clone(); | 1646 | eventRSync = (Event*) eventR->clone(); |
1647 | remote->deleteEvent(eventR ); | 1647 | remote->deleteEvent(eventR ); |
1648 | 1648 | ||
1649 | } else { | 1649 | } else { |
1650 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { | 1650 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { |
1651 | eventRSync = (Event*)eventLSync->clone(); | 1651 | eventRSync = (Event*)eventLSync->clone(); |
1652 | } else { | 1652 | } else { |
1653 | fullDateRange = true; | 1653 | fullDateRange = true; |
1654 | eventRSync = new Event(); | 1654 | eventRSync = new Event(); |
1655 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); | 1655 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); |
1656 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); | 1656 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); |
1657 | eventRSync->setDtStart( mLastCalendarSync ); | 1657 | eventRSync->setDtStart( mLastCalendarSync ); |
1658 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 1658 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
1659 | eventRSync->setCategories( i18n("SyncEvent") ); | 1659 | eventRSync->setCategories( i18n("SyncEvent") ); |
1660 | } | 1660 | } |
1661 | } | 1661 | } |
1662 | if ( eventLSync->dtStart() == mLastCalendarSync ) | 1662 | if ( eventLSync->dtStart() == mLastCalendarSync ) |
1663 | fullDateRange = true; | 1663 | fullDateRange = true; |
1664 | 1664 | ||
1665 | if ( ! fullDateRange ) { | 1665 | if ( ! fullDateRange ) { |
1666 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { | 1666 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { |
1667 | 1667 | ||
1668 | qDebug("KO: Sync: Set fulldate to true! Local: %s --- Remote: %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); | 1668 | qDebug("KO: Sync: Set fulldate to true! Local: %s --- Remote: %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); |
1669 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); | 1669 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); |
1670 | fullDateRange = true; | 1670 | fullDateRange = true; |
1671 | } | 1671 | } |
1672 | } | 1672 | } |
1673 | if ( mSyncManager->syncWithDesktop() ) { | 1673 | if ( mSyncManager->syncWithDesktop() ) { |
1674 | fullDateRange = ( eventLSync->dtStart() <= mLastCalendarSync && eventLSync->dtStart().addSecs(1) >= mLastCalendarSync ); | 1674 | fullDateRange = ( eventLSync->dtStart() <= mLastCalendarSync && eventLSync->dtStart().addSecs(1) >= mLastCalendarSync ); |
1675 | } | 1675 | } |
1676 | if ( fullDateRange ) | 1676 | if ( fullDateRange ) |
1677 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); | 1677 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); |
1678 | else | 1678 | else |
1679 | mLastCalendarSync = eventLSync->dtStart(); | 1679 | mLastCalendarSync = eventLSync->dtStart(); |
1680 | // for resyncing if own file has changed | 1680 | // for resyncing if own file has changed |
1681 | if ( mCurrentSyncDevice == "deleteaftersync" ) { | 1681 | if ( mCurrentSyncDevice == "deleteaftersync" ) { |
1682 | mLastCalendarSync = loadedFileVersion; | 1682 | mLastCalendarSync = loadedFileVersion; |
1683 | //qDebug("setting mLastCalendarSync "); | 1683 | //qDebug("setting mLastCalendarSync "); |
1684 | } | 1684 | } |
1685 | //qDebug("*************************** "); | 1685 | //qDebug("*************************** "); |
1686 | qDebug("KO: mLastCalendarSync %s .Full: %d",mLastCalendarSync.toString().latin1(), fullDateRange); | 1686 | qDebug("KO: mLastCalendarSync %s .Full: %d",mLastCalendarSync.toString().latin1(), fullDateRange); |
1687 | QPtrList<Incidence> er = remote->rawIncidences(); | 1687 | QPtrList<Incidence> er = remote->rawIncidences(); |
1688 | Incidence* inR = er.first(); | 1688 | Incidence* inR = er.first(); |
1689 | Incidence* inL; | 1689 | Incidence* inL; |
1690 | QProgressBar bar( er.count(),0 ); | 1690 | QProgressBar bar( er.count(),0 ); |
1691 | bar.setCaption (i18n("Syncing - close to abort!") ); | 1691 | bar.setCaption (i18n("Syncing - close to abort!") ); |
1692 | 1692 | ||
1693 | // ************** setting up filter ************* | 1693 | // ************** setting up filter ************* |
1694 | CalFilter *filterIN = 0; | 1694 | CalFilter *filterIN = 0; |
1695 | CalFilter *filterOUT = 0; | 1695 | CalFilter *filterOUT = 0; |
1696 | CalFilter *filter = mFilters.first(); | 1696 | CalFilter *filter = mFilters.first(); |
1697 | while(filter) { | 1697 | while(filter) { |
1698 | if ( filter->name() == mSyncManager->mFilterInCal ) | 1698 | if ( filter->name() == mSyncManager->mFilterInCal ) |
1699 | filterIN = filter; | 1699 | filterIN = filter; |
1700 | if ( filter->name() == mSyncManager->mFilterOutCal ) | 1700 | if ( filter->name() == mSyncManager->mFilterOutCal ) |
1701 | filterOUT = filter; | 1701 | filterOUT = filter; |
1702 | filter = mFilters.next(); | 1702 | filter = mFilters.next(); |
1703 | } | 1703 | } |
1704 | int w = 300; | 1704 | int w = 300; |
1705 | if ( QApplication::desktop()->width() < 320 ) | 1705 | if ( QApplication::desktop()->width() < 320 ) |
1706 | w = 220; | 1706 | w = 220; |
1707 | int h = bar.sizeHint().height() ; | 1707 | int h = bar.sizeHint().height() ; |
1708 | int dw = QApplication::desktop()->width(); | 1708 | int dw = QApplication::desktop()->width(); |
1709 | int dh = QApplication::desktop()->height(); | 1709 | int dh = QApplication::desktop()->height(); |
1710 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1710 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1711 | bar.show(); | 1711 | bar.show(); |
1712 | int modulo = (er.count()/10)+1; | 1712 | int modulo = (er.count()/10)+1; |
1713 | int incCounter = 0; | 1713 | int incCounter = 0; |
1714 | while ( inR ) { | 1714 | while ( inR ) { |
1715 | if ( ! bar.isVisible() ) | 1715 | if ( ! bar.isVisible() ) |
1716 | return false; | 1716 | return false; |
1717 | if ( incCounter % modulo == 0 ) | 1717 | if ( incCounter % modulo == 0 ) |
1718 | bar.setProgress( incCounter ); | 1718 | bar.setProgress( incCounter ); |
1719 | ++incCounter; | 1719 | ++incCounter; |
1720 | uid = inR->uid(); | 1720 | uid = inR->uid(); |
1721 | bool skipIncidence = false; | 1721 | bool skipIncidence = false; |
1722 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1722 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1723 | skipIncidence = true; | 1723 | skipIncidence = true; |
1724 | QString idS; | 1724 | QString idS; |
1725 | qApp->processEvents(); | 1725 | qApp->processEvents(); |
1726 | if ( !skipIncidence ) { | 1726 | if ( !skipIncidence ) { |
1727 | int hasCalId = 0; | 1727 | int hasCalId = 0; |
1728 | inL = local->incidenceForUid( uid , false , true, &hasCalId ); | 1728 | inL = local->incidenceForUid( uid , false , true, &hasCalId ); |
1729 | if ( hasCalId && !inL ) | 1729 | if ( hasCalId && !inL ) |
1730 | inL = local->incidenceForUid( uid , false , true, &hasCalId ); | 1730 | inL = local->incidenceForUid( uid , false , true, &hasCalId ); |
1731 | else | 1731 | else |
1732 | hasCalId = 0; | 1732 | hasCalId = 0; |
1733 | if ( inL ) { // maybe conflict - same uid in both calendars | 1733 | if ( inL ) { // maybe conflict - same uid in both calendars |
1734 | if ( hasCalId ) | 1734 | |
1735 | qDebug("KO: Cal id %d conflict detected: %s ", hasCalId, inL->summary().latin1()); | ||
1736 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { | 1735 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { |
1737 | //qDebug("take %d %s ", take, inL->summary().latin1()); | 1736 | //qDebug("take %d %s ", take, inL->summary().latin1()); |
1738 | if ( take == 3 ) | 1737 | if ( take == 3 ) |
1739 | return false; | 1738 | return false; |
1740 | if ( take == 1 ) {// take local ********************** | 1739 | if ( take == 1 ) {// take local ********************** |
1741 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 1740 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
1742 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1741 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1743 | else | 1742 | else |
1744 | idS = inR->IDStr(); | 1743 | idS = inR->IDStr(); |
1745 | int calID = inR->calID(); | 1744 | int calID = inR->calID(); |
1746 | remote->deleteIncidence( inR ); | 1745 | remote->deleteIncidence( inR ); |
1747 | inR = inL->clone(); | 1746 | if ( !hasCalId ) { |
1748 | inR->setCalID_block( calID ); | 1747 | inR = inL->clone(); |
1749 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1748 | inR->setCalID_block( calID ); |
1750 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) | 1749 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1751 | inR->setIDStr( idS ); | 1750 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) |
1752 | remote->addIncidence( inR ); | 1751 | inR->setIDStr( idS ); |
1753 | if ( mSyncManager->syncWithDesktop() ) | 1752 | remote->addIncidence( inR ); |
1754 | inR->setPilotId( 2 ); | 1753 | if ( mSyncManager->syncWithDesktop() ) |
1755 | ++changedRemote; | 1754 | inR->setPilotId( 2 ); |
1755 | ++changedRemote; | ||
1756 | } else | ||
1757 | ++deletedEventR; | ||
1756 | } else {// take remote ********************** | 1758 | } else {// take remote ********************** |
1757 | if ( !inL->isReadOnly() ) { | 1759 | if ( !inL->isReadOnly() ) { |
1758 | idS = inL->IDStr(); | 1760 | idS = inL->IDStr(); |
1759 | int pid = inL->pilotId(); | 1761 | int pid = inL->pilotId(); |
1760 | int calID = inL->calID(); | 1762 | int calID = inL->calID(); |
1761 | if ( hasCalId ) | 1763 | if ( hasCalId ) |
1762 | calID = hasCalId; | 1764 | calID = 0;// add to default calendar |
1763 | local->deleteIncidence( inL ); | 1765 | local->deleteIncidence( inL ); |
1764 | inL = inR->clone(); | 1766 | inL = inR->clone(); |
1765 | inL->setCalID_block( calID ); | 1767 | inL->setCalID_block( calID ); |
1766 | if ( mSyncManager->syncWithDesktop() ) | 1768 | if ( mSyncManager->syncWithDesktop() ) |
1767 | inL->setPilotId( pid ); | 1769 | inL->setPilotId( pid ); |
1768 | inL->setIDStr( idS ); | 1770 | inL->setIDStr( idS ); |
1769 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1771 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1770 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1772 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1771 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | 1773 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); |
1772 | } | 1774 | } |
1773 | local->addIncidence( inL ); | 1775 | local->addIncidence( inL ); |
1774 | ++changedLocal; | 1776 | ++changedLocal; |
1775 | } | 1777 | } |
1776 | } | 1778 | } |
1777 | } else { | 1779 | } else { |
1778 | // take == 0; events equal | 1780 | // take == 0; events equal |
1779 | if ( hasCalId ) | 1781 | if ( hasCalId ) { |
1780 | qDebug("EV EQUALLLL **************************** "); | 1782 | qDebug("KO: Changing Cal id %d to %d for : %s ", hasCalId, local->defaultCalendar(),inL->summary().latin1()); |
1783 | inL->setCalID( local->defaultCalendar() ); | ||
1784 | } | ||
1781 | 1785 | ||
1782 | } | 1786 | } |
1787 | |||
1788 | |||
1783 | } else { // no conflict ********** add or delete remote | 1789 | } else { // no conflict ********** add or delete remote |
1784 | if ( !filterIN || filterIN->filterCalendarItem( inR ) ){ | 1790 | if ( !filterIN || filterIN->filterCalendarItem( inR ) ){ |
1785 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1791 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1786 | QString des = eventLSync->description(); | 1792 | QString des = eventLSync->description(); |
1787 | QString pref = "e"; | 1793 | QString pref = "e"; |
1788 | if ( inR->typeID() == todoID ) | 1794 | if ( inR->typeID() == todoID ) |
1789 | pref = "t"; | 1795 | pref = "t"; |
1790 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it | 1796 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it |
1791 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); | 1797 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); |
1792 | //remote->deleteIncidence( inR ); | 1798 | //remote->deleteIncidence( inR ); |
1793 | ++deletedEventR; | 1799 | ++deletedEventR; |
1794 | } else { | 1800 | } else { |
1795 | inR->setLastModified( modifiedCalendar ); | 1801 | inR->setLastModified( modifiedCalendar ); |
1796 | inL = inR->clone(); | 1802 | inL = inR->clone(); |
1797 | inL->setIDStr( ":" ); | 1803 | inL->setIDStr( ":" ); |
1798 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1804 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1799 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | 1805 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); |
1800 | 1806 | ||
1801 | inL->setCalID_block( 0 );// add to default cal | 1807 | inL->setCalID_block( 0 );// add to default cal |
1802 | local->addIncidence( inL ); | 1808 | local->addIncidence( inL ); |
1803 | ++addedEvent; | 1809 | ++addedEvent; |
1804 | 1810 | ||
1805 | } | 1811 | } |
1806 | } else { | 1812 | } else { |
1807 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { | 1813 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { |
1808 | inR->setLastModified( modifiedCalendar ); | 1814 | inR->setLastModified( modifiedCalendar ); |
1809 | inL = inR->clone(); | 1815 | inL = inR->clone(); |
1810 | inL->setIDStr( ":" ); | 1816 | inL->setIDStr( ":" ); |
1811 | inL->setCalID_block( 0 );// add to default cal | 1817 | inL->setCalID_block( 0 );// add to default cal |
1812 | local->addIncidence( inL ); | 1818 | local->addIncidence( inL ); |
1813 | ++addedEvent; | 1819 | ++addedEvent; |
1814 | 1820 | ||
1815 | } else { | 1821 | } else { |
1816 | checkExternSyncEvent(eventRSyncSharp, inR); | 1822 | checkExternSyncEvent(eventRSyncSharp, inR); |
1817 | remote->deleteIncidence( inR ); | 1823 | remote->deleteIncidence( inR ); |
1818 | ++deletedEventR; | 1824 | ++deletedEventR; |
1819 | } | 1825 | } |
1820 | } | 1826 | } |
1821 | } else { | 1827 | } else { |
1822 | ++filteredIN; | 1828 | ++filteredIN; |
1823 | } | 1829 | } |
1824 | } | 1830 | } |
1825 | } | 1831 | } |
1826 | inR = er.next(); | 1832 | inR = er.next(); |
1827 | } | 1833 | } |
1828 | QPtrList<Incidence> el = local->rawIncidences(); | 1834 | QPtrList<Incidence> el = local->rawIncidences(); |
1829 | inL = el.first(); | 1835 | inL = el.first(); |
1830 | modulo = (el.count()/10)+1; | 1836 | modulo = (el.count()/10)+1; |
1831 | bar.setCaption (i18n("Add / remove events") ); | 1837 | bar.setCaption (i18n("Add / remove events") ); |
1832 | bar.setTotalSteps ( el.count() ) ; | 1838 | bar.setTotalSteps ( el.count() ) ; |
1833 | bar.show(); | 1839 | bar.show(); |
1834 | incCounter = 0; | 1840 | incCounter = 0; |
1835 | 1841 | ||
1836 | while ( inL ) { | 1842 | while ( inL ) { |
1837 | 1843 | ||
1838 | qApp->processEvents(); | 1844 | qApp->processEvents(); |
1839 | if ( ! bar.isVisible() ) | 1845 | if ( ! bar.isVisible() ) |
1840 | return false; | 1846 | return false; |
1841 | if ( incCounter % modulo == 0 ) | 1847 | if ( incCounter % modulo == 0 ) |
1842 | bar.setProgress( incCounter ); | 1848 | bar.setProgress( incCounter ); |
1843 | ++incCounter; | 1849 | ++incCounter; |
1844 | uid = inL->uid(); | 1850 | uid = inL->uid(); |
1845 | bool skipIncidence = false; | 1851 | bool skipIncidence = false; |
1846 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1852 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1847 | skipIncidence = true; | 1853 | skipIncidence = true; |
1848 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->typeID() == journalID ) | 1854 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->typeID() == journalID ) |
1849 | skipIncidence = true; | 1855 | skipIncidence = true; |
1850 | if ( !skipIncidence ) { | 1856 | if ( !skipIncidence ) { |
1851 | inR = remote->incidenceForUid( uid , true, true ); | 1857 | inR = remote->incidenceForUid( uid , true, true ); |
1852 | if ( ! inR ) { | 1858 | if ( ! inR ) { |
1853 | if ( !filterOUT || filterOUT->filterCalendarItem( inL ) ){ | 1859 | if ( !filterOUT || filterOUT->filterCalendarItem( inL ) ){ |
1854 | // no conflict ********** add or delete local | 1860 | // no conflict ********** add or delete local |
1855 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1861 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1856 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 1862 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
1857 | checkExternSyncEvent(eventLSyncSharp, inL); | 1863 | checkExternSyncEvent(eventLSyncSharp, inL); |
1858 | local->deleteIncidence( inL ); | 1864 | local->deleteIncidence( inL ); |
1859 | ++deletedEventL; | 1865 | ++deletedEventL; |
1860 | } else { | 1866 | } else { |
1861 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1867 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1862 | inL->removeID(mCurrentSyncDevice ); | 1868 | inL->removeID(mCurrentSyncDevice ); |
1863 | ++addedEventR; | 1869 | ++addedEventR; |
1864 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); | 1870 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); |
1865 | inL->setLastModified( modifiedCalendar ); | 1871 | inL->setLastModified( modifiedCalendar ); |
1866 | inR = inL->clone(); | 1872 | inR = inL->clone(); |
1867 | inR->setIDStr( ":" ); | 1873 | inR->setIDStr( ":" ); |
1868 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1874 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1869 | inR->setCalID_block( 0 );// add to default cal | 1875 | inR->setCalID_block( 0 );// add to default cal |
1870 | remote->addIncidence( inR ); | 1876 | remote->addIncidence( inR ); |
1871 | } | 1877 | } |
1872 | } | 1878 | } |
1873 | } else { | 1879 | } else { |
1874 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { | 1880 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { |
1875 | checkExternSyncEvent(eventLSyncSharp, inL); | 1881 | checkExternSyncEvent(eventLSyncSharp, inL); |
1876 | local->deleteIncidence( inL ); | 1882 | local->deleteIncidence( inL ); |
1877 | ++deletedEventL; | 1883 | ++deletedEventL; |
1878 | } else { | 1884 | } else { |
1879 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1885 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1880 | ++addedEventR; | 1886 | ++addedEventR; |
1881 | inL->setLastModified( modifiedCalendar ); | 1887 | inL->setLastModified( modifiedCalendar ); |
1882 | inR = inL->clone(); | 1888 | inR = inL->clone(); |
1883 | inR->setIDStr( ":" ); | 1889 | inR->setIDStr( ":" ); |
1884 | inR->setCalID_block( 0 );// add to default cal | 1890 | inR->setCalID_block( 0 );// add to default cal |
1885 | remote->addIncidence( inR ); | 1891 | remote->addIncidence( inR ); |
1886 | } | 1892 | } |
1887 | } | 1893 | } |
1888 | } | 1894 | } |
1889 | } else { | 1895 | } else { |
1890 | ++filteredOUT; | 1896 | ++filteredOUT; |
1891 | } | 1897 | } |
1892 | } | 1898 | } |
1893 | } | 1899 | } |
1894 | inL = el.next(); | 1900 | inL = el.next(); |
1895 | } | 1901 | } |
1896 | int delFut = 0; | 1902 | int delFut = 0; |
1897 | int remRem = 0; | 1903 | int remRem = 0; |
1898 | if ( mSyncManager->mWriteBackInFuture ) { | 1904 | if ( mSyncManager->mWriteBackInFuture ) { |
1899 | er = remote->rawIncidences(); | 1905 | er = remote->rawIncidences(); |
1900 | remRem = er.count(); | 1906 | remRem = er.count(); |
1901 | inR = er.first(); | 1907 | inR = er.first(); |
1902 | QDateTime dt; | 1908 | QDateTime dt; |
1903 | QDateTime cur = QDateTime::currentDateTime().addDays( -(mSyncManager->mWriteBackInPast * 7) ); | 1909 | QDateTime cur = QDateTime::currentDateTime().addDays( -(mSyncManager->mWriteBackInPast * 7) ); |
1904 | QDateTime end = QDateTime::currentDateTime().addDays( (mSyncManager->mWriteBackInFuture ) *7 ); | 1910 | QDateTime end = QDateTime::currentDateTime().addDays( (mSyncManager->mWriteBackInFuture ) *7 ); |
1905 | while ( inR ) { | 1911 | while ( inR ) { |
1906 | if ( inR->typeID() == todoID ) { | 1912 | if ( inR->typeID() == todoID ) { |
1907 | Todo * t = (Todo*)inR; | 1913 | Todo * t = (Todo*)inR; |
1908 | if ( t->hasDueDate() ) | 1914 | if ( t->hasDueDate() ) |
1909 | dt = t->dtDue(); | 1915 | dt = t->dtDue(); |
1910 | else | 1916 | else |
@@ -2357,266 +2363,262 @@ bool CalendarView::loadCalendars() | |||
2357 | return true; | 2363 | return true; |
2358 | } | 2364 | } |
2359 | bool CalendarView::restoreCalendarSettings() | 2365 | bool CalendarView::restoreCalendarSettings() |
2360 | { | 2366 | { |
2361 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; | 2367 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; |
2362 | KopiCalendarFile * cal = calendars.first(); | 2368 | KopiCalendarFile * cal = calendars.first(); |
2363 | while ( cal ) { | 2369 | while ( cal ) { |
2364 | mCalendar->setCalendarEnabled( cal->mCalNumber,cal->isEnabled ); | 2370 | mCalendar->setCalendarEnabled( cal->mCalNumber,cal->isEnabled ); |
2365 | mCalendar->setAlarmEnabled( cal->mCalNumber, cal->isAlarmEnabled ); | 2371 | mCalendar->setAlarmEnabled( cal->mCalNumber, cal->isAlarmEnabled ); |
2366 | mCalendar->setReadOnly( cal->mCalNumber, cal->isReadOnly ); | 2372 | mCalendar->setReadOnly( cal->mCalNumber, cal->isReadOnly ); |
2367 | if ( cal->isStandard ) | 2373 | if ( cal->isStandard ) |
2368 | mCalendar->setDefaultCalendar( cal->mCalNumber ); | 2374 | mCalendar->setDefaultCalendar( cal->mCalNumber ); |
2369 | cal = calendars.next(); | 2375 | cal = calendars.next(); |
2370 | } | 2376 | } |
2371 | setSyncEventsReadOnly(); | 2377 | setSyncEventsReadOnly(); |
2372 | mCalendar->reInitAlarmSettings(); | 2378 | mCalendar->reInitAlarmSettings(); |
2373 | updateUnmanagedViews(); | 2379 | updateUnmanagedViews(); |
2374 | updateView(); | 2380 | updateView(); |
2375 | return true; | 2381 | return true; |
2376 | } | 2382 | } |
2377 | void CalendarView::addCalendarId( int id ) | 2383 | void CalendarView::addCalendarId( int id ) |
2378 | { | 2384 | { |
2379 | KopiCalendarFile * cal = KOPrefs::instance()->getCalendar( id ); | 2385 | KopiCalendarFile * cal = KOPrefs::instance()->getCalendar( id ); |
2380 | if ( cal ) | 2386 | if ( cal ) |
2381 | addCalendar( cal ); | 2387 | addCalendar( cal ); |
2382 | } | 2388 | } |
2383 | bool CalendarView::addCalendar( KopiCalendarFile * cal ) | 2389 | bool CalendarView::addCalendar( KopiCalendarFile * cal ) |
2384 | { | 2390 | { |
2385 | cal->mErrorOnLoad = false; | 2391 | cal->mErrorOnLoad = false; |
2386 | if ( mCalendar->addCalendarFile( cal->mFileName, cal->mCalNumber )) { | 2392 | if ( mCalendar->addCalendarFile( cal->mFileName, cal->mCalNumber )) { |
2387 | cal->mLoadDt = QDateTime::currentDateTime(); | 2393 | cal->mLoadDt = QDateTime::currentDateTime(); |
2388 | return true; | 2394 | return true; |
2389 | } | 2395 | } |
2390 | qDebug("KO: Error adding calendar file %s ",cal->mFileName.latin1() ); | 2396 | qDebug("KO: Error adding calendar file %s ",cal->mFileName.latin1() ); |
2391 | cal->mErrorOnLoad = true; | 2397 | cal->mErrorOnLoad = true; |
2392 | return false; | 2398 | return false; |
2393 | } | 2399 | } |
2394 | bool CalendarView::openCalendar(QString filename, bool merge) | 2400 | bool CalendarView::openCalendar(QString filename, bool merge) |
2395 | { | 2401 | { |
2396 | 2402 | ||
2397 | if (filename.isEmpty()) { | 2403 | if (filename.isEmpty()) { |
2398 | return false; | 2404 | return false; |
2399 | } | 2405 | } |
2400 | 2406 | ||
2401 | if (!QFile::exists(filename)) { | 2407 | if (!QFile::exists(filename)) { |
2402 | KMessageBox::error(this,i18n("File does not exist:\n '%1'.").arg(filename)); | 2408 | KMessageBox::error(this,i18n("File does not exist:\n '%1'.").arg(filename)); |
2403 | return false; | 2409 | return false; |
2404 | } | 2410 | } |
2405 | 2411 | ||
2406 | globalFlagBlockAgenda = 1; | 2412 | globalFlagBlockAgenda = 1; |
2407 | clearAllViews(); | 2413 | clearAllViews(); |
2408 | if (!merge) { | 2414 | if (!merge) { |
2409 | mViewManager->setDocumentId( filename ); | 2415 | mViewManager->setDocumentId( filename ); |
2410 | mCalendar->close(); | 2416 | mCalendar->close(); |
2411 | } | 2417 | } |
2412 | mStorage->setFileName( filename ); | 2418 | mStorage->setFileName( filename ); |
2413 | 2419 | ||
2414 | if ( mStorage->load() ) { | 2420 | if ( mStorage->load() ) { |
2415 | if ( merge ) ;//setModified( true ); | 2421 | if ( merge ) ;//setModified( true ); |
2416 | else { | 2422 | else { |
2417 | //setModified( true ); | 2423 | //setModified( true ); |
2418 | mViewManager->setDocumentId( filename ); | 2424 | mViewManager->setDocumentId( filename ); |
2419 | mDialogManager->setDocumentId( filename ); | 2425 | mDialogManager->setDocumentId( filename ); |
2420 | mTodoList->setDocumentId( filename ); | 2426 | mTodoList->setDocumentId( filename ); |
2421 | } | 2427 | } |
2422 | globalFlagBlockAgenda = 2; | 2428 | globalFlagBlockAgenda = 2; |
2423 | // if ( getLastSyncEvent() ) | 2429 | // if ( getLastSyncEvent() ) |
2424 | // getLastSyncEvent()->setReadOnly( true ); | 2430 | // getLastSyncEvent()->setReadOnly( true ); |
2425 | mCalendar->reInitAlarmSettings(); | 2431 | mCalendar->reInitAlarmSettings(); |
2426 | setSyncEventsReadOnly(); | 2432 | setSyncEventsReadOnly(); |
2427 | //updateUnmanagedViews(); | 2433 | //updateUnmanagedViews(); |
2428 | //updateView(); | 2434 | //updateView(); |
2429 | if ( filename != MainWindow::defaultFileName() ) { | 2435 | if ( filename != MainWindow::defaultFileName() ) { |
2430 | saveCalendar( MainWindow::defaultFileName() ); | 2436 | saveCalendar( MainWindow::defaultFileName() ); |
2431 | } else { | 2437 | } else { |
2432 | QFileInfo finf ( MainWindow::defaultFileName()); | 2438 | QFileInfo finf ( MainWindow::defaultFileName()); |
2433 | if ( finf.exists() ) { | 2439 | if ( finf.exists() ) { |
2434 | setLoadedFileVersion( finf.lastModified () ); | 2440 | setLoadedFileVersion( finf.lastModified () ); |
2435 | } | 2441 | } |
2436 | } | 2442 | } |
2437 | return true; | 2443 | return true; |
2438 | } else { | 2444 | } else { |
2439 | // while failing to load, the calendar object could | 2445 | // while failing to load, the calendar object could |
2440 | // have become partially populated. Clear it out. | 2446 | // have become partially populated. Clear it out. |
2441 | if ( !merge ) { | 2447 | if ( !merge ) { |
2442 | mCalendar->close(); | 2448 | mCalendar->close(); |
2443 | mViewManager->setDocumentId( filename ); | 2449 | mViewManager->setDocumentId( filename ); |
2444 | mDialogManager->setDocumentId( filename ); | 2450 | mDialogManager->setDocumentId( filename ); |
2445 | mTodoList->setDocumentId( filename ); | 2451 | mTodoList->setDocumentId( filename ); |
2446 | } | 2452 | } |
2447 | 2453 | ||
2448 | //KMessageBox::error(this,i18n("Couldn't load calendar\n '%1'.").arg(filename)); | 2454 | //KMessageBox::error(this,i18n("Couldn't load calendar\n '%1'.").arg(filename)); |
2449 | 2455 | ||
2450 | QTimer::singleShot ( 1, this, SLOT ( showOpenError() ) ); | 2456 | QTimer::singleShot ( 1, this, SLOT ( showOpenError() ) ); |
2451 | globalFlagBlockAgenda = 2; | 2457 | globalFlagBlockAgenda = 2; |
2452 | mCalendar->reInitAlarmSettings(); | 2458 | mCalendar->reInitAlarmSettings(); |
2453 | setSyncEventsReadOnly(); | 2459 | setSyncEventsReadOnly(); |
2454 | updateUnmanagedViews(); | 2460 | updateUnmanagedViews(); |
2455 | updateView(); | 2461 | updateView(); |
2456 | } | 2462 | } |
2457 | return false; | 2463 | return false; |
2458 | } | 2464 | } |
2459 | void CalendarView::mergeFile( QString fn ) | 2465 | void CalendarView::mergeFile( QString fn ) |
2460 | { | 2466 | { |
2461 | clearAllViews(); | 2467 | clearAllViews(); |
2462 | mCalendar->mergeCalendarFile( fn ); | 2468 | mCalendar->mergeCalendarFile( fn ); |
2463 | mCalendar->reInitAlarmSettings(); | 2469 | mCalendar->reInitAlarmSettings(); |
2464 | setSyncEventsReadOnly(); | 2470 | setSyncEventsReadOnly(); |
2465 | updateUnmanagedViews(); | 2471 | updateUnmanagedViews(); |
2466 | updateView(); | 2472 | updateView(); |
2467 | } | 2473 | } |
2468 | void CalendarView::mergeFileResource( QString fn ,QString resource ) | 2474 | void CalendarView::mergeFileResource( QString fn ,QString resource ) |
2469 | { | 2475 | { |
2470 | 2476 | ||
2471 | if ( resource == "ALL" ) { | 2477 | if ( resource == "ALL" ) { |
2472 | mCalendar->setAllCalendarEnabled( true ); | 2478 | mCalendar->setAllCalendarEnabled( true ); |
2473 | mergeFile( fn ); | 2479 | mergeFile( fn ); |
2474 | restoreCalendarSettings(); | 2480 | restoreCalendarSettings(); |
2475 | return; | 2481 | return; |
2476 | } | 2482 | } |
2477 | 2483 | ||
2478 | int exclusiveResource = KOPrefs::instance()->getFuzzyCalendarID( resource ); | 2484 | int exclusiveResource = KOPrefs::instance()->getFuzzyCalendarID( resource ); |
2479 | if ( !exclusiveResource ) { | 2485 | if ( !exclusiveResource ) { |
2480 | qDebug("KO: CalendarView::mergeFileResource: resource not found %s", resource.latin1() ); | 2486 | qDebug("KO: CalendarView::mergeFileResource: resource not found %s", resource.latin1() ); |
2481 | return; | 2487 | return; |
2482 | } | 2488 | } |
2483 | clearAllViews(); | 2489 | clearAllViews(); |
2484 | mCalendar->setCalendarRemove( exclusiveResource ); | 2490 | mCalendar->setCalendarRemove( exclusiveResource ); |
2485 | int def = mCalendar->defaultCalendar(); | ||
2486 | mCalendar->setDefaultCalendar(exclusiveResource); | 2491 | mCalendar->setDefaultCalendar(exclusiveResource); |
2492 | mCalendar->setAllCalendarEnabled( true ); | ||
2487 | if ( !mCalendar->addCalendarFile( fn, exclusiveResource )) { | 2493 | if ( !mCalendar->addCalendarFile( fn, exclusiveResource )) { |
2488 | qDebug("KO: CalendarView::mergeFileResource: error adding file %s", fn.latin1() ); | 2494 | qDebug("KO: CalendarView::mergeFileResource: error adding file %s", fn.latin1() ); |
2489 | } | 2495 | } |
2490 | mCalendar->setDefaultCalendar( def ); | 2496 | restoreCalendarSettings(); |
2491 | mCalendar->reInitAlarmSettings(); | ||
2492 | setSyncEventsReadOnly(); | ||
2493 | updateUnmanagedViews(); | ||
2494 | updateView(); | ||
2495 | } | 2497 | } |
2496 | void CalendarView::showOpenError() | 2498 | void CalendarView::showOpenError() |
2497 | { | 2499 | { |
2498 | KMessageBox::error(this,i18n("Couldn't load calendar\n.")); | 2500 | KMessageBox::error(this,i18n("Couldn't load calendar\n.")); |
2499 | } | 2501 | } |
2500 | void CalendarView::setLoadedFileVersion(QDateTime dt) | 2502 | void CalendarView::setLoadedFileVersion(QDateTime dt) |
2501 | { | 2503 | { |
2502 | loadedFileVersion = dt; | 2504 | loadedFileVersion = dt; |
2503 | } | 2505 | } |
2504 | bool CalendarView::checkFileChanged(QString fn) | 2506 | bool CalendarView::checkFileChanged(QString fn) |
2505 | { | 2507 | { |
2506 | QFileInfo finf ( fn ); | 2508 | QFileInfo finf ( fn ); |
2507 | if ( !finf.exists() ) | 2509 | if ( !finf.exists() ) |
2508 | return true; | 2510 | return true; |
2509 | QDateTime dt = finf.lastModified (); | 2511 | QDateTime dt = finf.lastModified (); |
2510 | if ( dt <= loadedFileVersion ) | 2512 | if ( dt <= loadedFileVersion ) |
2511 | return false; | 2513 | return false; |
2512 | return true; | 2514 | return true; |
2513 | 2515 | ||
2514 | } | 2516 | } |
2515 | void CalendarView::watchSavedFile() | 2517 | void CalendarView::watchSavedFile() |
2516 | { | 2518 | { |
2517 | QFileInfo finf ( MainWindow::defaultFileName()); | 2519 | QFileInfo finf ( MainWindow::defaultFileName()); |
2518 | if ( !finf.exists() ) | 2520 | if ( !finf.exists() ) |
2519 | return; | 2521 | return; |
2520 | QDateTime dt = finf.lastModified (); | 2522 | QDateTime dt = finf.lastModified (); |
2521 | if ( dt < loadedFileVersion ) { | 2523 | if ( dt < loadedFileVersion ) { |
2522 | //qDebug("watch %s %s ", dt.toString().latin1(), loadedFileVersion.toString().latin1()); | 2524 | //qDebug("watch %s %s ", dt.toString().latin1(), loadedFileVersion.toString().latin1()); |
2523 | QTimer::singleShot( 1000 , this, SLOT ( watchSavedFile() ) ); | 2525 | QTimer::singleShot( 1000 , this, SLOT ( watchSavedFile() ) ); |
2524 | return; | 2526 | return; |
2525 | } | 2527 | } |
2526 | loadedFileVersion = dt; | 2528 | loadedFileVersion = dt; |
2527 | } | 2529 | } |
2528 | bool CalendarView::checkAllFileVersions() | 2530 | bool CalendarView::checkAllFileVersions() |
2529 | { | 2531 | { |
2530 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; | 2532 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; |
2531 | KopiCalendarFile * cal = calendars.first(); | 2533 | KopiCalendarFile * cal = calendars.first(); |
2532 | mCalendar->setDefaultCalendar( 1 ); | 2534 | mCalendar->setDefaultCalendar( 1 ); |
2533 | mCalendar->setDefaultCalendarEnabledOnly(); | 2535 | mCalendar->setDefaultCalendarEnabledOnly(); |
2534 | if ( !cal->isReadOnly && !cal->mErrorOnLoad ) { | 2536 | if ( !cal->isReadOnly && !cal->mErrorOnLoad ) { |
2535 | if ( !checkFileVersion(MainWindow::defaultFileName())) { | 2537 | if ( !checkFileVersion(MainWindow::defaultFileName())) { |
2536 | restoreCalendarSettings(); | 2538 | restoreCalendarSettings(); |
2537 | return false; | 2539 | return false; |
2538 | } | 2540 | } |
2539 | } | 2541 | } |
2540 | cal = calendars.next(); | 2542 | cal = calendars.next(); |
2541 | QDateTime storeTemp = loadedFileVersion; | 2543 | QDateTime storeTemp = loadedFileVersion; |
2542 | while ( cal ) { | 2544 | while ( cal ) { |
2543 | if ( !cal->isReadOnly && !cal->mErrorOnLoad ) { | 2545 | if ( !cal->isReadOnly && !cal->mErrorOnLoad ) { |
2544 | mCalendar->setDefaultCalendar( cal->mCalNumber ); | 2546 | mCalendar->setDefaultCalendar( cal->mCalNumber ); |
2545 | mCalendar->setDefaultCalendarEnabledOnly(); | 2547 | mCalendar->setDefaultCalendarEnabledOnly(); |
2546 | loadedFileVersion = cal->mLoadDt.addSecs( 15 ); | 2548 | loadedFileVersion = cal->mLoadDt.addSecs( 15 ); |
2547 | if ( !checkFileVersion(cal->mFileName )) { | 2549 | if ( !checkFileVersion(cal->mFileName )) { |
2548 | loadedFileVersion = storeTemp; | 2550 | loadedFileVersion = storeTemp; |
2549 | restoreCalendarSettings(); | 2551 | restoreCalendarSettings(); |
2550 | return false; | 2552 | return false; |
2551 | } | 2553 | } |
2552 | } | 2554 | } |
2553 | cal = calendars.next(); | 2555 | cal = calendars.next(); |
2554 | } | 2556 | } |
2555 | loadedFileVersion = storeTemp; | 2557 | loadedFileVersion = storeTemp; |
2556 | return true; | 2558 | return true; |
2557 | } | 2559 | } |
2558 | bool CalendarView::checkFileVersion(QString fn) | 2560 | bool CalendarView::checkFileVersion(QString fn) |
2559 | { | 2561 | { |
2560 | QFileInfo finf ( fn ); | 2562 | QFileInfo finf ( fn ); |
2561 | if ( !finf.exists() ) | 2563 | if ( !finf.exists() ) |
2562 | return true; | 2564 | return true; |
2563 | QDateTime dt = finf.lastModified (); | 2565 | QDateTime dt = finf.lastModified (); |
2564 | //qDebug("loaded file version %s %s", fn.latin1(), loadedFileVersion.toString().latin1()); | 2566 | //qDebug("loaded file version %s %s", fn.latin1(), loadedFileVersion.toString().latin1()); |
2565 | //qDebug("file on disk version %s %s", fn.latin1(),dt.toString().latin1()); | 2567 | //qDebug("file on disk version %s %s", fn.latin1(),dt.toString().latin1()); |
2566 | if ( dt <= loadedFileVersion ) | 2568 | if ( dt <= loadedFileVersion ) |
2567 | return true; | 2569 | return true; |
2568 | int km = KMessageBox::warningYesNoCancel(this, i18n("\nThe file\n%1\non disk has changed!\nFile size: %2 bytes.\nLast modified: %3\nDo you want to:\n\n - Save and overwrite file?\n - Sync with file, then save?\n - Cancel without saving? \n").arg(KGlobal::formatMessage(fn,0)).arg( QString::number( finf.size())).arg( KGlobal::locale()->formatDateTime(finf.lastModified (), true, true)) , | 2570 | int km = KMessageBox::warningYesNoCancel(this, i18n("\nThe file\n%1\non disk has changed!\nFile size: %2 bytes.\nLast modified: %3\nDo you want to:\n\n - Save and overwrite file?\n - Sync with file, then save?\n - Cancel without saving? \n").arg(KGlobal::formatMessage(fn,0)).arg( QString::number( finf.size())).arg( KGlobal::locale()->formatDateTime(finf.lastModified (), true, true)) , |
2569 | i18n("KO/Pi Warning"),i18n("Overwrite"), | 2571 | i18n("KO/Pi Warning"),i18n("Overwrite"), |
2570 | i18n("Sync+save")); | 2572 | i18n("Sync+save")); |
2571 | 2573 | ||
2572 | if ( km == KMessageBox::Cancel ) | 2574 | if ( km == KMessageBox::Cancel ) |
2573 | return false; | 2575 | return false; |
2574 | if ( km == KMessageBox::Yes ) | 2576 | if ( km == KMessageBox::Yes ) |
2575 | return true; | 2577 | return true; |
2576 | 2578 | ||
2577 | setSyncDevice("deleteaftersync" ); | 2579 | setSyncDevice("deleteaftersync" ); |
2578 | mSyncManager->mAskForPreferences = true; | 2580 | mSyncManager->mAskForPreferences = true; |
2579 | mSyncManager->mSyncAlgoPrefs = 3; | 2581 | mSyncManager->mSyncAlgoPrefs = 3; |
2580 | mSyncManager->mWriteBackFile = false; | 2582 | mSyncManager->mWriteBackFile = false; |
2581 | mSyncManager->mWriteBackExistingOnly = false; | 2583 | mSyncManager->mWriteBackExistingOnly = false; |
2582 | mSyncManager->mShowSyncSummary = false; | 2584 | mSyncManager->mShowSyncSummary = false; |
2583 | mMultiResourceSync = false; | 2585 | mMultiResourceSync = false; |
2584 | syncCalendar( fn, 3 ); | 2586 | syncCalendar( fn, 3 ); |
2585 | Event * e = getLastSyncEvent(); | 2587 | Event * e = getLastSyncEvent(); |
2586 | if ( e ) | 2588 | if ( e ) |
2587 | mCalendar->deleteEvent( e ); | 2589 | mCalendar->deleteEvent( e ); |
2588 | return true; | 2590 | return true; |
2589 | } | 2591 | } |
2590 | bool CalendarView::saveCalendars() | 2592 | bool CalendarView::saveCalendars() |
2591 | { | 2593 | { |
2592 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; | 2594 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; |
2593 | KopiCalendarFile * cal = calendars.first(); | 2595 | KopiCalendarFile * cal = calendars.first(); |
2594 | mCalendar->setDefaultCalendar( 1 ); | 2596 | mCalendar->setDefaultCalendar( 1 ); |
2595 | mCalendar->setDefaultCalendarEnabledOnly(); | 2597 | mCalendar->setDefaultCalendarEnabledOnly(); |
2596 | QString saveError; | 2598 | QString saveError; |
2597 | if ( !saveCalendar( MainWindow::defaultFileName() ) ) | 2599 | if ( !saveCalendar( MainWindow::defaultFileName() ) ) |
2598 | saveError = cal->mName +"\n"; | 2600 | saveError = cal->mName +"\n"; |
2599 | cal = calendars.next(); | 2601 | cal = calendars.next(); |
2600 | while ( cal ) { | 2602 | while ( cal ) { |
2601 | if ( !cal->isReadOnly && !cal->mErrorOnLoad ) { | 2603 | if ( !cal->isReadOnly && !cal->mErrorOnLoad ) { |
2602 | mCalendar->setDefaultCalendar( cal->mCalNumber ); | 2604 | mCalendar->setDefaultCalendar( cal->mCalNumber ); |
2603 | mCalendar->setDefaultCalendarEnabledOnly(); | 2605 | mCalendar->setDefaultCalendarEnabledOnly(); |
2604 | if ( saveCalendar( cal->mFileName ) ) | 2606 | if ( saveCalendar( cal->mFileName ) ) |
2605 | cal->mLoadDt = QDateTime::currentDateTime(); | 2607 | cal->mLoadDt = QDateTime::currentDateTime(); |
2606 | else | 2608 | else |
2607 | saveError += cal->mName + "\n"; | 2609 | saveError += cal->mName + "\n"; |
2608 | } | 2610 | } |
2609 | cal = calendars.next(); | 2611 | cal = calendars.next(); |
2610 | } | 2612 | } |
2611 | restoreCalendarSettings(); | 2613 | restoreCalendarSettings(); |
2612 | //saveError = "test error"; | 2614 | //saveError = "test error"; |
2613 | if ( !saveError.isEmpty() ) { | 2615 | if ( !saveError.isEmpty() ) { |
2614 | saveError = KGlobal::formatMessage( i18n("Calendar(s) not saved:"),0 )+"\n" + saveError; | 2616 | saveError = KGlobal::formatMessage( i18n("Calendar(s) not saved:"),0 )+"\n" + saveError; |
2615 | KMessageBox::error(this, saveError, i18n("Error saving data")); | 2617 | KMessageBox::error(this, saveError, i18n("Error saving data")); |
2616 | return false; | 2618 | return false; |
2617 | } | 2619 | } |
2618 | return true; | 2620 | return true; |
2619 | } | 2621 | } |
2620 | bool CalendarView::saveCalendarResource(QString filename, QString resource) | 2622 | bool CalendarView::saveCalendarResource(QString filename, QString resource) |
2621 | { | 2623 | { |
2622 | if ( resource == "ALL" ) { | 2624 | if ( resource == "ALL" ) { |