X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=03027ca867e2a01a5ccf7393dfd14b93811eebe3;hp=8fcdb022148114049dac6b9ff3f5cf1b9f375405;hb=66c5feaf7c9f480f06dfb45df2cf54e44c8b487b;hpb=6579cd49c867ce3fb6c99127851a881ea82d1b1b diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index 8fcdb022..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,16 +35,15 @@ CoreAliasManager::CoreAliasManager(CoreSession *parent) return; } - QVariantMap aliases = Core::getUserSetting(session->user(), "Aliases").toMap(); - if(aliases.isEmpty()) { + initSetAliases(Core::getUserSetting(session->user(), "Aliases").toMap()); + if(isEmpty()) loadDefaults(); - } else { - initSetAliases(aliases); - } -} + // 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!"; @@ -52,7 +53,12 @@ CoreAliasManager::~CoreAliasManager() { Core::setUserSetting(session->user(), "Aliases", initAliases()); } +const Network *CoreAliasManager::network(NetworkId id) const { + return qobject_cast(parent())->network(id); +} + void CoreAliasManager::loadDefaults() { - // Default Aliases: - addAlias("j", "/join $1"); + foreach(Alias alias, AliasManager::defaults()) { + addAlias(alias.name, alias.expansion); + } }