mirror of
https://github.com/archlinuxarm/PKGBUILDs.git
synced 2024-12-28 23:21:53 +00:00
75 lines
3 KiB
Diff
75 lines
3 KiB
Diff
Index: branches/KDE/4.3/kdepim/kmail/cachedimapjob.cpp
|
|
===================================================================
|
|
--- branches/KDE/4.3/kdepim/kmail/cachedimapjob.cpp (revision 1022962)
|
|
+++ branches/KDE/4.3/kdepim/kmail/cachedimapjob.cpp (revision 1022963)
|
|
@@ -510,7 +510,7 @@
|
|
bool b = kmkernel->iCalIface().isResourceQuiet();
|
|
kmkernel->iCalIface().setResourceQuiet( true );
|
|
|
|
- mFolder->take( i );
|
|
+ mFolder->takeTemporarily( i );
|
|
mFolder->addMsgKeepUID( mMsg );
|
|
mMsg->setTransferInProgress( false );
|
|
|
|
Index: branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.cpp
|
|
===================================================================
|
|
--- branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.cpp (revision 1022962)
|
|
+++ branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.cpp (revision 1022963)
|
|
@@ -527,6 +527,11 @@
|
|
return KMFolderMaildir::take( idx );
|
|
}
|
|
|
|
+void KMFolderCachedImap::takeTemporarily( int idx )
|
|
+{
|
|
+ KMFolderMaildir::take( idx );
|
|
+}
|
|
+
|
|
int KMFolderCachedImap::addMsgInternal( KMMessage *msg, bool newMail, int *index_return )
|
|
{
|
|
// Possible optimization: Only dirty if not filtered below
|
|
Index: branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.h
|
|
===================================================================
|
|
--- branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.h (revision 1022962)
|
|
+++ branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.h (revision 1022963)
|
|
@@ -228,10 +228,23 @@
|
|
/** Reimplemented from KMFolder. Moving is not supported, so aParent must be 0. */
|
|
virtual int rename( const QString &aName, KMFolderDir *aParent = 0 );
|
|
|
|
- /** Reimplemented from KMFolderMaildir */
|
|
- virtual KMMessage *take( int idx );
|
|
bool canDeleteMessages() const;
|
|
|
|
+ /**
|
|
+ * Reimplemented from KMFolderMaildir
|
|
+ * This deletes the message permanently, also from the server. For this,
|
|
+ * rememberDeletion() is called, so that the message can be deleted from
|
|
+ * the server on the next sync.
|
|
+ */
|
|
+ virtual KMMessage* take( int idx );
|
|
+
|
|
+ /**
|
|
+ * Like take(), only that the deletion is not remembered, i.e. the
|
|
+ * message will not be deleted from the server. Calling this can cause
|
|
+ * inconsistencies, so make sure you re-add the message later!
|
|
+ */
|
|
+ void takeTemporarily( int idx );
|
|
+
|
|
/** Reimplemented from KMFolderMaildir */
|
|
virtual int addMsg( KMMessage *msg, int *index_return = 0 );
|
|
|
|
Index: branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.cpp
|
|
===================================================================
|
|
--- branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.cpp (revision 1022963)
|
|
+++ branches/KDE/4.3/kdepim/kmail/kmfoldercachedimap.cpp (revision 1022964)
|
|
@@ -1678,6 +1678,11 @@
|
|
job->start();
|
|
return true;
|
|
} else {
|
|
+
|
|
+ // Nothing to delete on the server, make sure the map is clear again.
|
|
+ // Normally this wouldn't be necessary, but there can be stale maps because of
|
|
+ // https://issues.kolab.org/issue3833.
|
|
+ mDeletedUIDsSinceLastSync.clear();
|
|
return false;
|
|
}
|
|
}
|