X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fbacklogrequester.h;h=c3c6832b4f49bed6b1be7cda670e4816c511c180;hp=af7696afc98c9fb4d059aafb0f144125ed982a6e;hb=b3a8232d4959903591c309d765da9c271d0a761f;hpb=fb011e52bc6613198a65e037f0752f6361339aeb diff --git a/src/client/backlogrequester.h b/src/client/backlogrequester.h index af7696af..c3c6832b 100644 --- a/src/client/backlogrequester.h +++ b/src/client/backlogrequester.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -34,9 +34,9 @@ class BacklogRequester { public: enum RequesterTypes { InvalidRequester = 0, - GlobalUnread, + PerBufferFixed, PerBufferUnread, - PerBufferFixed + GlobalUnread }; BacklogRequester(bool buffering, ClientBacklogManager *backlogManger); @@ -45,6 +45,8 @@ public: inline bool isBuffering() { return _isBuffering; } inline const QList &bufferedMessages() { return _bufferedMessages; } + inline int buffersWaiting() const { return _buffersWaiting.count(); } + inline int totalBuffers() const { return _totalBuffers; } //! returns false if it was the last missing backlogpart bool buffer(BufferId bufferId, const MessageList &messages); @@ -52,15 +54,16 @@ public: protected: inline QList allBufferIds() const { return Client::networkModel()->allBufferIds(); } - inline void setWaitingBuffers(const QList &buffers) { _buffersWaiting = buffers.toSet(); } - inline void setWaitingBuffers(const QSet &buffers) { _buffersWaiting = buffers; } - inline void addWaitingBuffer(BufferId buffer) { _buffersWaiting << buffer; } + inline void setWaitingBuffers(const QList &buffers) { setWaitingBuffers(buffers.toSet()); } + void setWaitingBuffers(const QSet &buffers); + void addWaitingBuffer(BufferId buffer); ClientBacklogManager *backlogManager; private: bool _isBuffering; MessageList _bufferedMessages; + int _totalBuffers; QSet _buffersWaiting; }; @@ -76,5 +79,30 @@ 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