X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fbacklogrequester.h;h=e813c6c79d519d83fa7c47ed54b06212f308e882;hp=4ddc96246f3fbfcac00b850442367c8eb0f1d613;hb=62b7bed21f011037a34d7a4ea797d79fbdeff687;hpb=335e1e55ee8df69b37b1b4d839950ced9ac08cc4 diff --git a/src/client/backlogrequester.h b/src/client/backlogrequester.h index 4ddc9624..e813c6c7 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 * @@ -32,35 +32,43 @@ class ClientBacklogManager; class BacklogRequester { public: - enum RequesterTypes { + enum RequesterType { InvalidRequester = 0, - GlobalUnread, + PerBufferFixed, PerBufferUnread, - PerBufferFixed + 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; } - //! returns false if it was the last missing backlogpart - bool buffer(BufferId bufferId, const MessageList &messages); - - virtual void requestBacklog() = 0; + inline int buffersWaiting() const { return _buffersWaiting.count(); } + inline int totalBuffers() const { return _totalBuffers; } + + bool buffer(BufferId bufferId, const MessageList &messages); //! returns false if it was the last missing backlogpart + + virtual void requestBacklog(const BufferIdList &bufferIds) = 0; + virtual inline void requestInitialBacklog() { requestBacklog(allBufferIds()); } + + virtual void flushBuffer(); 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; } + BufferIdList allBufferIds() const; + inline void setWaitingBuffers(const QList &buffers) { setWaitingBuffers(buffers.toSet()); } + void setWaitingBuffers(const QSet &buffers); + void addWaitingBuffer(BufferId buffer); ClientBacklogManager *backlogManager; private: bool _isBuffering; + RequesterType _requesterType; MessageList _bufferedMessages; + int _totalBuffers; QSet _buffersWaiting; }; @@ -70,7 +78,7 @@ private: class FixedBacklogRequester : public BacklogRequester { public: FixedBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(); + virtual void requestBacklog(const BufferIdList &bufferIds); private: int _backlogCount; @@ -82,7 +90,8 @@ private: class GlobalUnreadBacklogRequester : public BacklogRequester { public: GlobalUnreadBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(); + virtual void requestInitialBacklog(); + virtual void requestBacklog(const BufferIdList &) {} private: int _limit; @@ -95,7 +104,7 @@ private: class PerBufferUnreadBacklogRequester : public BacklogRequester { public: PerBufferUnreadBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(); + virtual void requestBacklog(const BufferIdList &bufferIds); private: int _limit;