[Akonadi] [Bug 314964] after deleting large number of email, Invalid uidset errors
    Daniel Vrátil  
    dvratil at redhat.com
       
    Wed Oct 30 16:22:28 GMT 2013
    
    
  
https://bugs.kde.org/show_bug.cgi?id=314964
--- Comment #4 from Daniel Vrátil <dvratil at redhat.com> ---
Git commit 498d6678f478bd1bd9bdc944bb790f6b16b7ade4 by Dan Vrátil.
Committed on 30/10/2013 at 15:46.
Pushed by dvratil into branch 'KDE/4.11'.
Wait for changes from resource to be written to Akonadi before marking change
as processed
This fixes a problem with invalid RIDs after inter-resource moves.
When there is an another changeReplay for the just moved item
scheduled in the new parent resource, the item will have invalid RID
(or rather RID assigned to it by the previous parent resource).
It's because the ItemModifyJob dispatched from ResourceBase::changesCommitted()
with the new RID is not finished yet when the next task is dispatched,
and so the item in resource's EntityCache is not invalidated
and the resource will use it instead of the updated one.
By waiting for the ItemModifyJob dispatched from changesCommited()
to finish before marking the change as processed and dispatching
next task we make sure that in case the next task involves the
same item the change will be stored in Akonadi and the item will
be invalidated in local caches, forcing the resource to fetch the
item again from Akonadi before starting the task.
This fixes 'Invalid uidset' error reported by IMAP resources after
the MailDispatcher agent moves the mail from local Outbox to remote
Sent folder and updates it's flags.
Related: bug 323762, bug 324807
FIXED-IN: 4.11.3
M  +11   -5    akonadi/resourcebase.cpp
http://commits.kde.org/kdepimlibs/498d6678f478bd1bd9bdc944bb790f6b16b7ade4
-- 
You are receiving this mail because:
You are on the CC list for the bug.
    
    
More information about the Kdepim-bugs
mailing list