X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fclientbacklogmanager.h;h=400edcbab7c578b5e9d0c1be63158ae9a80b869a;hb=0480c16e33acc3cc6b1f1b507aa8696a70627bf8;hp=2f0fcf360d38a9bbfbccc1986d7e10dab66e57fc;hpb=ea372dac8dda146255c7232922904e9f90a0d7f9;p=quassel.git diff --git a/src/client/clientbacklogmanager.h b/src/client/clientbacklogmanager.h index 2f0fcf36..400edcba 100644 --- a/src/client/clientbacklogmanager.h +++ b/src/client/clientbacklogmanager.h @@ -24,6 +24,8 @@ #include "backlogmanager.h" #include "message.h" +class BacklogRequester; + class ClientBacklogManager : public BacklogManager { Q_OBJECT @@ -32,15 +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 QVariantList requestBacklog(BufferId bufferId, int lastMsgs = -1, int offset = -1); void requestInitialBacklog(); +signals: + void messagesReceived(BufferId bufferId, int count) const; + void messagesRequested(const QString &) const; + void messagesProcessed(const QString &) const; + private: - bool _buffer; - QList _messageBuffer; - QSet _buffersWaiting; + bool isBuffering(); + void stopBuffering(); + + void dispatchMessages(const MessageList &messages, bool sort = false); + + BacklogRequester *_requester; }; #endif // CLIENTBACKLOGMANAGER_H