X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=03027ca867e2a01a5ccf7393dfd14b93811eebe3;hp=9576c04b7cccc57f7599a3df196ec196467759ff;hb=66c5feaf7c9f480f06dfb45df2cf54e44c8b487b;hpb=8179670f13fbbdd5cbcd7fb4a3dc187913ee9ba3 diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index 9576c04b..03027ca8 100644 --- a/src/core/corealiasmanager.cpp +++ b/src/core/corealiasmanager.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -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()) {