X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientbacklogmanager.cpp;h=b969251d43df8fa281ce2dde505242f044801277;hp=0a584aeb7f07994e622513c0db243ab0ceed76a3;hb=ec747d2e6065e645e2cd768abc84923ef6a19705;hpb=9d54503555534a2c554f09a33df6afa33d6308ec diff --git a/src/client/clientbacklogmanager.cpp b/src/client/clientbacklogmanager.cpp index 0a584aeb..b969251d 100644 --- a/src/client/clientbacklogmanager.cpp +++ b/src/client/clientbacklogmanager.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2014 by the Quassel Project * + * Copyright (C) 2005-2019 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -20,23 +20,19 @@ #include "clientbacklogmanager.h" -#include "abstractmessageprocessor.h" -#include "backlogsettings.h" -#include "backlogrequester.h" -#include "client.h" - +#include #include #include -INIT_SYNCABLE_OBJECT(ClientBacklogManager) -ClientBacklogManager::ClientBacklogManager(QObject *parent) - : BacklogManager(parent), - _requester(0), - _initBacklogRequested(false) -{ -} +#include "abstractmessageprocessor.h" +#include "backlogrequester.h" +#include "backlogsettings.h" +#include "client.h" +ClientBacklogManager::ClientBacklogManager(QObject* parent) + : BacklogManager(parent) +{} QVariantList ClientBacklogManager::requestBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional) { @@ -44,15 +40,17 @@ QVariantList ClientBacklogManager::requestBacklog(BufferId bufferId, MsgId first return BacklogManager::requestBacklog(bufferId, first, last, limit, additional); } - void ClientBacklogManager::receiveBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional, QVariantList msgs) { - Q_UNUSED(first) Q_UNUSED(last) Q_UNUSED(limit) Q_UNUSED(additional) + Q_UNUSED(first) + Q_UNUSED(last) + Q_UNUSED(limit) + Q_UNUSED(additional) emit messagesReceived(bufferId, msgs.count()); MessageList msglist; - foreach(QVariant v, msgs) { + foreach (QVariant v, msgs) { Message msg = v.value(); msg.setFlags(msg.flags() | Message::Backlog); msglist << msg; @@ -71,13 +69,15 @@ void ClientBacklogManager::receiveBacklog(BufferId bufferId, MsgId first, MsgId } } - void ClientBacklogManager::receiveBacklogAll(MsgId first, MsgId last, int limit, int additional, QVariantList msgs) { - Q_UNUSED(first) Q_UNUSED(last) Q_UNUSED(limit) Q_UNUSED(additional) + Q_UNUSED(first) + Q_UNUSED(last) + Q_UNUSED(limit) + Q_UNUSED(additional) MessageList msglist; - foreach(QVariant v, msgs) { + foreach (QVariant v, msgs) { Message msg = v.value(); msg.setFlags(msg.flags() | Message::Backlog); msglist << msg; @@ -86,7 +86,6 @@ void ClientBacklogManager::receiveBacklogAll(MsgId first, MsgId last, int limit, dispatchMessages(msglist); } - void ClientBacklogManager::requestInitialBacklog() { if (_initBacklogRequested) { @@ -115,12 +114,11 @@ void ClientBacklogManager::requestInitialBacklog() } } - -BufferIdList ClientBacklogManager::filterNewBufferIds(const BufferIdList &bufferIds) +BufferIdList ClientBacklogManager::filterNewBufferIds(const BufferIdList& bufferIds) { BufferIdList newBuffers; QSet availableBuffers = Client::networkModel()->allBufferIds().toSet(); - foreach(BufferId bufferId, bufferIds) { + foreach (BufferId bufferId, bufferIds) { if (_buffersRequested.contains(bufferId) || !availableBuffers.contains(bufferId)) continue; newBuffers << bufferId; @@ -128,8 +126,7 @@ BufferIdList ClientBacklogManager::filterNewBufferIds(const BufferIdList &buffer return newBuffers; } - -void ClientBacklogManager::checkForBacklog(const QList &bufferIds) +void ClientBacklogManager::checkForBacklog(const QList& bufferIds) { // we ingore all backlogrequests until we had our initial request if (!_initBacklogRequested) { @@ -146,8 +143,7 @@ void ClientBacklogManager::checkForBacklog(const QList &bufferIds) break; case BacklogRequester::PerBufferUnread: case BacklogRequester::PerBufferFixed: - default: - { + default: { BufferIdList buffers = filterNewBufferIds(bufferIds); if (!buffers.isEmpty()) _requester->requestBacklog(buffers); @@ -155,14 +151,12 @@ void ClientBacklogManager::checkForBacklog(const QList &bufferIds) }; } - bool ClientBacklogManager::isBuffering() { return _requester && _requester->isBuffering(); } - -void ClientBacklogManager::dispatchMessages(const MessageList &messages, bool sort) +void ClientBacklogManager::dispatchMessages(const MessageList& messages, bool sort) { if (messages.isEmpty()) return; @@ -171,18 +165,17 @@ void ClientBacklogManager::dispatchMessages(const MessageList &messages, bool so clock_t start_t = clock(); if (sort) - qSort(msgs); + std::sort(msgs.begin(), msgs.end()); Client::messageProcessor()->process(msgs); clock_t end_t = clock(); emit messagesProcessed(tr("Processed %1 messages in %2 seconds.").arg(messages.count()).arg((float)(end_t - start_t) / CLOCKS_PER_SEC)); } - void ClientBacklogManager::reset() { delete _requester; - _requester = 0; + _requester = nullptr; _initBacklogRequested = false; _buffersRequested.clear(); }