X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fbufferviewmanager.cpp;h=41cdd463826fed6f4afbe95b5c8b6d27abf31bfd;hp=64af01e23219792f9cf8a8d01eccd1085e36ae71;hb=7fef34357cbd749e119dc3c47dda0ba63d068a03;hpb=68878dc8366f2f4a0afe132847aad9a51a80cdbf diff --git a/src/common/bufferviewmanager.cpp b/src/common/bufferviewmanager.cpp index 64af01e2..41cdd463 100644 --- a/src/common/bufferviewmanager.cpp +++ b/src/common/bufferviewmanager.cpp @@ -47,25 +47,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 +99,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()); } }