Enable plain old QTimer-based asynchronous message processing. More fancy stuff will...
authorManuel Nickschas <sputnick@quassel-irc.org>
Wed, 6 Aug 2008 20:51:26 +0000 (22:51 +0200)
committerManuel Nickschas <sputnick@quassel-irc.org>
Wed, 6 Aug 2008 20:51:26 +0000 (22:51 +0200)
src/client/abstractmessageprocessor.cpp
src/client/abstractmessageprocessor.h
src/qtui/qtuimessageprocessor.cpp
src/qtui/qtuimessageprocessor.h

index 5ba8683..0f692af 100644 (file)
@@ -28,14 +28,6 @@ AbstractMessageProcessor::AbstractMessageProcessor(QObject *parent) : QObject(pa
 
 }
 
 
 }
 
-void AbstractMessageProcessor::process(Message &msg) {
-  processMessage(msg);
+void AbstractMessageProcessor::postProcess(Message &msg) {
   Client::buffer(msg.bufferInfo())->updateActivityLevel(msg);
 }
   Client::buffer(msg.bufferInfo())->updateActivityLevel(msg);
 }
-
-void AbstractMessageProcessor::process(QList<Message> &msgs) {
-  processMessages(msgs);
-  foreach(Message msg, msgs) {
-    Client::buffer(msg.bufferInfo())->updateActivityLevel(msg);
-  }
-}
index b140ac1..f02728c 100644 (file)
@@ -30,14 +30,13 @@ class AbstractMessageProcessor : public QObject {
     AbstractMessageProcessor(QObject *parent);
 
   public slots:
     AbstractMessageProcessor(QObject *parent);
 
   public slots:
-    void process(Message &msg);
-    void process(QList<Message> &msgs);
+    virtual void process(Message &msg) = 0;
+    virtual void process(QList<Message> &msgs) = 0;
 
   signals:
 
   protected:
 
   signals:
 
   protected:
-    virtual void processMessage(Message &msg) = 0;
-    virtual void processMessages(QList<Message> &msgs) = 0;
+    void postProcess(Message &msg);
 
 };
 
 
 };
 
index 54ee570..203397d 100644 (file)
 #include "network.h"
 
 QtUiMessageProcessor::QtUiMessageProcessor(QObject *parent) : AbstractMessageProcessor(parent) {
 #include "network.h"
 
 QtUiMessageProcessor::QtUiMessageProcessor(QObject *parent) : AbstractMessageProcessor(parent) {
-
-
+  _processing = false;
+  _processMode = TimerBased;
+  _processTimer.setInterval(0);
+  connect(&_processTimer, SIGNAL(timeout()), this, SLOT(processNextMessage()));
 }
 
 }
 
-void QtUiMessageProcessor::processMessage(Message &msg) {
+void QtUiMessageProcessor::process(Message &msg) {
   checkForHighlight(msg);
   Client::messageModel()->insertMessage(msg);
   checkForHighlight(msg);
   Client::messageModel()->insertMessage(msg);
+  postProcess(msg);
+}
+
+void QtUiMessageProcessor::process(QList<Message> &msgs) {
+  _processQueue.append(msgs);
+  if(!isProcessing()) startProcessing();
 }
 
 }
 
-void QtUiMessageProcessor::processMessages(QList<Message> &msgs) {
-  foreach(Message msg, msgs) {
-    checkForHighlight(msg);
-    Client::messageModel()->insertMessage(msg);
+void QtUiMessageProcessor::startProcessing() {
+  if(processMode() == TimerBased) {
+    if(_currentBatch.isEmpty() && _processQueue.isEmpty()) return;
+    _processing = true;
+    if(!_processTimer.isActive()) _processTimer.start();
+  }
+}
+
+void QtUiMessageProcessor::processNextMessage() {
+  if(_currentBatch.isEmpty()) {
+    if(_processQueue.isEmpty()) {
+      _processTimer.stop();
+      _processing = false;
+      return;
+    }
+    _currentBatch = _processQueue.takeFirst();
   }
   }
+  Message msg = _currentBatch.takeFirst();
+  process(msg);
 }
 
 // TODO optimize checkForHighlight
 }
 
 // TODO optimize checkForHighlight
index 161385b..cfbc139 100644 (file)
 #ifndef QTUIMESSAGEPROCESSOR_H_
 #define QTUIMESSAGEPROCESSOR_H_
 
 #ifndef QTUIMESSAGEPROCESSOR_H_
 #define QTUIMESSAGEPROCESSOR_H_
 
+#include <QTimer>
+
 #include "abstractmessageprocessor.h"
 
 class QtUiMessageProcessor : public AbstractMessageProcessor {
   Q_OBJECT
 
   public:
 #include "abstractmessageprocessor.h"
 
 class QtUiMessageProcessor : public AbstractMessageProcessor {
   Q_OBJECT
 
   public:
+    enum Mode {
+      TimerBased,
+      Concurrent
+    };
+
     QtUiMessageProcessor(QObject *parent);
     QtUiMessageProcessor(QObject *parent);
+    inline bool isProcessing() const { return _processing; }
+    inline Mode processMode() const { return _processMode; }
 
 
+  public slots:
+    void process(Message &msg);
+    void process(QList<Message> &msgs);
 
 
-  private:
-    void processMessage(Message &msg);
-    void processMessages(QList<Message> &msgs);
+  private slots:
+    void processNextMessage();
 
 
+  private:
     void checkForHighlight(Message &msg);
     void checkForHighlight(Message &msg);
+    void startProcessing();
 
 
+    QList<QList<Message> > _processQueue;
+    QList<Message> _currentBatch;
+    QTimer _processTimer;
+    bool _processing;
+    Mode _processMode;
 };
 
 #endif
 };
 
 #endif