X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorebuffersyncer.h;h=05ddd6adb9b3b4219d3f0414c3dd2ea5d98126d2;hp=6b85b12b23b4021f92b9c8d0ec68b82788e82f5c;hb=695758015a80eb8c158a9ac4c0f1c0b547e70df3;hpb=f824db0e31b54969e0b7fa0b5405b1e9173d482c diff --git a/src/core/corebuffersyncer.h b/src/core/corebuffersyncer.h index 6b85b12b..05ddd6ad 100644 --- a/src/core/corebuffersyncer.h +++ b/src/core/corebuffersyncer.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-09 by the Quassel Project * + * Copyright (C) 2005-2015 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,7 +15,7 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #ifndef COREBUFFERSYNCER_H @@ -25,30 +25,45 @@ 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 dirtyBuffers; + QSet dirtyLastSeenBuffers; + QSet dirtyMarkerLineBuffers; + + void purgeBufferIds(); }; + #endif //COREBUFFERSYNCER_H