X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorebuffersyncer.h;h=3fba1c75d4364106380820a64f63d5699e536af9;hp=6aeaa6d3c9d0cd6b8df8f8111e2d40c186729613;hb=3e63cb8a6e83765069a45101b86ae9e21dcc57ad;hpb=68878dc8366f2f4a0afe132847aad9a51a80cdbf diff --git a/src/core/corebuffersyncer.h b/src/core/corebuffersyncer.h index 6aeaa6d3..3fba1c75 100644 --- a/src/core/corebuffersyncer.h +++ b/src/core/corebuffersyncer.h @@ -18,8 +18,7 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef COREBUFFERSYNCER_H -#define COREBUFFERSYNCER_H +#pragma once #include "buffersyncer.h" @@ -27,8 +26,7 @@ class CoreSession; class CoreBufferSyncer : public BufferSyncer { - SYNCABLE_OBJECT - Q_OBJECT + Q_OBJECT public: explicit CoreBufferSyncer(CoreSession *parent); @@ -47,8 +45,17 @@ public slots: } } + void addCoreHighlight(const Message &message) { + auto oldHighlightCount = highlightCount(message.bufferId()); + if (message.flags().testFlag(Message::Flag::Highlight) && !message.flags().testFlag(Message::Flag::Self)) { + setHighlightCount(message.bufferId(), oldHighlightCount + 1); + } + } + void setBufferActivity(BufferId buffer, int activity) override; + void setHighlightCount(BufferId buffer, int highlightCount) override; + inline void requestRenameBuffer(BufferId buffer, QString newName) override { renameBuffer(buffer, newName); } void renameBuffer(BufferId buffer, QString newName) override; @@ -60,6 +67,7 @@ public slots: inline void requestMarkBufferAsRead(BufferId buffer) override { int activity = Message::Types(); setBufferActivity(buffer, activity); + setHighlightCount(buffer, 0); markBufferAsRead(buffer); } @@ -75,9 +83,7 @@ private: QSet dirtyLastSeenBuffers; QSet dirtyMarkerLineBuffers; QSet dirtyActivities; + QSet dirtyHighlights; void purgeBufferIds(); }; - - -#endif //COREBUFFERSYNCER_H