X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientbacklogmanager.h;h=605149798fd6a65b513b04e66ed1558df2ad9780;hp=d9171cfec284df704399dca5f8c645d159c89075;hb=26b9300ccab24e526a9f43bef95a2a70f59161df;hpb=332069a1830ed3a055ac6f2d7661bae1cc83e40c diff --git a/src/client/clientbacklogmanager.h b/src/client/clientbacklogmanager.h index d9171cfe..60514979 100644 --- a/src/client/clientbacklogmanager.h +++ b/src/client/clientbacklogmanager.h @@ -22,6 +22,9 @@ #define CLIENTBACKLOGMANAGER_H #include "backlogmanager.h" +#include "message.h" + +class BacklogRequester; class ClientBacklogManager : public BacklogManager { Q_OBJECT @@ -31,9 +34,27 @@ public: 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, int limit, int offset, QVariantList msgs); void requestInitialBacklog(); + +signals: + void messagesReceived(BufferId bufferId, int count) const; + void messagesRequested(const QString &) const; + void messagesProcessed(const QString &) const; + +private: + bool isBuffering(); + void stopBuffering(); + + void dispatchMessages(const MessageList &messages, bool sort = false); + + BacklogRequester *_requester; }; #endif // CLIENTBACKLOGMANAGER_H