X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fbacklogrequester.h;h=af7696afc98c9fb4d059aafb0f144125ed982a6e;hp=5ef71b28784b7b7bdae562fbbf3b0ff02c5c8e8d;hb=fb011e52bc6613198a65e037f0752f6361339aeb;hpb=332069a1830ed3a055ac6f2d7661bae1cc83e40c diff --git a/src/client/backlogrequester.h b/src/client/backlogrequester.h index 5ef71b28..af7696af 100644 --- a/src/client/backlogrequester.h +++ b/src/client/backlogrequester.h @@ -24,32 +24,56 @@ #include #include "client.h" +#include "message.h" #include "networkmodel.h" #include "types.h" -class BacklogManager; +class ClientBacklogManager; class BacklogRequester { public: - BacklogRequester(BacklogManager *backlogManger); + enum RequesterTypes { + InvalidRequester = 0, + GlobalUnread, + PerBufferUnread, + PerBufferFixed + }; + + BacklogRequester(bool buffering, ClientBacklogManager *backlogManger); virtual inline ~BacklogRequester() {} + inline bool isBuffering() { return _isBuffering; } + inline const QList &bufferedMessages() { return _bufferedMessages; } + + //! returns false if it was the last missing backlogpart + bool buffer(BufferId bufferId, const MessageList &messages); + virtual void requestBacklog() = 0; protected: inline QList allBufferIds() const { return Client::networkModel()->allBufferIds(); } - BacklogManager *backlogManager; -}; + inline void setWaitingBuffers(const QList &buffers) { _buffersWaiting = buffers.toSet(); } + inline void setWaitingBuffers(const QSet &buffers) { _buffersWaiting = buffers; } + inline void addWaitingBuffer(BufferId buffer) { _buffersWaiting << buffer; } + ClientBacklogManager *backlogManager; +private: + bool _isBuffering; + MessageList _bufferedMessages; + QSet _buffersWaiting; +}; + +// ======================================== +// FIXED BACKLOG REQUESTER +// ======================================== class FixedBacklogRequester : public BacklogRequester { public: - FixedBacklogRequester(BacklogManager *backlogManager); - + FixedBacklogRequester(ClientBacklogManager *backlogManager); virtual void requestBacklog(); private: - static const int backlogCount; + int _backlogCount; };