X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=03027ca867e2a01a5ccf7393dfd14b93811eebe3;hp=78044db81f6734df004f38cd6c392244476a785b;hb=66c5feaf7c9f480f06dfb45df2cf54e44c8b487b;hpb=f824db0e31b54969e0b7fa0b5405b1e9173d482c diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index 78044db8..03027ca8 100644 --- a/src/core/corealiasmanager.cpp +++ b/src/core/corealiasmanager.cpp @@ -21,8 +21,10 @@ #include "corealiasmanager.h" #include "core.h" +#include "corenetwork.h" #include "coresession.h" +INIT_SYNCABLE_OBJECT(CoreAliasManager) CoreAliasManager::CoreAliasManager(CoreSession *parent) : AliasManager(parent) { @@ -33,14 +35,15 @@ CoreAliasManager::CoreAliasManager(CoreSession *parent) return; } - QVariantMap aliases = Core::getUserSetting(session->user(), "Aliases").toMap(); 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() { +void CoreAliasManager::save() const { CoreSession *session = qobject_cast(parent()); if(!session) { qWarning() << "CoreAliasManager: unable to save Aliases. Parent is not a Coresession!"; @@ -50,6 +53,9 @@ CoreAliasManager::~CoreAliasManager() { 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()) {