Reformat ALL the source!
[quassel.git] / src / core / corebuffersyncer.h
index 0c3a8c0..1160a5f 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-08 by the Quassel Project                          *
+ *   Copyright (C) 2005-09 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 
 class CoreSession;
 
-class CoreBufferSyncer : public BufferSyncer {
-  Q_OBJECT
+class CoreBufferSyncer : public BufferSyncer
+{
+    SYNCABLE_OBJECT
+        Q_OBJECT
 
 public:
-  CoreBufferSyncer(CoreSession *parent);
+    CoreBufferSyncer(CoreSession *parent);
 
 public slots:
-  virtual void requestSetLastSeenMsg(BufferId buffer, const MsgId &msgId);
+    virtual void requestSetLastSeenMsg(BufferId buffer, const MsgId &msgId);
+    virtual void requestSetMarkerLine(BufferId buffer, const MsgId &msgId);
 
-  virtual inline void requestRemoveBuffer(BufferId buffer) { removeBuffer(buffer); }
-  virtual void removeBuffer(BufferId bufferId);
+    virtual inline void requestRemoveBuffer(BufferId buffer) { removeBuffer(buffer); }
+    virtual void removeBuffer(BufferId bufferId);
 
-  virtual inline void requestRenameBuffer(BufferId buffer, QString newName) { renameBuffer(buffer, newName); }
-  virtual void renameBuffer(BufferId buffer, QString newName);
+    virtual inline void requestRenameBuffer(BufferId buffer, QString newName) { renameBuffer(buffer, newName); }
+    virtual void renameBuffer(BufferId buffer, QString newName);
 
-  virtual inline void requestMergeBuffersPermanently(BufferId buffer1, BufferId buffer2) { mergeBuffersPermanently(buffer1, buffer2); }
-  virtual void mergeBuffersPermanently(BufferId buffer1, BufferId buffer2);
+    virtual inline void requestMergeBuffersPermanently(BufferId buffer1, BufferId buffer2) { mergeBuffersPermanently(buffer1, buffer2); }
+    virtual void mergeBuffersPermanently(BufferId buffer1, BufferId buffer2);
 
-  void storeDirtyIds();
+    virtual void requestPurgeBufferIds();
+
+    virtual inline void requestMarkBufferAsRead(BufferId buffer) { markBufferAsRead(buffer); }
+
+    void storeDirtyIds();
+
+protected:
+    virtual void customEvent(QEvent *event);
 
 private:
-  CoreSession *_coreSession;
+    CoreSession *_coreSession;
+    bool _purgeBuffers;
 
-  QSet<BufferId> dirtyBuffers;
+    QSet<BufferId> dirtyLastSeenBuffers;
+    QSet<BufferId> dirtyMarkerLineBuffers;
+
+    void purgeBufferIds();
 };
 
+
 #endif //COREBUFFERSYNCER_H