X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientsettings.cpp;h=f35420d0b61d717544ce8bffc4e2ccc32f737f24;hp=83dd812888085311bcaf639053f2fb5356b021ea;hb=cd0868fff76dd067470881134fd736e1a1d97e71;hpb=d6b056e936ec441258d291b7a8af7b83f9f53016 diff --git a/src/client/clientsettings.cpp b/src/client/clientsettings.cpp index 83dd8128..f35420d0 100644 --- a/src/client/clientsettings.cpp +++ b/src/client/clientsettings.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-07 by the Quassel IRC Team * + * Copyright (C) 2005-08 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -20,68 +20,88 @@ #include "client.h" #include "clientsettings.h" +#include "global.h" #include -ClientSettings::ClientSettings(QString g) : Settings(g) { - - +ClientSettings::ClientSettings(QString g) : Settings(g, Global::clientApplicationName) { } ClientSettings::~ClientSettings() { +} +/***********************************************************************************************/ +CoreAccountSettings::CoreAccountSettings(const QString &subgroup) : ClientSettings("CoreAccounts") { + _subgroup = subgroup; } -QStringList ClientSettings::sessionKeys() { - return Client::sessionDataKeys(); +QList CoreAccountSettings::knownAccounts() { + QList ids; + foreach(QString key, localChildGroups()) { + ids << key.toInt(); + } + return ids; } -void ClientSettings::setSessionValue(const QString &key, const QVariant &data) { - Client::storeSessionData(key, data); +AccountId CoreAccountSettings::lastAccount() { + return localValue("LastAccount", 0).toInt(); } -QVariant ClientSettings::sessionValue(const QString &key, const QVariant &def) { - return Client::retrieveSessionData(key, def); +void CoreAccountSettings::setLastAccount(AccountId account) { + setLocalValue("LastAccount", account.toInt()); } -/***********************************************************************************************/ - -AccountSettings::AccountSettings() : ClientSettings("Accounts") { - - +AccountId CoreAccountSettings::autoConnectAccount() { + return localValue("AutoConnectAccount", 0).toInt(); } -QStringList AccountSettings::knownAccounts() { - return localChildGroups(); +void CoreAccountSettings::setAutoConnectAccount(AccountId account) { + setLocalValue("AutoConnectAccount", account.toInt()); } -QString AccountSettings::lastAccount() { - return localValue("LastAccount", "").toString(); +void CoreAccountSettings::storeAccountData(AccountId id, const QVariantMap &data) { + setLocalValue(QString("%1/Connection").arg(id.toInt()), data); } -void AccountSettings::setLastAccount(const QString &account) { - setLocalValue("LastAccount", account); +QVariantMap CoreAccountSettings::retrieveAccountData(AccountId id) { + return localValue(QString("%1/Connection").arg(id.toInt()), QVariant()).toMap(); } -QString AccountSettings::autoConnectAccount() { - return localValue("AutoConnectAccount", "").toString(); +void CoreAccountSettings::setAccountValue(const QString &key, const QVariant &value) { + if(!Client::currentCoreAccount().isValid()) return; + setLocalValue(QString("%1/%2/%3").arg(Client::currentCoreAccount().toInt()).arg(_subgroup).arg(key), value); } -void AccountSettings::setAutoConnectAccount(const QString &account) { - setLocalValue("AutoConnectAccount", account); +QVariant CoreAccountSettings::accountValue(const QString &key, const QVariant &def) { + if(!Client::currentCoreAccount().isValid()) return QVariant(); + return localValue(QString("%1/%2/%3").arg(Client::currentCoreAccount().toInt()).arg(_subgroup).arg(key), def); } -void AccountSettings::setValue(const QString &account, const QString &key, const QVariant &data) { - setLocalValue(QString("%1/%2").arg(account).arg(key), data); +void CoreAccountSettings::setJumpKeyMap(const QHash &keyMap) { + QVariantMap variants; + QHash::const_iterator mapIter = keyMap.constBegin(); + while(mapIter != keyMap.constEnd()) { + variants[QString::number(mapIter.key())] = qVariantFromValue(mapIter.value()); + mapIter++; + } + setLocalValue("JumpKeyMap", variants); } -QVariant AccountSettings::value(const QString &account, const QString &key, const QVariant &def) { - return localValue(QString("%1/%2").arg(account).arg(key), def); +QHash CoreAccountSettings::jumpKeyMap() { + QHash keyMap; + QVariantMap variants = localValue("JumpKeyMap", QVariant()).toMap(); + QVariantMap::const_iterator mapIter = variants.constBegin(); + while(mapIter != variants.constEnd()) { + keyMap[mapIter.key().toInt()] = mapIter.value().value(); + mapIter++; + } + return keyMap; } + -void AccountSettings::removeAccount(const QString &account) { - removeLocalKey(account); +void CoreAccountSettings::removeAccount(AccountId id) { + removeLocalKey(QString("%1").arg(id.toInt())); }