From 8aa25a7c1526915741a7da989cc0a663bd84eb31 Mon Sep 17 00:00:00 2001 From: Marcus Eggenberger Date: Thu, 26 Mar 2009 23:04:23 +0100 Subject: [PATCH] preventing refetching of backlog which was already pulled inwith the initial request --- src/client/clientbacklogmanager.cpp | 7 ++++++- src/client/clientbacklogmanager.h | 1 + 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/src/client/clientbacklogmanager.cpp b/src/client/clientbacklogmanager.cpp index 2b2c5864..fc82d20f 100644 --- a/src/client/clientbacklogmanager.cpp +++ b/src/client/clientbacklogmanager.cpp @@ -35,6 +35,12 @@ ClientBacklogManager::ClientBacklogManager(QObject *parent) { } +QVariantList ClientBacklogManager::requestBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional) { + _buffersRequested << bufferId; + qDebug() << _buffersRequested; + return BacklogManager::requestBacklog(bufferId, first, last, limit, additional); +} + void ClientBacklogManager::receiveBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional, QVariantList msgs) { Q_UNUSED(first) Q_UNUSED(last) Q_UNUSED(limit) Q_UNUSED(additional) @@ -102,7 +108,6 @@ BufferIdList ClientBacklogManager::filterNewBufferIds(const BufferIdList &buffer if(!_buffersRequested.contains(bufferId)) newBuffers << bufferId; } - _buffersRequested += bufferIds.toSet(); return newBuffers; } diff --git a/src/client/clientbacklogmanager.h b/src/client/clientbacklogmanager.h index 5f1e1cd9..1c9f6dd9 100644 --- a/src/client/clientbacklogmanager.h +++ b/src/client/clientbacklogmanager.h @@ -38,6 +38,7 @@ public: void reset(); public slots: + virtual QVariantList requestBacklog(BufferId bufferId, MsgId first = -1, MsgId last = -1, int limit = -1, int additional = 0); virtual void receiveBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional, QVariantList msgs); virtual void receiveBacklogAll(MsgId first, MsgId last, int limit, int additional, QVariantList msgs); -- 2.20.1