X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientbacklogmanager.h;h=2aa399b5e9b9e26ca74089d181e3f5ee6170a1cd;hp=0762edfda1284e584da8be9c9f7eb5c13a147de5;hb=0bc4b2b4a25adea85d5f6c6947cfd31f9098149e;hpb=92f256c9ef102ef5af61164bb17b63e501510541 diff --git a/src/client/clientbacklogmanager.h b/src/client/clientbacklogmanager.h index 0762edfd..2aa399b5 100644 --- a/src/client/clientbacklogmanager.h +++ b/src/client/clientbacklogmanager.h @@ -38,13 +38,14 @@ 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); void requestInitialBacklog(); void checkForBacklog(BufferId bufferId); - void checkForBacklog(const QList &bufferIds); + void checkForBacklog(const BufferIdList &bufferIds); signals: void messagesReceived(BufferId bufferId, int count) const; @@ -55,12 +56,17 @@ signals: private: bool isBuffering(); - void stopBuffering(); + BufferIdList filterNewBufferIds(const BufferIdList &bufferIds); void dispatchMessages(const MessageList &messages, bool sort = false); BacklogRequester *_requester; - QSet _backlogReceived; + QSet _buffersRequested; }; +// inlines +inline void ClientBacklogManager::checkForBacklog(BufferId bufferId) { + checkForBacklog(BufferIdList() << bufferId); +} + #endif // CLIENTBACKLOGMANAGER_H