X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fclientbacklogmanager.h;h=5f1e1cd9218071b7c637cee1a2d106107b3b94bf;hb=ab16c77fe03b73a863d9b52b11919bcbac903f58;hp=5ead6636a10f8363f272a8806a31adc6e6b67f70;hpb=8ec76e512d20ce5d1dc76de556bb98a06b75d695;p=quassel.git diff --git a/src/client/clientbacklogmanager.h b/src/client/clientbacklogmanager.h index 5ead6636..5f1e1cd9 100644 --- a/src/client/clientbacklogmanager.h +++ b/src/client/clientbacklogmanager.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -22,6 +22,9 @@ #define CLIENTBACKLOGMANAGER_H #include "backlogmanager.h" +#include "message.h" + +class BacklogRequester; class ClientBacklogManager : public BacklogManager { Q_OBJECT @@ -29,13 +32,41 @@ class ClientBacklogManager : public BacklogManager { public: ClientBacklogManager(QObject *parent = 0); - virtual const QMetaObject *syncMetaObject() const { return &BacklogManager::staticMetaObject; } + // helper for the backlogRequester, as it isn't a QObject and can't emit itself + inline void emitMessagesRequested(const QString &msg) const { emit messagesRequested(msg); } + + void reset(); public slots: - virtual void receiveBacklog(BufferId bufferId, int lastMsgs, int offset, QVariantList msgs); + virtual void receiveBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional, QVariantList msgs); + virtual void receiveBacklogAll(MsgId first, MsgId last, int limit, int additional, QVariantList msgs); + + void requestInitialBacklog(); + + void checkForBacklog(BufferId bufferId); + void checkForBacklog(const BufferIdList &bufferIds); signals: - void backlog(BufferId bufferId, const QVariantList &msgs); + void messagesReceived(BufferId bufferId, int count) const; + void messagesRequested(const QString &) const; + void messagesProcessed(const QString &) const; + + void updateProgress(int, int); + +private: + bool isBuffering(); + void stopBuffering(); + BufferIdList filterNewBufferIds(const BufferIdList &bufferIds); + + void dispatchMessages(const MessageList &messages, bool sort = false); + + BacklogRequester *_requester; + QSet _buffersRequested; }; +// inlines +inline void ClientBacklogManager::checkForBacklog(BufferId bufferId) { + checkForBacklog(BufferIdList() << bufferId); +} + #endif // CLIENTBACKLOGMANAGER_H