X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=1e8d89f7267789428a7baba626f43f7e7d0dd550;hp=b1e7f2f2c0fa0d8c23a001dde4d6ddd61a91e796;hb=694f9bfbf7f1af19108461c7e00d133e55082bce;hpb=ab16c77fe03b73a863d9b52b11919bcbac903f58 diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index b1e7f2f2..1e8d89f7 100644 --- a/src/core/corealiasmanager.cpp +++ b/src/core/corealiasmanager.cpp @@ -24,37 +24,47 @@ #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; - } - - 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; - } - Core::setUserSetting(session->user(), "Aliases", initAliases()); +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()); } -const Network *CoreAliasManager::network(NetworkId id) const { - return qobject_cast(parent())->network(id); + +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); + } }