X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorebuffersyncer.h;h=cb58b0ac8ae6b5d61cd2b36b92096643d7d79939;hp=0c3a8c04cdd070f818256f8149834cfb534b1e4c;hb=7582ce11d6fb8b5123f7ac4794c57e981a634e93;hpb=3c2914faeb01f3bc32e29f40179ae88040fbcf59 diff --git a/src/core/corebuffersyncer.h b/src/core/corebuffersyncer.h index 0c3a8c04..cb58b0ac 100644 --- a/src/core/corebuffersyncer.h +++ b/src/core/corebuffersyncer.h @@ -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 * @@ -26,6 +26,7 @@ class CoreSession; class CoreBufferSyncer : public BufferSyncer { + SYNCABLE_OBJECT Q_OBJECT public: @@ -33,6 +34,7 @@ public: public slots: 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); @@ -43,12 +45,23 @@ public slots: virtual inline void requestMergeBuffersPermanently(BufferId buffer1, BufferId buffer2) { mergeBuffersPermanently(buffer1, buffer2); } virtual void mergeBuffersPermanently(BufferId buffer1, BufferId buffer2); + virtual void requestPurgeBufferIds(); + + virtual inline void requestMarkBufferAsRead(BufferId buffer) { markBufferAsRead(buffer); } + void storeDirtyIds(); +protected: + virtual void customEvent(QEvent *event); + private: CoreSession *_coreSession; + bool _purgeBuffers; + + QSet dirtyLastSeenBuffers; + QSet dirtyMarkerLineBuffers; - QSet dirtyBuffers; + void purgeBufferIds(); }; #endif //COREBUFFERSYNCER_H