-rw-r--r-- | microkde/kconfig.cpp | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/microkde/kconfig.cpp b/microkde/kconfig.cpp index 737b3f2..4cbec94 100644 --- a/microkde/kconfig.cpp +++ b/microkde/kconfig.cpp | |||
@@ -1,120 +1,132 @@ | |||
1 | #include <qfile.h> | 1 | #include <qfile.h> |
2 | #include <qtextstream.h> | 2 | #include <qtextstream.h> |
3 | #include <qwidget.h> | 3 | #include <qwidget.h> |
4 | 4 | ||
5 | #include "kdebug.h" | 5 | #include "kdebug.h" |
6 | 6 | ||
7 | #include "kurl.h" | 7 | #include "kurl.h" |
8 | #include "kstandarddirs.h" | 8 | #include "kstandarddirs.h" |
9 | #include "kconfig.h" | 9 | #include "kconfig.h" |
10 | 10 | ||
11 | QString KConfig::mGroup = ""; | 11 | QString KConfig::mGroup = ""; |
12 | //QString KConfig::mGroup = "General"; | 12 | //QString KConfig::mGroup = "General"; |
13 | 13 | ||
14 | KConfig::KConfig( const QString &fileName ) | 14 | KConfig::KConfig( const QString &fileName ) |
15 | : mFileName( fileName ), mDirty( false ) | 15 | : mFileName( fileName ), mDirty( false ) |
16 | { | 16 | { |
17 | kdDebug() << "KConfig::KConfig(): '" << fileName << "'" << endl; | 17 | |
18 | 18 | mTempGroup = ""; | |
19 | load(); | 19 | load(); |
20 | 20 | ||
21 | } | 21 | } |
22 | 22 | ||
23 | 23 | ||
24 | KConfig::~KConfig() | 24 | KConfig::~KConfig() |
25 | { | 25 | { |
26 | sync(); | 26 | sync(); |
27 | } | 27 | } |
28 | // we need the temp group for plugins on windows | ||
29 | void KConfig::setTempGroup( const QString &group ) | ||
30 | { | ||
31 | mTempGroup = group; | ||
32 | |||
33 | if ( mTempGroup.right( 1 ) != "/" ) mTempGroup += "/"; | ||
34 | } | ||
35 | |||
36 | |||
37 | QString KConfig::tempGroup() const { | ||
38 | return mTempGroup; | ||
39 | } | ||
28 | 40 | ||
29 | void KConfig::setGroup( const QString &group ) | 41 | void KConfig::setGroup( const QString &group ) |
30 | { | 42 | { |
31 | kdDebug() << "KConfig::setGroup(): '" << group << "'" << endl; | 43 | |
32 | 44 | ||
33 | mGroup = group; | 45 | mGroup = group; |
34 | 46 | ||
35 | if ( mGroup.right( 1 ) != "/" ) mGroup += "/"; | 47 | if ( mGroup.right( 1 ) != "/" ) mGroup += "/"; |
36 | } | 48 | } |
37 | 49 | ||
38 | //US | 50 | //US |
39 | QString KConfig::group() const { | 51 | QString KConfig::group() const { |
40 | return mGroup; | 52 | return mGroup; |
41 | } | 53 | } |
42 | 54 | ||
43 | //US added method | 55 | //US added method |
44 | QValueList<int> KConfig::readIntListEntry( const QString & key) | 56 | QValueList<int> KConfig::readIntListEntry( const QString & key) |
45 | { | 57 | { |
46 | // qDebug("KConfig::readIntListEntry key=%s:", key.latin1()); | 58 | // qDebug("KConfig::readIntListEntry key=%s:", key.latin1()); |
47 | 59 | ||
48 | QValueList<int> result; | 60 | QValueList<int> result; |
49 | 61 | ||
50 | QMap<QString,QString>::ConstIterator mit = mStringMap.find( mGroup + key ); | 62 | QMap<QString,QString>::ConstIterator mit = mStringMap.find( mGroup + key ); |
51 | 63 | ||
52 | if ( mit == mStringMap.end() ) { | 64 | if ( mit == mStringMap.end() ) { |
53 | return result; | 65 | return result; |
54 | } | 66 | } |
55 | 67 | ||
56 | QStringList valuesAsStrings = QStringList::split(":", *mit ); | 68 | QStringList valuesAsStrings = QStringList::split(":", *mit ); |
57 | bool ok = false; | 69 | bool ok = false; |
58 | bool ok2 = true; | 70 | bool ok2 = true; |
59 | int val; | 71 | int val; |
60 | 72 | ||
61 | for ( QStringList::Iterator sit = valuesAsStrings.begin(); sit != valuesAsStrings.end(); ++sit ) { | 73 | for ( QStringList::Iterator sit = valuesAsStrings.begin(); sit != valuesAsStrings.end(); ++sit ) { |
62 | val = (*sit).toInt(&ok); | 74 | val = (*sit).toInt(&ok); |
63 | result << val; | 75 | result << val; |
64 | if (ok == false) { | 76 | if (ok == false) { |
65 | qDebug("KConfig::readIntListEntry str=%s , int=%n:", (*sit).latin1(), &val); | 77 | qDebug("KConfig::readIntListEntry str=%s , int=%n:", (*sit).latin1(), &val); |
66 | ok2 = false; | 78 | ok2 = false; |
67 | } | 79 | } |
68 | } | 80 | } |
69 | 81 | ||
70 | if (ok2 == false) | 82 | if (ok2 == false) |
71 | { | 83 | { |
72 | kdDebug() << "KConfig::readIntListEntry: error while reading one of the intvalues." << endl; | 84 | |
73 | qDebug("KConfig::readIntListEntry: error while reading one of the intvalues."); | 85 | qDebug("KConfig::readIntListEntry: error while reading one of the intvalues."); |
74 | } | 86 | } |
75 | 87 | ||
76 | return result; | 88 | return result; |
77 | } | 89 | } |
78 | 90 | ||
79 | int KConfig::readNumEntry( const QString & key, int def ) | 91 | int KConfig::readNumEntry( const QString & key, int def ) |
80 | { | 92 | { |
81 | QString res = readEntry(key, QString::number(def ) ); | 93 | QString res = readEntry(key, QString::number(def ) ); |
82 | bool ok = false; | 94 | bool ok = false; |
83 | int result = res.toInt(&ok); | 95 | int result = res.toInt(&ok); |
84 | if ( ok ) | 96 | if ( ok ) |
85 | return result; | 97 | return result; |
86 | return def; | 98 | return def; |
87 | } | 99 | } |
88 | 100 | ||
89 | QString KConfig::readEntry( const QString &key, const QString &def ) | 101 | QString KConfig::readEntry( const QString &key, const QString &def ) |
90 | { | 102 | { |
91 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); | 103 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); |
92 | 104 | ||
93 | if ( it == mStringMap.end() ) { | 105 | if ( it == mStringMap.end() ) { |
94 | return def; | 106 | return def; |
95 | } | 107 | } |
96 | 108 | ||
97 | return *it; | 109 | return *it; |
98 | } | 110 | } |
99 | 111 | ||
100 | QStringList KConfig::readListEntry( const QString &key ) | 112 | QStringList KConfig::readListEntry( const QString &key ) |
101 | { | 113 | { |
102 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); | 114 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); |
103 | 115 | ||
104 | if ( it == mStringMap.end() ) { | 116 | if ( it == mStringMap.end() ) { |
105 | return QStringList(); | 117 | return QStringList(); |
106 | } | 118 | } |
107 | return QStringList::split(":", *it ); | 119 | return QStringList::split(":", *it ); |
108 | 120 | ||
109 | } | 121 | } |
110 | 122 | ||
111 | bool KConfig::readBoolEntry( const QString &key, bool def ) | 123 | bool KConfig::readBoolEntry( const QString &key, bool def ) |
112 | { | 124 | { |
113 | QMap<QString,bool>::ConstIterator it = mBoolMap.find( mGroup + key ); | 125 | QMap<QString,bool>::ConstIterator it = mBoolMap.find( mGroup + key ); |
114 | 126 | ||
115 | if ( it == mBoolMap.end() ) { | 127 | if ( it == mBoolMap.end() ) { |
116 | return def; | 128 | return def; |
117 | } | 129 | } |
118 | 130 | ||
119 | return *it; | 131 | return *it; |
120 | } | 132 | } |
@@ -182,97 +194,97 @@ void KConfig::writeEntry( const QString & key , int num ) | |||
182 | 194 | ||
183 | void KConfig::writeEntry( const QString &key, const QString &value ) | 195 | void KConfig::writeEntry( const QString &key, const QString &value ) |
184 | { | 196 | { |
185 | mStringMap.insert( mGroup + key, value ); | 197 | mStringMap.insert( mGroup + key, value ); |
186 | 198 | ||
187 | mDirty = true; | 199 | mDirty = true; |
188 | } | 200 | } |
189 | 201 | ||
190 | void KConfig::writeEntry( const QString &key, const QStringList &value ) | 202 | void KConfig::writeEntry( const QString &key, const QStringList &value ) |
191 | { | 203 | { |
192 | mStringMap.insert( mGroup + key, value.join(":") ); | 204 | mStringMap.insert( mGroup + key, value.join(":") ); |
193 | 205 | ||
194 | mDirty = true; | 206 | mDirty = true; |
195 | } | 207 | } |
196 | 208 | ||
197 | void KConfig::writeEntry( const QString &key, bool value) | 209 | void KConfig::writeEntry( const QString &key, bool value) |
198 | { | 210 | { |
199 | mBoolMap.insert( mGroup + key, value ); | 211 | mBoolMap.insert( mGroup + key, value ); |
200 | 212 | ||
201 | mDirty = true; | 213 | mDirty = true; |
202 | } | 214 | } |
203 | 215 | ||
204 | void KConfig::writeEntry( const QString & e, const QColor & c ) | 216 | void KConfig::writeEntry( const QString & e, const QColor & c ) |
205 | { | 217 | { |
206 | QStringList l; | 218 | QStringList l; |
207 | l.append( QString::number ( c.red() ) ); | 219 | l.append( QString::number ( c.red() ) ); |
208 | l.append( QString::number ( c.green() ) ); | 220 | l.append( QString::number ( c.green() ) ); |
209 | l.append( QString::number ( c.blue() ) ); | 221 | l.append( QString::number ( c.blue() ) ); |
210 | writeEntry( e, l ); | 222 | writeEntry( e, l ); |
211 | } | 223 | } |
212 | 224 | ||
213 | void KConfig::writeEntry( const QString & e , const QFont & f ) | 225 | void KConfig::writeEntry( const QString & e , const QFont & f ) |
214 | { | 226 | { |
215 | QStringList font; | 227 | QStringList font; |
216 | font.append( f.family()); | 228 | font.append( f.family()); |
217 | font.append( (!f.bold ()?"nonbold":"bold") ); | 229 | font.append( (!f.bold ()?"nonbold":"bold") ); |
218 | font.append( QString::number ( f.pointSize () ) ); | 230 | font.append( QString::number ( f.pointSize () ) ); |
219 | font.append( !f.italic ()?"nonitalic":"italic" ); | 231 | font.append( !f.italic ()?"nonitalic":"italic" ); |
220 | writeEntry( e, font ); | 232 | writeEntry( e, font ); |
221 | } | 233 | } |
222 | 234 | ||
223 | void KConfig::writeEntry( const QString &key, const QDateTime &dt ) | 235 | void KConfig::writeEntry( const QString &key, const QDateTime &dt ) |
224 | { | 236 | { |
225 | mDateTimeMap.insert( mGroup + key, dt ); | 237 | mDateTimeMap.insert( mGroup + key, dt ); |
226 | } | 238 | } |
227 | 239 | ||
228 | void KConfig::load() | 240 | void KConfig::load() |
229 | { | 241 | { |
230 | kdDebug() << "KConfig::load(): " << mFileName << endl; | 242 | |
231 | 243 | ||
232 | QFile f( mFileName ); | 244 | QFile f( mFileName ); |
233 | if ( !f.open( IO_ReadOnly ) ) { | 245 | if ( !f.open( IO_ReadOnly ) ) { |
234 | qDebug("KConfig: could not open file %s ",mFileName.latin1() ); | 246 | qDebug("KConfig: could not open file %s ",mFileName.latin1() ); |
235 | return; | 247 | return; |
236 | } | 248 | } |
237 | 249 | ||
238 | mBoolMap.clear(); | 250 | mBoolMap.clear(); |
239 | mStringMap.clear(); | 251 | mStringMap.clear(); |
240 | 252 | ||
241 | QTextStream t( &f ); | 253 | QTextStream t( &f ); |
242 | 254 | ||
243 | QString line = t.readLine(); | 255 | QString line = t.readLine(); |
244 | 256 | ||
245 | while ( !line.isNull() ) { | 257 | while ( !line.isNull() ) { |
246 | QStringList tokens = QStringList::split( ",", line ); | 258 | QStringList tokens = QStringList::split( ",", line ); |
247 | if ( tokens[0] == "bool" ) { | 259 | if ( tokens[0] == "bool" ) { |
248 | bool value = false; | 260 | bool value = false; |
249 | if ( tokens[2] == "1" ) value = true; | 261 | if ( tokens[2] == "1" ) value = true; |
250 | mBoolMap.insert( tokens[1], value ); | 262 | mBoolMap.insert( tokens[1], value ); |
251 | } else if ( tokens[0] == "QString" ) { | 263 | } else if ( tokens[0] == "QString" ) { |
252 | QString value = tokens[2]; | 264 | QString value = tokens[2]; |
253 | mStringMap.insert( tokens[1], value ); | 265 | mStringMap.insert( tokens[1], value ); |
254 | } else if ( tokens[0] == "QDateTime" ) { | 266 | } else if ( tokens[0] == "QDateTime" ) { |
255 | #if 0 | 267 | #if 0 |
256 | int year = tokens[2].toInt(); | 268 | int year = tokens[2].toInt(); |
257 | QDateTime dt( QDate( year, | 269 | QDateTime dt( QDate( year, |
258 | tokens[3].toInt(), | 270 | tokens[3].toInt(), |
259 | tokens[4].toInt() ), | 271 | tokens[4].toInt() ), |
260 | QTime( tokens[5].toInt(), tokens[6].toInt(), | 272 | QTime( tokens[5].toInt(), tokens[6].toInt(), |
261 | tokens[7].toInt() ) ); | 273 | tokens[7].toInt() ) ); |
262 | mDateTimeMap.insert( tokens[1], dt ); | 274 | mDateTimeMap.insert( tokens[1], dt ); |
263 | #endif | 275 | #endif |
264 | } | 276 | } |
265 | 277 | ||
266 | line = t.readLine(); | 278 | line = t.readLine(); |
267 | } | 279 | } |
268 | } | 280 | } |
269 | 281 | ||
270 | void KConfig::sync() | 282 | void KConfig::sync() |
271 | { | 283 | { |
272 | 284 | ||
273 | if ( !mDirty ) return; | 285 | if ( !mDirty ) return; |
274 | //qDebug("KConfig::sync() %s ",mFileName.latin1() ); | 286 | //qDebug("KConfig::sync() %s ",mFileName.latin1() ); |
275 | //kdDebug() << "KConfig::sync(): " << mFileName << endl; | 287 | //kdDebug() << "KConfig::sync(): " << mFileName << endl; |
276 | 288 | ||
277 | //US I took the following code from a newer version of KDE | 289 | //US I took the following code from a newer version of KDE |
278 | // Create the containing dir if needed | 290 | // Create the containing dir if needed |