-rw-r--r-- | microkde/kconfig.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/microkde/kconfig.cpp b/microkde/kconfig.cpp index 4cbec94..ba41f6c 100644 --- a/microkde/kconfig.cpp +++ b/microkde/kconfig.cpp | |||
@@ -1,521 +1,547 @@ | |||
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 | 17 | ||
18 | mTempGroup = ""; | 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 | 28 | // we need the temp group for plugins on windows |
29 | void KConfig::setTempGroup( const QString &group ) | 29 | void KConfig::setTempGroup( const QString &group ) |
30 | { | 30 | { |
31 | mTempGroup = group; | 31 | mTempGroup = group; |
32 | 32 | ||
33 | if ( mTempGroup.right( 1 ) != "/" ) mTempGroup += "/"; | 33 | if ( mTempGroup.right( 1 ) != "/" ) mTempGroup += "/"; |
34 | } | 34 | } |
35 | 35 | ||
36 | 36 | ||
37 | QString KConfig::tempGroup() const { | 37 | QString KConfig::tempGroup() const { |
38 | return mTempGroup; | 38 | return mTempGroup; |
39 | } | 39 | } |
40 | 40 | ||
41 | void KConfig::setGroup( const QString &group ) | 41 | void KConfig::setGroup( const QString &group ) |
42 | { | 42 | { |
43 | 43 | ||
44 | 44 | ||
45 | mGroup = group; | 45 | mGroup = group; |
46 | 46 | ||
47 | if ( mGroup.right( 1 ) != "/" ) mGroup += "/"; | 47 | if ( mGroup.right( 1 ) != "/" ) mGroup += "/"; |
48 | } | 48 | } |
49 | 49 | ||
50 | //US | 50 | //US |
51 | QString KConfig::group() const { | 51 | QString KConfig::group() const { |
52 | return mGroup; | 52 | return mGroup; |
53 | } | 53 | } |
54 | 54 | ||
55 | //US added method | 55 | //US added method |
56 | QValueList<int> KConfig::readIntListEntry( const QString & key) | 56 | QValueList<int> KConfig::readIntListEntry( const QString & key) |
57 | { | 57 | { |
58 | // qDebug("KConfig::readIntListEntry key=%s:", key.latin1()); | 58 | // qDebug("KConfig::readIntListEntry key=%s:", key.latin1()); |
59 | 59 | ||
60 | QValueList<int> result; | 60 | QValueList<int> result; |
61 | 61 | ||
62 | QMap<QString,QString>::ConstIterator mit = mStringMap.find( mGroup + key ); | 62 | QMap<QString,QString>::ConstIterator mit = mStringMap.find( mGroup + key ); |
63 | 63 | ||
64 | if ( mit == mStringMap.end() ) { | 64 | if ( mit == mStringMap.end() ) { |
65 | return result; | 65 | return result; |
66 | } | 66 | } |
67 | 67 | ||
68 | QStringList valuesAsStrings = QStringList::split(":", *mit ); | 68 | QStringList valuesAsStrings = QStringList::split(":", *mit ); |
69 | bool ok = false; | 69 | bool ok = false; |
70 | bool ok2 = true; | 70 | bool ok2 = true; |
71 | int val; | 71 | int val; |
72 | 72 | ||
73 | for ( QStringList::Iterator sit = valuesAsStrings.begin(); sit != valuesAsStrings.end(); ++sit ) { | 73 | for ( QStringList::Iterator sit = valuesAsStrings.begin(); sit != valuesAsStrings.end(); ++sit ) { |
74 | val = (*sit).toInt(&ok); | 74 | val = (*sit).toInt(&ok); |
75 | result << val; | 75 | result << val; |
76 | if (ok == false) { | 76 | if (ok == false) { |
77 | qDebug("KConfig::readIntListEntry str=%s , int=%n:", (*sit).latin1(), &val); | 77 | qDebug("KConfig::readIntListEntry str=%s , int=%n:", (*sit).latin1(), &val); |
78 | ok2 = false; | 78 | ok2 = false; |
79 | } | 79 | } |
80 | } | 80 | } |
81 | 81 | ||
82 | if (ok2 == false) | 82 | if (ok2 == false) |
83 | { | 83 | { |
84 | 84 | ||
85 | qDebug("KConfig::readIntListEntry: error while reading one of the intvalues."); | 85 | qDebug("KConfig::readIntListEntry: error while reading one of the intvalues."); |
86 | } | 86 | } |
87 | 87 | ||
88 | return result; | 88 | return result; |
89 | } | 89 | } |
90 | 90 | ||
91 | int KConfig::readNumEntry( const QString & key, int def ) | 91 | int KConfig::readNumEntry( const QString & key, int def ) |
92 | { | 92 | { |
93 | QString res = readEntry(key, QString::number(def ) ); | 93 | QString res = readEntry(key, QString::number(def ) ); |
94 | bool ok = false; | 94 | bool ok = false; |
95 | int result = res.toInt(&ok); | 95 | int result = res.toInt(&ok); |
96 | if ( ok ) | 96 | if ( ok ) |
97 | return result; | 97 | return result; |
98 | return def; | 98 | return def; |
99 | } | 99 | } |
100 | 100 | ||
101 | QString KConfig::readEntry( const QString &key, const QString &def ) | 101 | QString KConfig::readEntry( const QString &key, const QString &def ) |
102 | { | 102 | { |
103 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); | 103 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); |
104 | 104 | ||
105 | if ( it == mStringMap.end() ) { | 105 | if ( it == mStringMap.end() ) { |
106 | return def; | 106 | return def; |
107 | } | 107 | } |
108 | 108 | ||
109 | return *it; | 109 | return *it; |
110 | } | 110 | } |
111 | 111 | ||
112 | QSize KConfig::readSizeEntry( const QString &key, QSize* def ) | ||
113 | { | ||
114 | QValueList<int> intlist = readIntListEntry(key); | ||
115 | |||
116 | if (intlist.count() < 2) | ||
117 | { | ||
118 | if (def) | ||
119 | return *def; | ||
120 | else | ||
121 | return QSize(); | ||
122 | } | ||
123 | |||
124 | QSize ret; | ||
125 | ret.setWidth(intlist[0]); | ||
126 | ret.setHeight(intlist[1]); | ||
127 | |||
128 | return ret; | ||
129 | } | ||
130 | |||
112 | QStringList KConfig::readListEntry( const QString &key ) | 131 | QStringList KConfig::readListEntry( const QString &key ) |
113 | { | 132 | { |
114 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); | 133 | QMap<QString,QString>::ConstIterator it = mStringMap.find( mGroup + key ); |
115 | 134 | ||
116 | if ( it == mStringMap.end() ) { | 135 | if ( it == mStringMap.end() ) { |
117 | return QStringList(); | 136 | return QStringList(); |
118 | } | 137 | } |
119 | return QStringList::split(":", *it ); | 138 | return QStringList::split(":", *it ); |
120 | 139 | ||
121 | } | 140 | } |
122 | 141 | ||
123 | bool KConfig::readBoolEntry( const QString &key, bool def ) | 142 | bool KConfig::readBoolEntry( const QString &key, bool def ) |
124 | { | 143 | { |
125 | QMap<QString,bool>::ConstIterator it = mBoolMap.find( mGroup + key ); | 144 | QMap<QString,bool>::ConstIterator it = mBoolMap.find( mGroup + key ); |
126 | 145 | ||
127 | if ( it == mBoolMap.end() ) { | 146 | if ( it == mBoolMap.end() ) { |
128 | return def; | 147 | return def; |
129 | } | 148 | } |
130 | 149 | ||
131 | return *it; | 150 | return *it; |
132 | } | 151 | } |
133 | 152 | ||
134 | QColor KConfig::readColorEntry( const QString & e, QColor *def ) | 153 | QColor KConfig::readColorEntry( const QString & e, QColor *def ) |
135 | { | 154 | { |
136 | 155 | ||
137 | QStringList l; | 156 | QStringList l; |
138 | l = readListEntry( e ); | 157 | l = readListEntry( e ); |
139 | if (l.count() != 3 ) { | 158 | if (l.count() != 3 ) { |
140 | if ( def ) | 159 | if ( def ) |
141 | return *def; | 160 | return *def; |
142 | else | 161 | else |
143 | return QColor(); | 162 | return QColor(); |
144 | } | 163 | } |
145 | QColor c ( l[0].toInt(), l[1].toInt(), l[2].toInt() ); | 164 | QColor c ( l[0].toInt(), l[1].toInt(), l[2].toInt() ); |
146 | return c; | 165 | return c; |
147 | } | 166 | } |
148 | 167 | ||
149 | QFont KConfig::readFontEntry( const QString & e, QFont *def ) | 168 | QFont KConfig::readFontEntry( const QString & e, QFont *def ) |
150 | { | 169 | { |
151 | QStringList font = readListEntry( e ); | 170 | QStringList font = readListEntry( e ); |
152 | if ( font.isEmpty() ) | 171 | if ( font.isEmpty() ) |
153 | return *def; | 172 | return *def; |
154 | QFont f; | 173 | QFont f; |
155 | f.setFamily( font[0]); | 174 | f.setFamily( font[0]); |
156 | f.setBold ( font[1] == "bold"); | 175 | f.setBold ( font[1] == "bold"); |
157 | f.setPointSize ( font[2].toInt()); | 176 | f.setPointSize ( font[2].toInt()); |
158 | f.setItalic( font[3] == "italic" ); | 177 | f.setItalic( font[3] == "italic" ); |
159 | return f; | 178 | return f; |
160 | } | 179 | } |
161 | 180 | ||
162 | QDateTime KConfig::readDateTimeEntry( const QString &key, const QDateTime *def ) | 181 | QDateTime KConfig::readDateTimeEntry( const QString &key, const QDateTime *def ) |
163 | { | 182 | { |
164 | QMap<QString,QDateTime>::ConstIterator it = mDateTimeMap.find( mGroup + key ); | 183 | QMap<QString,QDateTime>::ConstIterator it = mDateTimeMap.find( mGroup + key ); |
165 | 184 | ||
166 | if ( it == mDateTimeMap.end() ) { | 185 | if ( it == mDateTimeMap.end() ) { |
167 | if ( def ) return *def; | 186 | if ( def ) return *def; |
168 | else return QDateTime(); | 187 | else return QDateTime(); |
169 | } | 188 | } |
170 | 189 | ||
171 | return *it; | 190 | return *it; |
172 | } | 191 | } |
173 | 192 | ||
174 | //US added method | 193 | //US added method |
175 | void KConfig::writeEntry( const QString &key, const QValueList<int> &value) | 194 | void KConfig::writeEntry( const QString &key, const QValueList<int> &value) |
176 | { | 195 | { |
177 | QStringList valuesAsStrings; | 196 | QStringList valuesAsStrings; |
178 | 197 | ||
179 | QValueList<int>::ConstIterator it; | 198 | QValueList<int>::ConstIterator it; |
180 | 199 | ||
181 | for( it = value.begin(); it != value.end(); ++it ) | 200 | for( it = value.begin(); it != value.end(); ++it ) |
182 | { | 201 | { |
183 | valuesAsStrings << QString::number(*it); | 202 | valuesAsStrings << QString::number(*it); |
184 | } | 203 | } |
185 | 204 | ||
186 | mStringMap.insert( mGroup + key, valuesAsStrings.join(":") ); | 205 | mStringMap.insert( mGroup + key, valuesAsStrings.join(":") ); |
187 | mDirty = true; | 206 | mDirty = true; |
188 | } | 207 | } |
189 | 208 | ||
190 | void KConfig::writeEntry( const QString & key , int num ) | 209 | void KConfig::writeEntry( const QString & key , int num ) |
191 | { | 210 | { |
192 | writeEntry( key, QString::number ( num ) ); | 211 | writeEntry( key, QString::number ( num ) ); |
193 | } | 212 | } |
194 | 213 | ||
195 | void KConfig::writeEntry( const QString &key, const QString &value ) | 214 | void KConfig::writeEntry( const QString &key, const QString &value ) |
196 | { | 215 | { |
197 | mStringMap.insert( mGroup + key, value ); | 216 | mStringMap.insert( mGroup + key, value ); |
198 | 217 | ||
199 | mDirty = true; | 218 | mDirty = true; |
200 | } | 219 | } |
201 | 220 | ||
202 | void KConfig::writeEntry( const QString &key, const QStringList &value ) | 221 | void KConfig::writeEntry( const QString &key, const QStringList &value ) |
203 | { | 222 | { |
204 | mStringMap.insert( mGroup + key, value.join(":") ); | 223 | mStringMap.insert( mGroup + key, value.join(":") ); |
205 | 224 | ||
206 | mDirty = true; | 225 | mDirty = true; |
207 | } | 226 | } |
208 | 227 | ||
209 | void KConfig::writeEntry( const QString &key, bool value) | 228 | void KConfig::writeEntry( const QString &key, bool value) |
210 | { | 229 | { |
211 | mBoolMap.insert( mGroup + key, value ); | 230 | mBoolMap.insert( mGroup + key, value ); |
212 | 231 | ||
213 | mDirty = true; | 232 | mDirty = true; |
214 | } | 233 | } |
215 | 234 | ||
216 | void KConfig::writeEntry( const QString & e, const QColor & c ) | 235 | void KConfig::writeEntry( const QString & e, const QColor & c ) |
217 | { | 236 | { |
218 | QStringList l; | 237 | QStringList l; |
219 | l.append( QString::number ( c.red() ) ); | 238 | l.append( QString::number ( c.red() ) ); |
220 | l.append( QString::number ( c.green() ) ); | 239 | l.append( QString::number ( c.green() ) ); |
221 | l.append( QString::number ( c.blue() ) ); | 240 | l.append( QString::number ( c.blue() ) ); |
222 | writeEntry( e, l ); | 241 | writeEntry( e, l ); |
223 | } | 242 | } |
224 | 243 | ||
244 | void KConfig::writeEntry( const QString & e, const QSize & s ) | ||
245 | { | ||
246 | QValueList<int> intlist; | ||
247 | intlist << s.width() << s.height(); | ||
248 | writeEntry( e, intlist ); | ||
249 | } | ||
250 | |||
225 | void KConfig::writeEntry( const QString & e , const QFont & f ) | 251 | void KConfig::writeEntry( const QString & e , const QFont & f ) |
226 | { | 252 | { |
227 | QStringList font; | 253 | QStringList font; |
228 | font.append( f.family()); | 254 | font.append( f.family()); |
229 | font.append( (!f.bold ()?"nonbold":"bold") ); | 255 | font.append( (!f.bold ()?"nonbold":"bold") ); |
230 | font.append( QString::number ( f.pointSize () ) ); | 256 | font.append( QString::number ( f.pointSize () ) ); |
231 | font.append( !f.italic ()?"nonitalic":"italic" ); | 257 | font.append( !f.italic ()?"nonitalic":"italic" ); |
232 | writeEntry( e, font ); | 258 | writeEntry( e, font ); |
233 | } | 259 | } |
234 | 260 | ||
235 | void KConfig::writeEntry( const QString &key, const QDateTime &dt ) | 261 | void KConfig::writeEntry( const QString &key, const QDateTime &dt ) |
236 | { | 262 | { |
237 | mDateTimeMap.insert( mGroup + key, dt ); | 263 | mDateTimeMap.insert( mGroup + key, dt ); |
238 | } | 264 | } |
239 | 265 | ||
240 | void KConfig::load() | 266 | void KConfig::load() |
241 | { | 267 | { |
242 | 268 | ||
243 | 269 | ||
244 | QFile f( mFileName ); | 270 | QFile f( mFileName ); |
245 | if ( !f.open( IO_ReadOnly ) ) { | 271 | if ( !f.open( IO_ReadOnly ) ) { |
246 | qDebug("KConfig: could not open file %s ",mFileName.latin1() ); | 272 | qDebug("KConfig: could not open file %s ",mFileName.latin1() ); |
247 | return; | 273 | return; |
248 | } | 274 | } |
249 | 275 | ||
250 | mBoolMap.clear(); | 276 | mBoolMap.clear(); |
251 | mStringMap.clear(); | 277 | mStringMap.clear(); |
252 | 278 | ||
253 | QTextStream t( &f ); | 279 | QTextStream t( &f ); |
254 | 280 | ||
255 | QString line = t.readLine(); | 281 | QString line = t.readLine(); |
256 | 282 | ||
257 | while ( !line.isNull() ) { | 283 | while ( !line.isNull() ) { |
258 | QStringList tokens = QStringList::split( ",", line ); | 284 | QStringList tokens = QStringList::split( ",", line ); |
259 | if ( tokens[0] == "bool" ) { | 285 | if ( tokens[0] == "bool" ) { |
260 | bool value = false; | 286 | bool value = false; |
261 | if ( tokens[2] == "1" ) value = true; | 287 | if ( tokens[2] == "1" ) value = true; |
262 | mBoolMap.insert( tokens[1], value ); | 288 | mBoolMap.insert( tokens[1], value ); |
263 | } else if ( tokens[0] == "QString" ) { | 289 | } else if ( tokens[0] == "QString" ) { |
264 | QString value = tokens[2]; | 290 | QString value = tokens[2]; |
265 | mStringMap.insert( tokens[1], value ); | 291 | mStringMap.insert( tokens[1], value ); |
266 | } else if ( tokens[0] == "QDateTime" ) { | 292 | } else if ( tokens[0] == "QDateTime" ) { |
267 | #if 0 | 293 | #if 0 |
268 | int year = tokens[2].toInt(); | 294 | int year = tokens[2].toInt(); |
269 | QDateTime dt( QDate( year, | 295 | QDateTime dt( QDate( year, |
270 | tokens[3].toInt(), | 296 | tokens[3].toInt(), |
271 | tokens[4].toInt() ), | 297 | tokens[4].toInt() ), |
272 | QTime( tokens[5].toInt(), tokens[6].toInt(), | 298 | QTime( tokens[5].toInt(), tokens[6].toInt(), |
273 | tokens[7].toInt() ) ); | 299 | tokens[7].toInt() ) ); |
274 | mDateTimeMap.insert( tokens[1], dt ); | 300 | mDateTimeMap.insert( tokens[1], dt ); |
275 | #endif | 301 | #endif |
276 | } | 302 | } |
277 | 303 | ||
278 | line = t.readLine(); | 304 | line = t.readLine(); |
279 | } | 305 | } |
280 | } | 306 | } |
281 | 307 | ||
282 | void KConfig::sync() | 308 | void KConfig::sync() |
283 | { | 309 | { |
284 | 310 | ||
285 | if ( !mDirty ) return; | 311 | if ( !mDirty ) return; |
286 | //qDebug("KConfig::sync() %s ",mFileName.latin1() ); | 312 | //qDebug("KConfig::sync() %s ",mFileName.latin1() ); |
287 | //kdDebug() << "KConfig::sync(): " << mFileName << endl; | 313 | //kdDebug() << "KConfig::sync(): " << mFileName << endl; |
288 | 314 | ||
289 | //US I took the following code from a newer version of KDE | 315 | //US I took the following code from a newer version of KDE |
290 | // Create the containing dir if needed | 316 | // Create the containing dir if needed |
291 | KURL path; | 317 | KURL path; |
292 | path.setPath(mFileName); | 318 | path.setPath(mFileName); |
293 | QString dir=path.directory(); | 319 | QString dir=path.directory(); |
294 | KStandardDirs::makeDir(dir); | 320 | KStandardDirs::makeDir(dir); |
295 | 321 | ||
296 | QFile f( mFileName ); | 322 | QFile f( mFileName ); |
297 | if ( !f.open( IO_WriteOnly ) ) { | 323 | if ( !f.open( IO_WriteOnly ) ) { |
298 | 324 | ||
299 | qDebug("KConfig::sync() Can't open file %s ",mFileName.latin1() ); | 325 | qDebug("KConfig::sync() Can't open file %s ",mFileName.latin1() ); |
300 | 326 | ||
301 | return; | 327 | return; |
302 | } | 328 | } |
303 | 329 | ||
304 | QTextStream t( &f ); | 330 | QTextStream t( &f ); |
305 | 331 | ||
306 | QMap<QString,bool>::ConstIterator itBool; | 332 | QMap<QString,bool>::ConstIterator itBool; |
307 | for( itBool = mBoolMap.begin(); itBool != mBoolMap.end(); ++itBool ) { | 333 | for( itBool = mBoolMap.begin(); itBool != mBoolMap.end(); ++itBool ) { |
308 | t << "bool," << itBool.key() << "," << ( *itBool ? "1" : "0" ) << endl; | 334 | t << "bool," << itBool.key() << "," << ( *itBool ? "1" : "0" ) << endl; |
309 | } | 335 | } |
310 | 336 | ||
311 | QMap<QString,QString>::ConstIterator itString; | 337 | QMap<QString,QString>::ConstIterator itString; |
312 | for( itString = mStringMap.begin(); itString != mStringMap.end(); ++itString ) { | 338 | for( itString = mStringMap.begin(); itString != mStringMap.end(); ++itString ) { |
313 | t << "QString," << itString.key() << "," << (*itString ) << endl; | 339 | t << "QString," << itString.key() << "," << (*itString ) << endl; |
314 | } | 340 | } |
315 | 341 | ||
316 | QMap<QString,QDateTime>::ConstIterator itDateTime; | 342 | QMap<QString,QDateTime>::ConstIterator itDateTime; |
317 | for( itDateTime = mDateTimeMap.begin(); itDateTime != mDateTimeMap.end(); ++itDateTime ) { | 343 | for( itDateTime = mDateTimeMap.begin(); itDateTime != mDateTimeMap.end(); ++itDateTime ) { |
318 | QDateTime dt = *itDateTime; | 344 | QDateTime dt = *itDateTime; |
319 | t << "QDateTime," << itDateTime.key() << "," | 345 | t << "QDateTime," << itDateTime.key() << "," |
320 | << dt.date().year() << "," | 346 | << dt.date().year() << "," |
321 | << dt.date().month() << "," | 347 | << dt.date().month() << "," |
322 | << dt.date().day() << "," | 348 | << dt.date().day() << "," |
323 | << dt.time().hour() << "," | 349 | << dt.time().hour() << "," |
324 | << dt.time().minute() << "," | 350 | << dt.time().minute() << "," |
325 | << dt.time().second() << endl; | 351 | << dt.time().second() << endl; |
326 | } | 352 | } |
327 | 353 | ||
328 | f.close(); | 354 | f.close(); |
329 | 355 | ||
330 | mDirty = false; | 356 | mDirty = false; |
331 | } | 357 | } |
332 | 358 | ||
333 | 359 | ||
334 | //US I took the following deleteGroup method from a newer version from KDE. | 360 | //US I took the following deleteGroup method from a newer version from KDE. |
335 | /** | 361 | /** |
336 | * Deletes a configuration entry group | 362 | * Deletes a configuration entry group |
337 | * | 363 | * |
338 | * If the group is not empty and bDeep is false, nothing gets | 364 | * If the group is not empty and bDeep is false, nothing gets |
339 | * deleted and false is returned. | 365 | * deleted and false is returned. |
340 | * If this group is the current group and it is deleted, the | 366 | * If this group is the current group and it is deleted, the |
341 | * current group is undefined and should be set with setGroup() | 367 | * current group is undefined and should be set with setGroup() |
342 | * before the next operation on the configuration object. | 368 | * before the next operation on the configuration object. |
343 | * | 369 | * |
344 | * @param group The name of the group | 370 | * @param group The name of the group |
345 | * returns true if we deleted at least one entry. | 371 | * returns true if we deleted at least one entry. |
346 | */ | 372 | */ |
347 | bool KConfig::deleteGroup( const QString& group) | 373 | bool KConfig::deleteGroup( const QString& group) |
348 | { | 374 | { |
349 | bool dirty = false; | 375 | bool dirty = false; |
350 | int pos; | 376 | int pos; |
351 | 377 | ||
352 | QMap<QString,bool>::Iterator itBool = mBoolMap.begin(); | 378 | QMap<QString,bool>::Iterator itBool = mBoolMap.begin(); |
353 | QMap<QString,bool>::Iterator delBool; | 379 | QMap<QString,bool>::Iterator delBool; |
354 | 380 | ||
355 | while ( itBool != mBoolMap.end() ) { | 381 | while ( itBool != mBoolMap.end() ) { |
356 | pos = itBool.key().find( group ); | 382 | pos = itBool.key().find( group ); |
357 | if (pos == 0) { | 383 | if (pos == 0) { |
358 | delBool = itBool; | 384 | delBool = itBool; |
359 | ++itBool; | 385 | ++itBool; |
360 | mBoolMap.remove(delBool); | 386 | mBoolMap.remove(delBool); |
361 | dirty = true; | 387 | dirty = true; |
362 | } else | 388 | } else |
363 | ++itBool; | 389 | ++itBool; |
364 | 390 | ||
365 | } | 391 | } |
366 | /* | 392 | /* |
367 | for( itBool = mBoolMap.begin(); itBool != mBoolMap.end(); ++itBool ) | 393 | for( itBool = mBoolMap.begin(); itBool != mBoolMap.end(); ++itBool ) |
368 | { | 394 | { |
369 | pos = itBool.key().find( group ); | 395 | pos = itBool.key().find( group ); |
370 | if (pos == 0) { | 396 | if (pos == 0) { |
371 | mBoolMap.remove(itBool); | 397 | mBoolMap.remove(itBool); |
372 | dirty = true; | 398 | dirty = true; |
373 | } | 399 | } |
374 | } | 400 | } |
375 | */ | 401 | */ |
376 | QMap<QString,QString>::Iterator itString = mStringMap.begin(); | 402 | QMap<QString,QString>::Iterator itString = mStringMap.begin(); |
377 | QMap<QString,QString>::Iterator delString ; | 403 | QMap<QString,QString>::Iterator delString ; |
378 | while( itString != mStringMap.end() ) { | 404 | while( itString != mStringMap.end() ) { |
379 | pos = itString.key().find( group ); | 405 | pos = itString.key().find( group ); |
380 | if (pos == 0) { | 406 | if (pos == 0) { |
381 | delString = itString; | 407 | delString = itString; |
382 | ++itString; | 408 | ++itString; |
383 | mStringMap.remove(delString); | 409 | mStringMap.remove(delString); |
384 | //qDebug("delte++++++++++++++++++ "); | 410 | //qDebug("delte++++++++++++++++++ "); |
385 | dirty = true; | 411 | dirty = true; |
386 | } else | 412 | } else |
387 | ++itString; | 413 | ++itString; |
388 | 414 | ||
389 | } | 415 | } |
390 | /* this leads to a memory access violation | 416 | /* this leads to a memory access violation |
391 | for( itString = mStringMap.begin(); itString != mStringMap.end(); ++itString ) | 417 | for( itString = mStringMap.begin(); itString != mStringMap.end(); ++itString ) |
392 | { | 418 | { |
393 | pos = itString.key().find( group ); | 419 | pos = itString.key().find( group ); |
394 | if (pos == 0) { | 420 | if (pos == 0) { |
395 | mStringMap.remove(itString); | 421 | mStringMap.remove(itString); |
396 | dirty = true; | 422 | dirty = true; |
397 | } | 423 | } |
398 | } | 424 | } |
399 | */ | 425 | */ |
400 | QMap<QString,QDateTime>::Iterator itDateTime= mDateTimeMap.begin(); | 426 | QMap<QString,QDateTime>::Iterator itDateTime= mDateTimeMap.begin(); |
401 | QMap<QString,QDateTime>::Iterator delDateTime; | 427 | QMap<QString,QDateTime>::Iterator delDateTime; |
402 | while ( itDateTime != mDateTimeMap.end() ) { | 428 | while ( itDateTime != mDateTimeMap.end() ) { |
403 | pos = itDateTime.key().find( group ); | 429 | pos = itDateTime.key().find( group ); |
404 | if (pos == 0) { | 430 | if (pos == 0) { |
405 | delDateTime = itDateTime; | 431 | delDateTime = itDateTime; |
406 | ++itDateTime; | 432 | ++itDateTime; |
407 | mDateTimeMap.remove(delDateTime); | 433 | mDateTimeMap.remove(delDateTime); |
408 | dirty = true; | 434 | dirty = true; |
409 | } else | 435 | } else |
410 | ++itDateTime; | 436 | ++itDateTime; |
411 | 437 | ||
412 | } | 438 | } |
413 | /* | 439 | /* |
414 | for( itDateTime = mDateTimeMap.begin(); itDateTime != mDateTimeMap.end(); ++itDateTime ) | 440 | for( itDateTime = mDateTimeMap.begin(); itDateTime != mDateTimeMap.end(); ++itDateTime ) |
415 | { | 441 | { |
416 | pos = itDateTime.key().find( group ); | 442 | pos = itDateTime.key().find( group ); |
417 | if (pos == 0) { | 443 | if (pos == 0) { |
418 | mDateTimeMap.remove(itDateTime); | 444 | mDateTimeMap.remove(itDateTime); |
419 | dirty = true; | 445 | dirty = true; |
420 | } | 446 | } |
421 | } | 447 | } |
422 | */ | 448 | */ |
423 | 449 | ||
424 | if (dirty) | 450 | if (dirty) |
425 | mDirty = true; | 451 | mDirty = true; |
426 | 452 | ||
427 | return dirty; | 453 | return dirty; |
428 | 454 | ||
429 | } | 455 | } |
430 | 456 | ||
431 | //US I took the following hasGroup method from a newer version from KDE. | 457 | //US I took the following hasGroup method from a newer version from KDE. |
432 | /** | 458 | /** |
433 | * Returns true if the specified group is known about. | 459 | * Returns true if the specified group is known about. |
434 | * | 460 | * |
435 | * @param group The group to search for. | 461 | * @param group The group to search for. |
436 | * @return Whether the group exists. | 462 | * @return Whether the group exists. |
437 | */ | 463 | */ |
438 | bool KConfig::hasGroup(const QString &group) const | 464 | bool KConfig::hasGroup(const QString &group) const |
439 | { | 465 | { |
440 | QMap<QString,bool>::ConstIterator itBool; | 466 | QMap<QString,bool>::ConstIterator itBool; |
441 | for( itBool = mBoolMap.begin(); itBool != mBoolMap.end(); ++itBool ) | 467 | for( itBool = mBoolMap.begin(); itBool != mBoolMap.end(); ++itBool ) |
442 | { | 468 | { |
443 | if (itBool.key().find( group ) == 0) { | 469 | if (itBool.key().find( group ) == 0) { |
444 | return true; | 470 | return true; |
445 | } | 471 | } |
446 | } | 472 | } |
447 | 473 | ||
448 | QMap<QString,QString>::ConstIterator itString; | 474 | QMap<QString,QString>::ConstIterator itString; |
449 | for( itString = mStringMap.begin(); itString != mStringMap.end(); ++itString ) | 475 | for( itString = mStringMap.begin(); itString != mStringMap.end(); ++itString ) |
450 | { | 476 | { |
451 | if (itString.key().find( group ) == 0) { | 477 | if (itString.key().find( group ) == 0) { |
452 | return true; | 478 | return true; |
453 | } | 479 | } |
454 | } | 480 | } |
455 | 481 | ||
456 | QMap<QString,QDateTime>::ConstIterator itDateTime; | 482 | QMap<QString,QDateTime>::ConstIterator itDateTime; |
457 | for( itDateTime = mDateTimeMap.begin(); itDateTime != mDateTimeMap.end(); ++itDateTime ) | 483 | for( itDateTime = mDateTimeMap.begin(); itDateTime != mDateTimeMap.end(); ++itDateTime ) |
458 | { | 484 | { |
459 | if (itDateTime.key().find( group ) == 0) { | 485 | if (itDateTime.key().find( group ) == 0) { |
460 | return true; | 486 | return true; |
461 | } | 487 | } |
462 | } | 488 | } |
463 | 489 | ||
464 | return false; | 490 | return false; |
465 | } | 491 | } |
466 | 492 | ||
467 | void KConfig::deleteEntry( const QString &key) | 493 | void KConfig::deleteEntry( const QString &key) |
468 | { | 494 | { |
469 | bool dirty = false; | 495 | bool dirty = false; |
470 | 496 | ||
471 | QMap<QString,bool>::Iterator itBool = mBoolMap.find( mGroup + key ); | 497 | QMap<QString,bool>::Iterator itBool = mBoolMap.find( mGroup + key ); |
472 | if ( itBool != mBoolMap.end() ) { | 498 | if ( itBool != mBoolMap.end() ) { |
473 | mBoolMap.remove(itBool); | 499 | mBoolMap.remove(itBool); |
474 | dirty = true; | 500 | dirty = true; |
475 | } | 501 | } |
476 | 502 | ||
477 | 503 | ||
478 | QMap<QString,QString>::Iterator itString = mStringMap.find( mGroup + key ); | 504 | QMap<QString,QString>::Iterator itString = mStringMap.find( mGroup + key ); |
479 | if ( itString != mStringMap.end() ) { | 505 | if ( itString != mStringMap.end() ) { |
480 | mStringMap.remove(itString); | 506 | mStringMap.remove(itString); |
481 | dirty = true; | 507 | dirty = true; |
482 | } | 508 | } |
483 | 509 | ||
484 | 510 | ||
485 | QMap<QString,QDateTime>::Iterator itDateTime = mDateTimeMap.find( mGroup + key ); | 511 | QMap<QString,QDateTime>::Iterator itDateTime = mDateTimeMap.find( mGroup + key ); |
486 | if ( itDateTime != mDateTimeMap.end() ) { | 512 | if ( itDateTime != mDateTimeMap.end() ) { |
487 | mDateTimeMap.remove(itDateTime); | 513 | mDateTimeMap.remove(itDateTime); |
488 | dirty = true; | 514 | dirty = true; |
489 | } | 515 | } |
490 | 516 | ||
491 | if (dirty) | 517 | if (dirty) |
492 | mDirty = true; | 518 | mDirty = true; |
493 | 519 | ||
494 | } | 520 | } |
495 | 521 | ||
496 | //US | 522 | //US |
497 | QString KConfig::getFileName() | 523 | QString KConfig::getFileName() |
498 | { | 524 | { |
499 | return mFileName; | 525 | return mFileName; |
500 | } | 526 | } |
501 | 527 | ||
502 | bool KConfig::hasKey( const QString &key) | 528 | bool KConfig::hasKey( const QString &key) |
503 | { | 529 | { |
504 | QMap<QString,bool>::Iterator itBool = mBoolMap.find( mGroup + key ); | 530 | QMap<QString,bool>::Iterator itBool = mBoolMap.find( mGroup + key ); |
505 | if ( itBool != mBoolMap.end() ) { | 531 | if ( itBool != mBoolMap.end() ) { |
506 | return true; | 532 | return true; |
507 | } | 533 | } |
508 | 534 | ||
509 | QMap<QString,QString>::Iterator itString = mStringMap.find( mGroup + key ); | 535 | QMap<QString,QString>::Iterator itString = mStringMap.find( mGroup + key ); |
510 | if ( itString != mStringMap.end() ) { | 536 | if ( itString != mStringMap.end() ) { |
511 | return true; | 537 | return true; |
512 | } | 538 | } |
513 | 539 | ||
514 | QMap<QString,QDateTime>::Iterator itDateTime = mDateTimeMap.find( mGroup + key ); | 540 | QMap<QString,QDateTime>::Iterator itDateTime = mDateTimeMap.find( mGroup + key ); |
515 | if ( itDateTime != mDateTimeMap.end() ) { | 541 | if ( itDateTime != mDateTimeMap.end() ) { |
516 | return true; | 542 | return true; |
517 | } | 543 | } |
518 | 544 | ||
519 | return false; | 545 | return false; |
520 | } | 546 | } |
521 | 547 | ||