From ce4a32fe52ef09d8f5ff1dd22c001110902b60a2 Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: 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/kdelibs@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kdecore/kconfigskeleton.cpp | 1207 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 1207 insertions(+) create mode 100644 kdecore/kconfigskeleton.cpp (limited to 'kdecore/kconfigskeleton.cpp') diff --git a/kdecore/kconfigskeleton.cpp b/kdecore/kconfigskeleton.cpp new file mode 100644 index 000000000..819696a15 --- /dev/null +++ b/kdecore/kconfigskeleton.cpp @@ -0,0 +1,1207 @@ +/* + This file is part of KOrganizer. + Copyright (c) 2000,2001 Cornelius Schumacher + Copyright (c) 2003 Waldo Bastian + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + Boston, MA 02110-1301, USA. +*/ + +#include +#include + +#include +#include +#include +#include +#include + +#include "kstringhandler.h" + +#include "kconfigskeleton.h" + +void KConfigSkeletonItem::readImmutability( KConfig *config ) +{ + mIsImmutable = config->entryIsImmutable( mKey ); +} + + +KConfigSkeleton::ItemString::ItemString( const QString &group, const QString &key, + QString &reference, + const QString &defaultValue, + Type type ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ), + mType( type ) +{ +} + +void KConfigSkeleton::ItemString::writeConfig( KConfig *config ) +{ + if ( mReference != mLoadedValue ) // WABA: Is this test needed? + { + config->setGroup( mGroup ); + if ((mDefault == mReference) && !config->hasDefault( mKey)) + config->revertToDefault( mKey ); + else if ( mType == Path ) + config->writePathEntry( mKey, mReference ); + else if ( mType == Password ) + config->writeEntry( mKey, KStringHandler::obscure( mReference ) ); + else + config->writeEntry( mKey, mReference ); + } +} + + +void KConfigSkeleton::ItemString::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + + if ( mType == Path ) + { + mReference = config->readPathEntry( mKey, mDefault ); + } + else if ( mType == Password ) + { + QString value = config->readEntry( mKey, + KStringHandler::obscure( mDefault ) ); + mReference = KStringHandler::obscure( value ); + } + else + { + mReference = config->readEntry( mKey, mDefault ); + } + + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemString::setProperty(const QVariant & p) +{ + mReference = p.toString(); +} + +QVariant KConfigSkeleton::ItemString::property() const +{ + return QVariant(mReference); +} + +KConfigSkeleton::ItemPassword::ItemPassword( const QString &group, const QString &key, + QString &reference, + const QString &defaultValue) + : ItemString( group, key, reference, defaultValue, Password ) +{ +} + +KConfigSkeleton::ItemPath::ItemPath( const QString &group, const QString &key, + QString &reference, + const QString &defaultValue) + : ItemString( group, key, reference, defaultValue, Path ) +{ +} + +KConfigSkeleton::ItemProperty::ItemProperty( const QString &group, + const QString &key, + QVariant &reference, + QVariant defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemProperty::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readPropertyEntry( mKey, mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemProperty::setProperty(const QVariant & p) +{ + mReference = p; +} + +QVariant KConfigSkeleton::ItemProperty::property() const +{ + return mReference; +} + +KConfigSkeleton::ItemBool::ItemBool( const QString &group, const QString &key, + bool &reference, bool defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemBool::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readBoolEntry( mKey, mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemBool::setProperty(const QVariant & p) +{ + mReference = p.toBool(); +} + +QVariant KConfigSkeleton::ItemBool::property() const +{ + return QVariant( mReference, 42 /* dummy */ ); +} + + +KConfigSkeleton::ItemInt::ItemInt( const QString &group, const QString &key, + int &reference, int defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemInt::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readNumEntry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemInt::setProperty(const QVariant & p) +{ + mReference = p.toInt(); +} + +QVariant KConfigSkeleton::ItemInt::property() const +{ + return QVariant(mReference); +} + +QVariant KConfigSkeleton::ItemInt::minValue() const +{ + if (mHasMin) + return QVariant(mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemInt::maxValue() const +{ + if (mHasMax) + return QVariant(mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemInt::setMinValue(int v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemInt::setMaxValue(int v) +{ + mHasMax = true; + mMax = v; +} + + +KConfigSkeleton::ItemInt64::ItemInt64( const QString &group, const QString &key, + Q_INT64 &reference, Q_INT64 defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemInt64::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readNum64Entry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemInt64::setProperty(const QVariant & p) +{ + mReference = p.toLongLong(); +} + +QVariant KConfigSkeleton::ItemInt64::property() const +{ + return QVariant(mReference); +} + +QVariant KConfigSkeleton::ItemInt64::minValue() const +{ + if (mHasMin) + return QVariant(mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemInt64::maxValue() const +{ + if (mHasMax) + return QVariant(mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemInt64::setMinValue(Q_INT64 v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemInt64::setMaxValue(Q_INT64 v) +{ + mHasMax = true; + mMax = v; +} + +KConfigSkeleton::ItemEnum::ItemEnum( const QString &group, const QString &key, + int &reference, + const QValueList &choices, + int defaultValue ) + : ItemInt( group, key, reference, defaultValue ), mChoices( choices ) +{ +} + +void KConfigSkeleton::ItemEnum::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + if (!config->hasKey(mKey)) + { + mReference = mDefault; + } + else + { + int i = 0; + mReference = -1; + QString tmp = config->readEntry( mKey ).lower(); + for(QValueList::ConstIterator it = mChoices.begin(); + it != mChoices.end(); ++it, ++i) + { + if ((*it).name.lower() == tmp) + { + mReference = i; + break; + } + } + if (mReference == -1) + mReference = config->readNumEntry( mKey, mDefault ); + } + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemEnum::writeConfig( KConfig *config ) +{ + if ( mReference != mLoadedValue ) // WABA: Is this test needed? + { + config->setGroup( mGroup ); + if ((mDefault == mReference) && !config->hasDefault( mKey)) + config->revertToDefault( mKey ); + else if ((mReference >= 0) && (mReference < (int) mChoices.count())) + config->writeEntry( mKey, mChoices[mReference].name ); + else + config->writeEntry( mKey, mReference ); + } +} + +QValueList KConfigSkeleton::ItemEnum::choices() const +{ + return mChoices; +} + + +KConfigSkeleton::ItemUInt::ItemUInt( const QString &group, const QString &key, + unsigned int &reference, + unsigned int defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemUInt::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readUnsignedNumEntry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemUInt::setProperty(const QVariant & p) +{ + mReference = p.toUInt(); +} + +QVariant KConfigSkeleton::ItemUInt::property() const +{ + return QVariant(mReference); +} + +QVariant KConfigSkeleton::ItemUInt::minValue() const +{ + if (mHasMin) + return QVariant(mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemUInt::maxValue() const +{ + if (mHasMax) + return QVariant(mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemUInt::setMinValue(unsigned int v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemUInt::setMaxValue(unsigned int v) +{ + mHasMax = true; + mMax = v; +} + + +KConfigSkeleton::ItemUInt64::ItemUInt64( const QString &group, const QString &key, + Q_UINT64 &reference, Q_UINT64 defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemUInt64::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readUnsignedNum64Entry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemUInt64::setProperty(const QVariant & p) +{ + mReference = p.toULongLong(); +} + +QVariant KConfigSkeleton::ItemUInt64::property() const +{ + return QVariant(mReference); +} + +QVariant KConfigSkeleton::ItemUInt64::minValue() const +{ + if (mHasMin) + return QVariant(mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemUInt64::maxValue() const +{ + if (mHasMax) + return QVariant(mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemUInt64::setMinValue(Q_UINT64 v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemUInt64::setMaxValue(Q_UINT64 v) +{ + mHasMax = true; + mMax = v; +} + +KConfigSkeleton::ItemLong::ItemLong( const QString &group, const QString &key, + long &reference, long defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemLong::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readLongNumEntry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemLong::setProperty(const QVariant & p) +{ + mReference = p.toLongLong(); +} + +QVariant KConfigSkeleton::ItemLong::property() const +{ + return QVariant((Q_LLONG) mReference); +} + +QVariant KConfigSkeleton::ItemLong::minValue() const +{ + if (mHasMin) + return QVariant((Q_LLONG) mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemLong::maxValue() const +{ + if (mHasMax) + return QVariant((Q_LLONG) mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemLong::setMinValue(long v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemLong::setMaxValue(long v) +{ + mHasMax = true; + mMax = v; +} + + +KConfigSkeleton::ItemULong::ItemULong( const QString &group, const QString &key, + unsigned long &reference, + unsigned long defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemULong::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readUnsignedLongNumEntry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemULong::setProperty(const QVariant & p) +{ + mReference = p.toULongLong(); +} + +QVariant KConfigSkeleton::ItemULong::property() const +{ + return QVariant((Q_ULLONG) mReference); +} + +QVariant KConfigSkeleton::ItemULong::minValue() const +{ + if (mHasMin) + return QVariant((Q_ULLONG) mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemULong::maxValue() const +{ + if (mHasMax) + return QVariant((Q_ULLONG) mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemULong::setMinValue(unsigned long v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemULong::setMaxValue(unsigned long v) +{ + mHasMax = true; + mMax = v; +} + + +KConfigSkeleton::ItemDouble::ItemDouble( const QString &group, const QString &key, + double &reference, double defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) + ,mHasMin(false), mHasMax(false) +{ +} + +void KConfigSkeleton::ItemDouble::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readDoubleNumEntry( mKey, mDefault ); + if (mHasMin) + mReference = QMAX(mReference, mMin); + if (mHasMax) + mReference = QMIN(mReference, mMax); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemDouble::setProperty(const QVariant & p) +{ + mReference = p.toDouble(); +} + +QVariant KConfigSkeleton::ItemDouble::property() const +{ + return QVariant(mReference); +} + +QVariant KConfigSkeleton::ItemDouble::minValue() const +{ + if (mHasMin) + return QVariant(mMin); + return QVariant(); +} + +QVariant KConfigSkeleton::ItemDouble::maxValue() const +{ + if (mHasMax) + return QVariant(mMax); + return QVariant(); +} + +void KConfigSkeleton::ItemDouble::setMinValue(double v) +{ + mHasMin = true; + mMin = v; +} + +void KConfigSkeleton::ItemDouble::setMaxValue(double v) +{ + mHasMax = true; + mMax = v; +} + + +KConfigSkeleton::ItemColor::ItemColor( const QString &group, const QString &key, + QColor &reference, + const QColor &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemColor::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readColorEntry( mKey, &mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemColor::setProperty(const QVariant & p) +{ + mReference = p.toColor(); +} + +QVariant KConfigSkeleton::ItemColor::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemFont::ItemFont( const QString &group, const QString &key, + QFont &reference, + const QFont &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemFont::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readFontEntry( mKey, &mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemFont::setProperty(const QVariant & p) +{ + mReference = p.toFont(); +} + +QVariant KConfigSkeleton::ItemFont::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemRect::ItemRect( const QString &group, const QString &key, + QRect &reference, + const QRect &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemRect::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readRectEntry( mKey, &mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemRect::setProperty(const QVariant & p) +{ + mReference = p.toRect(); +} + +QVariant KConfigSkeleton::ItemRect::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemPoint::ItemPoint( const QString &group, const QString &key, + QPoint &reference, + const QPoint &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemPoint::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readPointEntry( mKey, &mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemPoint::setProperty(const QVariant & p) +{ + mReference = p.toPoint(); +} + +QVariant KConfigSkeleton::ItemPoint::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemSize::ItemSize( const QString &group, const QString &key, + QSize &reference, + const QSize &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemSize::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readSizeEntry( mKey, &mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemSize::setProperty(const QVariant & p) +{ + mReference = p.toSize(); +} + +QVariant KConfigSkeleton::ItemSize::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemDateTime::ItemDateTime( const QString &group, const QString &key, + QDateTime &reference, + const QDateTime &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemDateTime::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + mReference = config->readDateTimeEntry( mKey, &mDefault ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemDateTime::setProperty(const QVariant & p) +{ + mReference = p.toDateTime(); +} + +QVariant KConfigSkeleton::ItemDateTime::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemStringList::ItemStringList( const QString &group, const QString &key, + QStringList &reference, + const QStringList &defaultValue ) + : KConfigSkeletonGenericItem( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemStringList::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + if ( !config->hasKey( mKey ) ) + mReference = mDefault; + else + mReference = config->readListEntry( mKey ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemStringList::setProperty(const QVariant & p) +{ + mReference = p.toStringList(); +} + +QVariant KConfigSkeleton::ItemStringList::property() const +{ + return QVariant(mReference); +} + + +KConfigSkeleton::ItemPathList::ItemPathList( const QString &group, const QString &key, + QStringList &reference, + const QStringList &defaultValue ) + : ItemStringList( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemPathList::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + if ( !config->hasKey( mKey ) ) + mReference = mDefault; + else + mReference = config->readPathListEntry( mKey ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemPathList::writeConfig( KConfig *config ) +{ + if ( mReference != mLoadedValue ) // WABA: Is this test needed? + { + config->setGroup( mGroup ); + if ((mDefault == mReference) && !config->hasDefault( mKey)) + config->revertToDefault( mKey ); + else { + QStringList sl = mReference; + config->writePathEntry( mKey, sl ); + } + } +} + + +KConfigSkeleton::ItemIntList::ItemIntList( const QString &group, const QString &key, + QValueList &reference, + const QValueList &defaultValue ) + : KConfigSkeletonGenericItem >( group, key, reference, defaultValue ) +{ +} + +void KConfigSkeleton::ItemIntList::readConfig( KConfig *config ) +{ + config->setGroup( mGroup ); + if ( !config->hasKey( mKey ) ) + mReference = mDefault; + else + mReference = config->readIntListEntry( mKey ); + mLoadedValue = mReference; + + readImmutability( config ); +} + +void KConfigSkeleton::ItemIntList::setProperty(const QVariant &) +{ + // TODO: Not yet supported +} + +QVariant KConfigSkeleton::ItemIntList::property() const +{ + // TODO: Not yet supported + return QVariant(); +} + + +KConfigSkeleton::KConfigSkeleton( const QString &configname ) + : mCurrentGroup( "No Group" ), mUseDefaults(false) +{ + kdDebug(177) << "Creating KConfigSkeleton (" << (void *)this << ")" << endl; + + if ( !configname.isEmpty() ) + { + mConfig = KSharedConfig::openConfig( configname ); + } + else + { + mConfig = KGlobal::sharedConfig(); + } +} + +KConfigSkeleton::KConfigSkeleton(KSharedConfig::Ptr config) + : mCurrentGroup( "No Group" ), mUseDefaults(false) +{ + kdDebug(177) << "Creating KConfigSkeleton (" << (void *)this << ")" << endl; + mConfig = config; +} + + +KConfigSkeleton::~KConfigSkeleton() +{ + KConfigSkeletonItem::List::ConstIterator it; + for( it = mItems.begin(); it != mItems.end(); ++it ) + { + delete *it; + } +} + +void KConfigSkeleton::setCurrentGroup( const QString &group ) +{ + mCurrentGroup = group; +} + +KConfig *KConfigSkeleton::config() const +{ + return mConfig; +} + +bool KConfigSkeleton::useDefaults(bool b) +{ + if (b == mUseDefaults) + return mUseDefaults; + + mUseDefaults = b; + KConfigSkeletonItem::List::ConstIterator it; + for( it = mItems.begin(); it != mItems.end(); ++it ) + { + (*it)->swapDefault(); + } + + usrUseDefaults(b); + return !mUseDefaults; +} + +void KConfigSkeleton::setDefaults() +{ + KConfigSkeletonItem::List::ConstIterator it; + for( it = mItems.begin(); it != mItems.end(); ++it ) { + (*it)->setDefault(); + } + + usrSetDefaults(); +} + +void KConfigSkeleton::readConfig() +{ + kdDebug(177) << "KConfigSkeleton::readConfig()" << endl; + + QString origGroup = mConfig->group(); + + mConfig->reparseConfiguration(); + KConfigSkeletonItem::List::ConstIterator it; + for( it = mItems.begin(); it != mItems.end(); ++it ) + { + (*it)->readConfig( mConfig ); + } + + usrReadConfig(); + + mConfig->setGroup(origGroup); +} + +void KConfigSkeleton::writeConfig() +{ + kdDebug(177) << "KConfigSkeleton::writeConfig()" << endl; + + QString origGroup = mConfig->group(); + + KConfigSkeletonItem::List::ConstIterator it; + for( it = mItems.begin(); it != mItems.end(); ++it ) + { + (*it)->writeConfig( mConfig ); + } + + usrWriteConfig(); + + mConfig->sync(); + + readConfig(); + + mConfig->setGroup(origGroup); +} + +void KConfigSkeleton::addItem( KConfigSkeletonItem *item, const QString &name ) +{ + item->setName( name.isEmpty() ? item->key() : name ); + mItems.append( item ); + mItemDict.insert( item->name(), item ); + item->readDefault( mConfig ); + item->readConfig( mConfig ); +} + +KConfigSkeleton::ItemString *KConfigSkeleton::addItemString( const QString &name, QString &reference, + const QString &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemString *item; + item = new KConfigSkeleton::ItemString( mCurrentGroup, key.isEmpty() ? name : key, + reference, defaultValue, + KConfigSkeleton::ItemString::Normal ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemPassword *KConfigSkeleton::addItemPassword( const QString &name, QString &reference, + const QString &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemPassword *item; + item = new KConfigSkeleton::ItemPassword( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemPath *KConfigSkeleton::addItemPath( const QString &name, QString &reference, + const QString &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemPath *item; + item = new KConfigSkeleton::ItemPath( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemProperty *KConfigSkeleton::addItemProperty( const QString &name, QVariant &reference, + const QVariant &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemProperty *item; + item = new KConfigSkeleton::ItemProperty( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemBool *KConfigSkeleton::addItemBool( const QString &name, bool &reference, + bool defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemBool *item; + item = new KConfigSkeleton::ItemBool( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemInt *KConfigSkeleton::addItemInt( const QString &name, int &reference, + int defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemInt *item; + item = new KConfigSkeleton::ItemInt( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemUInt *KConfigSkeleton::addItemUInt( const QString &name, unsigned int &reference, + unsigned int defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemUInt *item; + item = new KConfigSkeleton::ItemUInt( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemInt64 *KConfigSkeleton::addItemInt64( const QString &name, Q_INT64 &reference, + Q_INT64 defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemInt64 *item; + item = new KConfigSkeleton::ItemInt64( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemUInt64 *KConfigSkeleton::addItemUInt64( const QString &name, Q_UINT64 &reference, + Q_UINT64 defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemUInt64 *item; + item = new KConfigSkeleton::ItemUInt64( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemLong *KConfigSkeleton::addItemLong( const QString &name, long &reference, + long defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemLong *item; + item = new KConfigSkeleton::ItemLong( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemULong *KConfigSkeleton::addItemULong( const QString &name, unsigned long &reference, + unsigned long defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemULong *item; + item = new KConfigSkeleton::ItemULong( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemDouble *KConfigSkeleton::addItemDouble( const QString &name, double &reference, + double defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemDouble *item; + item = new KConfigSkeleton::ItemDouble( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemColor *KConfigSkeleton::addItemColor( const QString &name, QColor &reference, + const QColor &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemColor *item; + item = new KConfigSkeleton::ItemColor( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemFont *KConfigSkeleton::addItemFont( const QString &name, QFont &reference, + const QFont &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemFont *item; + item = new KConfigSkeleton::ItemFont( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemRect *KConfigSkeleton::addItemRect( const QString &name, QRect &reference, + const QRect &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemRect *item; + item = new KConfigSkeleton::ItemRect( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemPoint *KConfigSkeleton::addItemPoint( const QString &name, QPoint &reference, + const QPoint &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemPoint *item; + item = new KConfigSkeleton::ItemPoint( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemSize *KConfigSkeleton::addItemSize( const QString &name, QSize &reference, + const QSize &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemSize *item; + item = new KConfigSkeleton::ItemSize( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemDateTime *KConfigSkeleton::addItemDateTime( const QString &name, QDateTime &reference, + const QDateTime &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemDateTime *item; + item = new KConfigSkeleton::ItemDateTime( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemStringList *KConfigSkeleton::addItemStringList( const QString &name, QStringList &reference, + const QStringList &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemStringList *item; + item = new KConfigSkeleton::ItemStringList( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +KConfigSkeleton::ItemIntList *KConfigSkeleton::addItemIntList( const QString &name, QValueList &reference, + const QValueList &defaultValue, const QString &key ) +{ + KConfigSkeleton::ItemIntList *item; + item = new KConfigSkeleton::ItemIntList( mCurrentGroup, key.isNull() ? name : key, + reference, defaultValue ); + addItem( item, name ); + return item; +} + +bool KConfigSkeleton::isImmutable(const QString &name) +{ + KConfigSkeletonItem *item = findItem(name); + return !item || item->isImmutable(); +} + +KConfigSkeletonItem *KConfigSkeleton::findItem(const QString &name) +{ + return mItemDict.find(name); +} -- cgit v1.2.1