diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | bcb704366cb5e333a626c18c308c7e0448a8e69f (patch) | |
tree | f0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /krdc/hostpreferences.cpp | |
download | tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'krdc/hostpreferences.cpp')
-rw-r--r-- | krdc/hostpreferences.cpp | 192 |
1 files changed, 192 insertions, 0 deletions
diff --git a/krdc/hostpreferences.cpp b/krdc/hostpreferences.cpp new file mode 100644 index 00000000..4b02191b --- /dev/null +++ b/krdc/hostpreferences.cpp @@ -0,0 +1,192 @@ +/*************************************************************************** + hostpreferences.cpp - per host preferences + ------------------- + begin : Fri May 09 22:33 CET 2003 + copyright : (C) 2003 by Tim Jansen + : (C) 2004 Nadeem Hasan <nhasan@kde.org> + email : tim@tjansen.de + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "hostpreferences.h" +#include "vnc/vnchostpref.h" +#include "rdp/rdphostpref.h" + +#include <kapplication.h> +#include <kconfig.h> +#include <kstaticdeleter.h> + +#include <qregexp.h> +#include <qmap.h> + +HostPreferences *HostPreferences::m_instance = 0; +static KStaticDeleter<HostPreferences> sd; + +HostPreferences *HostPreferences::instance() +{ + if ( m_instance == 0 ) + sd.setObject( m_instance, new HostPreferences() ); + + return m_instance; +} + +HostPref::HostPref(KConfig *conf, const QString &host, const QString &type) : + m_host(host), + m_type(type), + m_config(conf) { +} + +HostPref::~HostPref() { + m_config->sync(); +} + +QString HostPref::host() const { + return m_host; +} + +QString HostPref::type() const { + return m_type; +} + +QString HostPref::prefix() const { + return prefix(m_host, m_type); +} + +QString HostPref::prefix(const QString &host, const QString &type) { + return QString("PerHost-%1-%2-").arg(type).arg(host); +} + + +HostPreferences::HostPreferences() { + m_config = kapp->config(); +} + +HostPreferences::~HostPreferences() { + if ( m_instance == this ) + sd.setObject( m_instance, 0, false ); +} + +HostPrefPtr HostPreferences::getHostPref(const QString &host, const QString &type) { + m_config->setGroup("PerHostSettings"); + if (!m_config->readBoolEntry(HostPref::prefix(host, type)+"exists")) + return 0; + + if (type == VncHostPref::VncType) { + HostPrefPtr hp = new VncHostPref(m_config, host, type); + hp->load(); + return hp; + } + else if(type == RdpHostPref::RdpType) { + HostPrefPtr hp = new RdpHostPref(m_config, host, type); + hp->load(); + return hp; + } + Q_ASSERT(true); + return 0; +} + +HostPrefPtr HostPreferences::createHostPref(const QString &host, const QString &type) { + HostPrefPtr hp = getHostPref(host, type); + if (hp) + return hp; + + if(type == VncHostPref::VncType) + { + hp = new VncHostPref(m_config, host, type); + } + else if(type == RdpHostPref::RdpType) + { + hp = new RdpHostPref(m_config, host, type); + } + hp->setDefaults(); + return hp; +} + +HostPrefPtr HostPreferences::vncDefaults() +{ + HostPrefPtr hp = new VncHostPref( m_config ); + hp->load(); + + return hp; +} + +HostPrefPtr HostPreferences::rdpDefaults() +{ + HostPrefPtr hp = new RdpHostPref( m_config ); + hp->load(); + + return hp; +} + +HostPrefPtrList HostPreferences::getAllHostPrefs() { + HostPrefPtrList r; + QMap<QString, QString> map = m_config->entryMap("PerHostSettings"); + QStringList keys = map.keys(); + QStringList::iterator it = keys.begin(); + while (it != keys.end()) { + QString key = *it; + if (key.endsWith("-exists")) { + QRegExp re("PerHost-([^-]+)-(.*)-exists"); + if (re.exactMatch(key)) { + HostPrefPtr hp = getHostPref(re.cap(2), re.cap(1)); + if (hp) + r += hp; + } + + } + it++; + } + return r; +} + +void HostPreferences::removeHostPref(HostPref *hostPref) { + hostPref->remove(); +} + +void HostPreferences::setShowBrowsingPanel( bool b ) +{ + m_config->setGroup( QString::null ); + m_config->writeEntry( "browsingPanel", b ); +} + +void HostPreferences::setServerCompletions( const QStringList &list ) +{ + m_config->setGroup( QString::null ); + m_config->writeEntry( "serverCompletions", list ); +} + +void HostPreferences::setServerHistory( const QStringList &list ) +{ + m_config->setGroup( QString::null ); + m_config->writeEntry( "serverHistory", list ); +} + +bool HostPreferences::showBrowsingPanel() +{ + m_config->setGroup( QString::null ); + return m_config->readBoolEntry( "browsingPanel" ); +} + +QStringList HostPreferences::serverCompletions() +{ + m_config->setGroup( QString::null ); + return m_config->readListEntry( "serverCompletions" ); +} + +QStringList HostPreferences::serverHistory() +{ + m_config->setGroup( QString::null ); + return m_config->readListEntry( "serverHistory" ); +} + +void HostPreferences::sync() { + m_config->sync(); +} |