X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fcorebuffersyncer.h;h=1cf66fd47af42df3f9a242f187b641877b584b04;hb=12028f7dfb31ebf5694f5dae95bfc31bcde83b43;hp=bea39cf2daffd5486c1cb8e9db72bcb718658d60;hpb=5b686746c880e5cda6d5de3e08180ea4332ff222;p=quassel.git diff --git a/src/core/corebuffersyncer.h b/src/core/corebuffersyncer.h index bea39cf2..1cf66fd4 100644 --- a/src/core/corebuffersyncer.h +++ b/src/core/corebuffersyncer.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2012 by the Quassel Project * + * Copyright (C) 2005-2016 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -31,29 +31,42 @@ class CoreBufferSyncer : public BufferSyncer Q_OBJECT public: - CoreBufferSyncer(CoreSession *parent); + explicit CoreBufferSyncer(CoreSession *parent); public slots: - virtual void requestSetLastSeenMsg(BufferId buffer, const MsgId &msgId); - virtual void requestSetMarkerLine(BufferId buffer, const MsgId &msgId); + void requestSetLastSeenMsg(BufferId buffer, const MsgId &msgId) override; + void requestSetMarkerLine(BufferId buffer, const MsgId &msgId) override; - virtual inline void requestRemoveBuffer(BufferId buffer) { removeBuffer(buffer); } - virtual void removeBuffer(BufferId bufferId); + inline void requestRemoveBuffer(BufferId buffer) override { removeBuffer(buffer); } + void removeBuffer(BufferId bufferId) override; - virtual inline void requestRenameBuffer(BufferId buffer, QString newName) { renameBuffer(buffer, newName); } - virtual void renameBuffer(BufferId buffer, QString newName); + void addBufferActivity(const Message &message) { + auto oldActivity = activity(message.bufferId()); + if (!oldActivity.testFlag(message.type())) { + setBufferActivity(message.bufferId(), (int) (oldActivity | message.type())); + } + } - virtual inline void requestMergeBuffersPermanently(BufferId buffer1, BufferId buffer2) { mergeBuffersPermanently(buffer1, buffer2); } - virtual void mergeBuffersPermanently(BufferId buffer1, BufferId buffer2); + void setBufferActivity(BufferId buffer, int activity) override; - virtual void requestPurgeBufferIds(); + inline void requestRenameBuffer(BufferId buffer, QString newName) override { renameBuffer(buffer, newName); } + void renameBuffer(BufferId buffer, QString newName) override; - virtual inline void requestMarkBufferAsRead(BufferId buffer) { markBufferAsRead(buffer); } + inline void requestMergeBuffersPermanently(BufferId buffer1, BufferId buffer2) override { mergeBuffersPermanently(buffer1, buffer2); } + void mergeBuffersPermanently(BufferId buffer1, BufferId buffer2) override; + + void requestPurgeBufferIds() override; + + inline void requestMarkBufferAsRead(BufferId buffer) override { + int activity = Message::Types(); + setBufferActivity(buffer, activity); + markBufferAsRead(buffer); + } void storeDirtyIds(); protected: - virtual void customEvent(QEvent *event); + void customEvent(QEvent *event) override; private: CoreSession *_coreSession; @@ -61,6 +74,7 @@ private: QSet dirtyLastSeenBuffers; QSet dirtyMarkerLineBuffers; + QSet dirtyActivities; void purgeBufferIds(); };