From 3506c78afcfcf63d74d1b57b53518ea27dae2f8c Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Tue, 7 Mar 2017 14:56:03 +0100 Subject: Merge synchronization requests for individual mails of the same folder. We use this frequently when loading conversations, so this results in a significant preformance improvement. --- examples/imapresource/imapresource.cpp | 38 ++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) (limited to 'examples/imapresource/imapresource.cpp') diff --git a/examples/imapresource/imapresource.cpp b/examples/imapresource/imapresource.cpp index 09f57d5..fff4dc7 100644 --- a/examples/imapresource/imapresource.cpp +++ b/examples/imapresource/imapresource.cpp @@ -393,6 +393,44 @@ public: return list; } + QByteArray getFolderFromLocalId(const QByteArray &id) + { + auto mailRemoteId = syncStore().resolveLocalId(ApplicationDomain::getTypeName(), id); + return folderIdFromMailRid(mailRemoteId); + } + + void mergeIntoQueue(const Synchronizer::SyncRequest &request, QList &queue) Q_DECL_OVERRIDE + { + auto isIndividualMailSync = [](const Synchronizer::SyncRequest &request) { + if (request.requestType == SyncRequest::Synchronization) { + const auto query = request.query; + if (query.type() == ApplicationDomain::getTypeName()) { + return !query.ids().isEmpty(); + } + } + return false; + + }; + + if (isIndividualMailSync(request)) { + auto newId = request.query.ids().first(); + auto requestFolder = getFolderFromLocalId(newId); + for (auto &r : queue) { + if (isIndividualMailSync(r)) { + auto queueFolder = getFolderFromLocalId(r.query.ids().first()); + if (requestFolder == queueFolder) { + //Merge + r.query.filter(newId); + SinkTrace() << "Merging request " << request.query; + SinkTrace() << " to " << r.query; + return; + } + } + } + } + queue << request; + } + KAsync::Job login(QSharedPointer imap) { SinkTrace() << "Connecting to:" << mServer << mPort; -- cgit v1.2.3