X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=03027ca867e2a01a5ccf7393dfd14b93811eebe3;hp=b89435623d4ab41b71b8be04c075789f379f2a12;hb=bf10e3ead6e50f90c6bb34074e39b938f9d35bc3;hpb=eb8ee27deb8346dbf9e8515b0cceefd58cda971b diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index b8943562..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,16 +53,12 @@ CoreAliasManager::~CoreAliasManager() { Core::setUserSetting(session->user(), "Aliases", initAliases()); } -void CoreAliasManager::loadDefaults() { - // Default Aliases: - addAlias("j", "/join $0"); - - addAlias("ns", "/msg nickserv $0"); - addAlias("nickserv", "/msg nickserv $0"); - addAlias("cs", "/msg chanserv $0"); - addAlias("chanserv", "/msg chanserv $0"); - addAlias("hs", "/msg hostserv $0"); - addAlias("hostserv", "/msg hostserv $0"); +const Network *CoreAliasManager::network(NetworkId id) const { + return qobject_cast(parent())->network(id); +} - addAlias("back", "/quote away"); +void CoreAliasManager::loadDefaults() { + foreach(Alias alias, AliasManager::defaults()) { + addAlias(alias.name, alias.expansion); + } }