X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fbacklogrequester.h;h=73571270835f048f01a65e2846a31c3ea7c40ff4;hp=991ea8acdae16b7aa84c10b6ce29ed2d758459c5;hb=47b54cd3ad35201ff2ab9ef6bfdba83fc086558d;hpb=76db8cdfbeffaaba359c8e80cf2146da9e9e7f8a diff --git a/src/client/backlogrequester.h b/src/client/backlogrequester.h index 991ea8ac..73571270 100644 --- a/src/client/backlogrequester.h +++ b/src/client/backlogrequester.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2013 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -18,8 +18,9 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef BACKLOGREQUESTER_H -#define BACKLOGREQUESTER_H +#pragma once + +#include #include @@ -33,90 +34,83 @@ class ClientBacklogManager; class BacklogRequester { public: - enum RequesterType { + enum RequesterType + { InvalidRequester = 0, PerBufferFixed, PerBufferUnread, GlobalUnread }; - BacklogRequester(bool buffering, RequesterType requesterType, ClientBacklogManager *backlogManger); - virtual inline ~BacklogRequester() {} + BacklogRequester(bool buffering, RequesterType requesterType, ClientBacklogManager* backlogManger); + virtual ~BacklogRequester() = default; inline bool isBuffering() { return _isBuffering; } inline RequesterType type() { return _requesterType; } - inline const QList &bufferedMessages() { return _bufferedMessages; } + inline const QList& bufferedMessages() { return _bufferedMessages; } - inline int buffersWaiting() const { return _buffersWaiting.count(); } + inline int buffersWaiting() const { return int(_buffersWaiting.size()); } inline int totalBuffers() const { return _totalBuffers; } - bool buffer(BufferId bufferId, const MessageList &messages); //! returns false if it was the last missing backlogpart + bool buffer(BufferId bufferId, const MessageList& messages); //! returns false if it was the last missing backlogpart - virtual void requestBacklog(const BufferIdList &bufferIds) = 0; + virtual void requestBacklog(const BufferIdList& bufferIds) = 0; virtual inline void requestInitialBacklog() { requestBacklog(allBufferIds()); } virtual void flushBuffer(); protected: BufferIdList allBufferIds() const; - inline void setWaitingBuffers(const QList &buffers) { setWaitingBuffers(buffers.toSet()); } - void setWaitingBuffers(const QSet &buffers); - void addWaitingBuffer(BufferId buffer); + void setWaitingBuffers(const BufferIdList& buffers); - ClientBacklogManager *backlogManager; + ClientBacklogManager* backlogManager; private: bool _isBuffering; RequesterType _requesterType; MessageList _bufferedMessages; int _totalBuffers; - QSet _buffersWaiting; + std::set _buffersWaiting; }; - // ======================================== // FIXED BACKLOG REQUESTER // ======================================== class FixedBacklogRequester : public BacklogRequester { public: - FixedBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(const BufferIdList &bufferIds); + FixedBacklogRequester(ClientBacklogManager* backlogManager); + void requestBacklog(const BufferIdList& bufferIds) override; private: int _backlogCount; }; - // ======================================== // GLOBAL UNREAD BACKLOG REQUESTER // ======================================== class GlobalUnreadBacklogRequester : public BacklogRequester { public: - GlobalUnreadBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestInitialBacklog(); - virtual void requestBacklog(const BufferIdList &) {} + GlobalUnreadBacklogRequester(ClientBacklogManager* backlogManager); + void requestInitialBacklog() override; + void requestBacklog(const BufferIdList&) override {} private: int _limit; int _additional; }; - // ======================================== // PER BUFFER UNREAD BACKLOG REQUESTER // ======================================== class PerBufferUnreadBacklogRequester : public BacklogRequester { public: - PerBufferUnreadBacklogRequester(ClientBacklogManager *backlogManager); - virtual void requestBacklog(const BufferIdList &bufferIds); + PerBufferUnreadBacklogRequester(ClientBacklogManager* backlogManager); + void requestBacklog(const BufferIdList& bufferIds) override; private: int _limit; int _additional; }; - - -#endif //BACKLOGREQUESTER_H