X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientbacklogmanager.cpp;h=35403c0ed3d0d51ef4291b7658801dce30e86e5b;hp=07e23f1ceac66cea9e8b9eb9ee07255da168db81;hb=52209badc8e769e50aa3019b63689dda0e79e9d0;hpb=0a43227b8cd44625f4881cc1545d42c8c8a4876c diff --git a/src/client/clientbacklogmanager.cpp b/src/client/clientbacklogmanager.cpp index 07e23f1c..35403c0e 100644 --- a/src/client/clientbacklogmanager.cpp +++ b/src/client/clientbacklogmanager.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2016 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,20 @@ #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" +#include "util.h" +ClientBacklogManager::ClientBacklogManager(QObject* parent) + : BacklogManager(parent) +{} QVariantList ClientBacklogManager::requestBacklog(BufferId bufferId, MsgId first, MsgId last, int limit, int additional) { @@ -44,15 +41,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 +70,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 +87,6 @@ void ClientBacklogManager::receiveBacklogAll(MsgId first, MsgId last, int limit, dispatchMessages(msglist); } - void ClientBacklogManager::requestInitialBacklog() { if (_initBacklogRequested) { @@ -115,12 +115,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) { + QSet availableBuffers = toQSet(Client::networkModel()->allBufferIds()); + foreach (BufferId bufferId, bufferIds) { if (_buffersRequested.contains(bufferId) || !availableBuffers.contains(bufferId)) continue; newBuffers << bufferId; @@ -128,8 +127,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 +144,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 +152,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 +166,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(); }