X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=1e8d89f7267789428a7baba626f43f7e7d0dd550;hp=78044db81f6734df004f38cd6c392244476a785b;hb=694f9bfbf7f1af19108461c7e00d133e55082bce;hpb=f824db0e31b54969e0b7fa0b5405b1e9173d482c diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index 78044db8..1e8d89f7 100644 --- a/src/core/corealiasmanager.cpp +++ b/src/core/corealiasmanager.cpp @@ -21,38 +21,50 @@ #include "corealiasmanager.h" #include "core.h" +#include "corenetwork.h" #include "coresession.h" +INIT_SYNCABLE_OBJECT(CoreAliasManager) CoreAliasManager::CoreAliasManager(CoreSession *parent) - : AliasManager(parent) + : AliasManager(parent) { - CoreSession *session = qobject_cast(parent); - if(!session) { - qWarning() << "CoreAliasManager: unable to load Aliases. Parent is not a Coresession!"; - loadDefaults(); - return; - } - - QVariantMap aliases = Core::getUserSetting(session->user(), "Aliases").toMap(); - initSetAliases(Core::getUserSetting(session->user(), "Aliases").toMap()); - if(isEmpty()) - loadDefaults(); + CoreSession *session = qobject_cast(parent); + if (!session) { + qWarning() << "CoreAliasManager: unable to load Aliases. Parent is not a Coresession!"; + loadDefaults(); + return; + } + + initSetAliases(Core::getUserSetting(session->user(), "Aliases").toMap()); + if (isEmpty()) + loadDefaults(); + + // we store our settings whenever they change + connect(this, SIGNAL(updatedRemotely()), SLOT(save())); } -CoreAliasManager::~CoreAliasManager() { - CoreSession *session = qobject_cast(parent()); - if(!session) { - qWarning() << "CoreAliasManager: unable to save Aliases. Parent is not a Coresession!"; - return; - } +void CoreAliasManager::save() const +{ + CoreSession *session = qobject_cast(parent()); + if (!session) { + qWarning() << "CoreAliasManager: unable to save Aliases. Parent is not a Coresession!"; + return; + } + + Core::setUserSetting(session->user(), "Aliases", initAliases()); +} + - Core::setUserSetting(session->user(), "Aliases", initAliases()); +const Network *CoreAliasManager::network(NetworkId id) const +{ + return qobject_cast(parent())->network(id); } -void CoreAliasManager::loadDefaults() { - foreach(Alias alias, AliasManager::defaults()) { - addAlias(alias.name, alias.expansion); - } +void CoreAliasManager::loadDefaults() +{ + foreach(Alias alias, AliasManager::defaults()) { + addAlias(alias.name, alias.expansion); + } }