X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcorealiasmanager.cpp;h=dc6f037ce0d00fa7b7d12f444546c43675286973;hp=b89435623d4ab41b71b8be04c075789f379f2a12;hb=e8a39b4c3c92e193ab861a3fea84a261bb6fbd24;hpb=eb8ee27deb8346dbf9e8515b0cceefd58cda971b diff --git a/src/core/corealiasmanager.cpp b/src/core/corealiasmanager.cpp index b8943562..dc6f037c 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-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,53 +15,55 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include "corealiasmanager.h" #include "core.h" +#include "corenetwork.h" #include "coresession.h" 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; - } + CoreSession *session = qobject_cast(parent); + if (!session) { + qWarning() << "CoreAliasManager: unable to load Aliases. Parent is not a Coresession!"; + loadDefaults(); + return; + } - QVariantMap aliases = Core::getUserSetting(session->user(), "Aliases").toMap(); - if(aliases.isEmpty()) { - loadDefaults(); - } else { - initSetAliases(aliases); - } + 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; - } +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()); + 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); + } }