X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorebuffersyncer.h;fp=src%2Fcore%2Fcorebuffersyncer.h;h=c490419a95bd7363fd241cdb43dd4e817eb32b5e;hp=16155344564f6bc51432fef5a1f28091955b1c01;hb=fd16e241d2fd1f33f4625b3255956f025a67273b;hpb=502b47a608a55374bd28b6b698971f9f697e2d20 diff --git a/src/core/corebuffersyncer.h b/src/core/corebuffersyncer.h index 16155344..c490419a 100644 --- a/src/core/corebuffersyncer.h +++ b/src/core/corebuffersyncer.h @@ -40,6 +40,15 @@ public slots: virtual inline void requestRemoveBuffer(BufferId buffer) { removeBuffer(buffer); } virtual void removeBuffer(BufferId bufferId); + void addBufferActivity(Message message) { + auto oldActivity = activity(message.bufferId()); + if (!oldActivity.testFlag(message.type())) { + setBufferActivity(message.bufferId(), (int) (oldActivity | message.type())); + } + } + + void setBufferActivity(BufferId buffer, const int &activity) override; + virtual inline void requestRenameBuffer(BufferId buffer, QString newName) { renameBuffer(buffer, newName); } virtual void renameBuffer(BufferId buffer, QString newName); @@ -48,7 +57,10 @@ public slots: virtual void requestPurgeBufferIds(); - virtual inline void requestMarkBufferAsRead(BufferId buffer) { markBufferAsRead(buffer); } + virtual inline void requestMarkBufferAsRead(BufferId buffer) { + setLastSeenMsg(buffer, (int) Message::Types()); + markBufferAsRead(buffer); + } void storeDirtyIds(); @@ -61,6 +73,7 @@ private: QSet dirtyLastSeenBuffers; QSet dirtyMarkerLineBuffers; + QSet dirtyActivities; void purgeBufferIds(); };