X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fbuffersyncer.cpp;h=222f65bc8eb84ee44b87c821d4a51587944f494e;hp=82fe0da04a9f78b2eee48ed3c20777e32a979dfa;hb=3eebe11329417e77038d860af3b6f35630f40450;hpb=f6b9eeda207d42c99fc3e9085631722cf2ec83dc diff --git a/src/common/buffersyncer.cpp b/src/common/buffersyncer.cpp index 82fe0da0..222f65bc 100644 --- a/src/common/buffersyncer.cpp +++ b/src/common/buffersyncer.cpp @@ -26,16 +26,15 @@ BufferSyncer::BufferSyncer(QObject *parent) { } -BufferSyncer::BufferSyncer(const QHash &lastSeenMsg, QObject *parent) +BufferSyncer::BufferSyncer(const QHash &lastSeenMsg, const QHash &markerLines, QObject *parent) : SyncableObject(parent), - _lastSeenMsg(lastSeenMsg) + _lastSeenMsg(lastSeenMsg), + _markerLines(markerLines) { } MsgId BufferSyncer::lastSeenMsg(BufferId buffer) const { - if(_lastSeenMsg.contains(buffer)) - return _lastSeenMsg[buffer]; - return MsgId(); + return _lastSeenMsg.value(buffer, MsgId()); } bool BufferSyncer::setLastSeenMsg(BufferId buffer, const MsgId &msgId) { @@ -52,13 +51,30 @@ bool BufferSyncer::setLastSeenMsg(BufferId buffer, const MsgId &msgId) { return false; } +MsgId BufferSyncer::markerLine(BufferId buffer) const { + return _markerLines.value(buffer, MsgId()); +} + +bool BufferSyncer::setMarkerLine(BufferId buffer, const MsgId &msgId) { + if(!msgId.isValid()) + return false; + + if(_markerLines.value(buffer) == msgId) + return false; + + _markerLines[buffer] = msgId; + SYNC(ARG(buffer), ARG(msgId)) + emit markerLineSet(buffer, msgId); + return true; +} + QVariantList BufferSyncer::initLastSeenMsg() const { QVariantList list; QHash::const_iterator iter = _lastSeenMsg.constBegin(); while(iter != _lastSeenMsg.constEnd()) { list << QVariant::fromValue(iter.key()) - << QVariant::fromValue(iter.value()); - iter++; + << QVariant::fromValue(iter.value()); + ++iter; } return list; } @@ -67,13 +83,34 @@ void BufferSyncer::initSetLastSeenMsg(const QVariantList &list) { _lastSeenMsg.clear(); Q_ASSERT(list.count() % 2 == 0); for(int i = 0; i < list.count(); i += 2) { - setLastSeenMsg(list[i].value(), list[i+1].value()); + setLastSeenMsg(list.at(i).value(), list.at(i+1).value()); + } +} + +QVariantList BufferSyncer::initMarkerLines() const { + QVariantList list; + QHash::const_iterator iter = _markerLines.constBegin(); + while(iter != _markerLines.constEnd()) { + list << QVariant::fromValue(iter.key()) + << QVariant::fromValue(iter.value()); + ++iter; + } + return list; +} + +void BufferSyncer::initSetMarkerLines(const QVariantList &list) { + _markerLines.clear(); + Q_ASSERT(list.count() % 2 == 0); + for(int i = 0; i < list.count(); i += 2) { + setMarkerLine(list.at(i).value(), list.at(i+1).value()); } } void BufferSyncer::removeBuffer(BufferId buffer) { if(_lastSeenMsg.contains(buffer)) _lastSeenMsg.remove(buffer); + if(_markerLines.contains(buffer)) + _markerLines.remove(buffer); SYNC(ARG(buffer)) emit bufferRemoved(buffer); } @@ -81,6 +118,8 @@ void BufferSyncer::removeBuffer(BufferId buffer) { void BufferSyncer::mergeBuffersPermanently(BufferId buffer1, BufferId buffer2) { if(_lastSeenMsg.contains(buffer2)) _lastSeenMsg.remove(buffer2); + if(_markerLines.contains(buffer2)) + _markerLines.remove(buffer2); SYNC(ARG(buffer1), ARG(buffer2)) emit buffersPermanentlyMerged(buffer1, buffer2); }