X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Fbufferviewmanager.cpp;h=2287dda19519c4f8beb957be5db5850902cfb0b8;hb=f9cd845a9119e0abf450a91d8802f5c1822dd638;hp=580b4ad2c627215cc0fd9f648bf7289b25847ffa;hpb=b50541ba6d7c58322846cc2eb9f023a117d8c47d;p=quassel.git diff --git a/src/common/bufferviewmanager.cpp b/src/common/bufferviewmanager.cpp index 580b4ad2..2287dda1 100644 --- a/src/common/bufferviewmanager.cpp +++ b/src/common/bufferviewmanager.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2015 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -23,7 +23,6 @@ #include "bufferviewconfig.h" #include "signalproxy.h" -INIT_SYNCABLE_OBJECT(BufferViewManager) BufferViewManager::BufferViewManager(SignalProxy *proxy, QObject *parent) : SyncableObject(parent), _proxy(proxy) @@ -37,7 +36,7 @@ BufferViewConfig *BufferViewManager::bufferViewConfig(int bufferViewId) const if (_bufferViewConfigs.contains(bufferViewId)) return _bufferViewConfigs[bufferViewId]; else - return 0; + return nullptr; } @@ -47,25 +46,28 @@ BufferViewConfig *BufferViewManager::bufferViewConfigFactory(int bufferViewConfi } -void BufferViewManager::addBufferViewConfig(BufferViewConfig *config) +void BufferViewManager::addBufferViewConfig(int bufferViewConfigId) { - if (_bufferViewConfigs.contains(config->bufferViewId())) + if (_bufferViewConfigs.contains(bufferViewConfigId)) { return; + } - _proxy->synchronize(config); - _bufferViewConfigs[config->bufferViewId()] = config; - int bufferViewId = config->bufferViewId(); - SYNC_OTHER(addBufferViewConfig, ARG(bufferViewId)) - emit bufferViewConfigAdded(bufferViewId); + addBufferViewConfig(bufferViewConfigFactory(bufferViewConfigId)); } -void BufferViewManager::addBufferViewConfig(int bufferViewConfigId) +void BufferViewManager::addBufferViewConfig(BufferViewConfig *config) { - if (_bufferViewConfigs.contains(bufferViewConfigId)) + if (_bufferViewConfigs.contains(config->bufferViewId())) { + delete config; return; + } - addBufferViewConfig(bufferViewConfigFactory(bufferViewConfigId)); + _proxy->synchronize(config); + _bufferViewConfigs[config->bufferViewId()] = config; + int bufferViewId = config->bufferViewId(); + SYNC_OTHER(addBufferViewConfig, ARG(bufferViewId)) + emit bufferViewConfigAdded(bufferViewId); } @@ -96,10 +98,7 @@ QVariantList BufferViewManager::initBufferViewIds() const void BufferViewManager::initSetBufferViewIds(const QVariantList bufferViewIds) { - QVariantList::const_iterator iter = bufferViewIds.constBegin(); - QVariantList::const_iterator iterEnd = bufferViewIds.constEnd(); - while (iter != iterEnd) { - newBufferViewConfig((*iter).value()); - ++iter; + for (auto &&id : bufferViewIds) { + addBufferViewConfig(id.value()); } }