X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fbacklogrequester.h;h=95745ab3ed3ec27df418d9eab22c237e68473c32;hb=5992edbbfa5a6e4a3c72b07c6f08a464f87dd432;hp=b942d7b34f0db9997e83f6c70f0281df73ddcc65;hpb=8f0946673bc3edc84b6f13e16cbe8ece912b4a3b;p=quassel.git diff --git a/src/client/backlogrequester.h b/src/client/backlogrequester.h index b942d7b3..95745ab3 100644 --- a/src/client/backlogrequester.h +++ b/src/client/backlogrequester.h @@ -28,18 +28,18 @@ #include "networkmodel.h" #include "types.h" -class BacklogManager; +class ClientBacklogManager; class BacklogRequester { public: enum RequesterTypes { InvalidRequester = 0, - GlobalUnread, + PerBufferFixed, PerBufferUnread, - PerBufferFixed + GlobalUnread }; - BacklogRequester(bool buffering, BacklogManager *backlogManger); + BacklogRequester(bool buffering, ClientBacklogManager *backlogManger); virtual inline ~BacklogRequester() {} inline bool isBuffering() { return _isBuffering; } @@ -55,7 +55,8 @@ protected: inline void setWaitingBuffers(const QList &buffers) { _buffersWaiting = buffers.toSet(); } inline void setWaitingBuffers(const QSet &buffers) { _buffersWaiting = buffers; } inline void addWaitingBuffer(BufferId buffer) { _buffersWaiting << buffer; } - BacklogManager *backlogManager; + + ClientBacklogManager *backlogManager; private: bool _isBuffering; @@ -68,12 +69,37 @@ private: // ======================================== class FixedBacklogRequester : public BacklogRequester { public: - FixedBacklogRequester(BacklogManager *backlogManager); + FixedBacklogRequester(ClientBacklogManager *backlogManager); virtual void requestBacklog(); private: int _backlogCount; }; +// ======================================== +// GLOBAL UNREAD BACKLOG REQUESTER +// ======================================== +class GlobalUnreadBacklogRequester : public BacklogRequester { +public: + GlobalUnreadBacklogRequester(ClientBacklogManager *backlogManager); + virtual void requestBacklog(); + +private: + int _limit; + int _additional; +}; + +// ======================================== +// PER BUFFER UNREAD BACKLOG REQUESTER +// ======================================== +class PerBufferUnreadBacklogRequester : public BacklogRequester { +public: + PerBufferUnreadBacklogRequester(ClientBacklogManager *backlogManager); + virtual void requestBacklog(); + +private: + int _limit; + int _additional; +}; #endif //BACKLOGREQUESTER_H