X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fbacklogrequester.h;h=c7c3afe922fbcc34e0a1e47cc4cf9c92c8765c1d;hb=0a1c1ff4f99a7eb53ff6cdd95ce5d7ac263e77d2;hp=c3c6832b4f49bed6b1be7cda670e4816c511c180;hpb=5bd4e3fcf31a7a337f91b3bba86bd237aa5e7ed6;p=quassel.git diff --git a/src/client/backlogrequester.h b/src/client/backlogrequester.h index c3c6832b..c7c3afe9 100644 --- a/src/client/backlogrequester.h +++ b/src/client/backlogrequester.h @@ -32,17 +32,18 @@ class ClientBacklogManager; class BacklogRequester { public: - enum RequesterTypes { + enum RequesterType { InvalidRequester = 0, PerBufferFixed, PerBufferUnread, GlobalUnread }; - BacklogRequester(bool buffering, ClientBacklogManager *backlogManger); + BacklogRequester(bool buffering, RequesterType requesterType, ClientBacklogManager *backlogManger); virtual inline ~BacklogRequester() {} inline bool isBuffering() { return _isBuffering; } + inline RequesterType type() { return _requesterType; } inline const QList &bufferedMessages() { return _bufferedMessages; } inline int buffersWaiting() const { return _buffersWaiting.count(); } @@ -50,10 +51,11 @@ public: //! returns false if it was the last missing backlogpart bool buffer(BufferId bufferId, const MessageList &messages); - virtual void requestBacklog() = 0; + virtual void requestBacklog(const BufferIdList &bufferIds) = 0; + virtual inline void requestInitialBacklog() { requestBacklog(allBufferIds()); } protected: - inline QList allBufferIds() const { return Client::networkModel()->allBufferIds(); } + BufferIdList allBufferIds() const; inline void setWaitingBuffers(const QList &buffers) { setWaitingBuffers(buffers.toSet()); } void setWaitingBuffers(const QSet &buffers); void addWaitingBuffer(BufferId buffer); @@ -62,6 +64,7 @@ protected: private: bool _isBuffering; + RequesterType _requesterType; MessageList _bufferedMessages; int _totalBuffers; QSet _buffersWaiting; @@ -73,7 +76,7 @@ private: class FixedBacklogRequester : public BacklogRequester { public: FixedBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(); + virtual void requestBacklog(const BufferIdList &bufferIds); private: int _backlogCount; @@ -85,7 +88,8 @@ private: class GlobalUnreadBacklogRequester : public BacklogRequester { public: GlobalUnreadBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(); + virtual void requestInitialBacklog(); + virtual void requestBacklog(const BufferIdList &) {} private: int _limit; @@ -98,7 +102,7 @@ private: class PerBufferUnreadBacklogRequester : public BacklogRequester { public: PerBufferUnreadBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(); + virtual void requestBacklog(const BufferIdList &bufferIds); private: int _limit;