summaryrefslogtreecommitdiff
authorbrad <brad>2004-04-12 07:01:55 (UTC)
committer brad <brad>2004-04-12 07:01:55 (UTC)
commit2c087dc52d50eb9b13670254f70347d7b1147b20 (patch) (unidiff)
tree79814aa2618a6a512a0e669ba2b6829ca13b7bdd
parent66f497a5c7990d7e54cc1ae26995231ade55b86c (diff)
downloadopie-2c087dc52d50eb9b13670254f70347d7b1147b20.zip
opie-2c087dc52d50eb9b13670254f70347d7b1147b20.tar.gz
opie-2c087dc52d50eb9b13670254f70347d7b1147b20.tar.bz2
Changed launcher to only add/remove icons/tabs that have changed when removable
media is mounted/unmounted. A card insert on my machine used to take 7500ms. It now takes 548ms. Same with card removal. Old code has been left as is an can be re-enabled with a simple comment.
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/documentlist.cpp92
-rw-r--r--core/launcher/documentlist.h1
2 files changed, 91 insertions, 2 deletions
diff --git a/core/launcher/documentlist.cpp b/core/launcher/documentlist.cpp
index 92b8c25..59dd721 100644
--- a/core/launcher/documentlist.cpp
+++ b/core/launcher/documentlist.cpp
@@ -140,390 +140,478 @@ void DocumentList::start()
140 resume(); 140 resume();
141} 141}
142 142
143 143
144void DocumentList::pause() 144void DocumentList::pause()
145{ 145{
146 //odebug << "pause " << d->tid << "" << oendl; 146 //odebug << "pause " << d->tid << "" << oendl;
147 killTimer( d->tid ); 147 killTimer( d->tid );
148 d->tid = 0; 148 d->tid = 0;
149} 149}
150 150
151 151
152void DocumentList::resume() 152void DocumentList::resume()
153{ 153{
154 if ( d->tid == 0 ) { 154 if ( d->tid == 0 ) {
155 d->tid = startTimer( 20 ); 155 d->tid = startTimer( 20 );
156 //odebug << "resumed " << d->tid << "" << oendl; 156 //odebug << "resumed " << d->tid << "" << oendl;
157 } 157 }
158} 158}
159 159
160/* 160/*
161void DocumentList::resend() 161void DocumentList::resend()
162{ 162{
163 // Re-emits all the added items to the list (firstly letting everyone know to 163 // Re-emits all the added items to the list (firstly letting everyone know to
164 // clear what they have as it is being sent again) 164 // clear what they have as it is being sent again)
165 pause(); 165 pause();
166 emit allRemoved(); 166 emit allRemoved();
167 QTimer::singleShot( 5, this, SLOT( resendWorker() ) ); 167 QTimer::singleShot( 5, this, SLOT( resendWorker() ) );
168} 168}
169 169
170 170
171void DocumentList::resendWorker() 171void DocumentList::resendWorker()
172{ 172{
173 const QList<DocLnk> &list = d->dls.children(); 173 const QList<DocLnk> &list = d->dls.children();
174 for ( QListIterator<DocLnk> it( list ); it.current(); ++it ) 174 for ( QListIterator<DocLnk> it( list ); it.current(); ++it )
175 add( *(*it) ); 175 add( *(*it) );
176 resume(); 176 resume();
177} 177}
178*/ 178*/
179 179
180void DocumentList::rescan() 180void DocumentList::rescan()
181{ 181{
182 //odebug << "rescan" << oendl; 182 //odebug << "rescan" << oendl;
183 pause(); 183 pause();
184 d->initialize(); 184 d->initialize();
185 resume(); 185 resume();
186} 186}
187 187
188 188
189void DocumentList::timerEvent( QTimerEvent *te ) 189void DocumentList::timerEvent( QTimerEvent *te )
190{ 190{
191 if ( te->timerId() == d->tid ) { 191 if ( te->timerId() == d->tid ) {
192 // Do 3 at a time 192 // Do 3 at a time
193 for (int i = 0; i < 3; i++ ) { 193 for (int i = 0; i < 3; i++ ) {
194 const DocLnk *lnk = d->iterate(); 194 const DocLnk *lnk = d->iterate();
195 if ( lnk ) { 195 if ( lnk ) {
196 add( *lnk ); 196 add( *lnk );
197 } else { 197 } else {
198 // stop when done 198 // stop when done
199 pause(); 199 pause();
200 if ( d->serverGui ) 200 if ( d->serverGui )
201 d->serverGui->documentScanningProgress( 100 ); 201 d->serverGui->documentScanningProgress( 100 );
202 if ( d->needToSendAllDocLinks ) 202 if ( d->needToSendAllDocLinks )
203 sendAllDocLinks(); 203 sendAllDocLinks();
204 break; 204 break;
205 } 205 }
206 } 206 }
207 } 207 }
208} 208}
209 209
210 210
211void DocumentList::reloadAppLnks() 211void DocumentList::reloadAppLnks()
212{ 212{
213 if ( d->sendAppLnks && d->serverGui ) { 213 if ( d->sendAppLnks && d->serverGui ) {
214 d->serverGui->applicationScanningProgress( 0 ); 214 d->serverGui->applicationScanningProgress( 0 );
215 d->serverGui->allApplicationsRemoved(); 215 d->serverGui->allApplicationsRemoved();
216 } 216 }
217 217
218 delete appLnkSet; 218 delete appLnkSet;
219 appLnkSet = new AppLnkSet( MimeType::appsFolderName() ); 219 appLnkSet = new AppLnkSet( MimeType::appsFolderName() );
220 220
221 if ( d->sendAppLnks && d->serverGui ) { 221 if ( d->sendAppLnks && d->serverGui ) {
222 static QStringList prevTypeList; 222 static QStringList prevTypeList;
223 QStringList types = appLnkSet->types(); 223 QStringList types = appLnkSet->types();
224 for ( QStringList::Iterator ittypes=types.begin(); ittypes!=types.end(); ++ittypes) { 224 for ( QStringList::Iterator ittypes=types.begin(); ittypes!=types.end(); ++ittypes) {
225 if ( !(*ittypes).isEmpty() ) { 225 if ( !(*ittypes).isEmpty() ) {
226 if ( !prevTypeList.contains(*ittypes) ) { 226 if ( !prevTypeList.contains(*ittypes) ) {
227 QString name = appLnkSet->typeName(*ittypes); 227 QString name = appLnkSet->typeName(*ittypes);
228 QPixmap pm = appLnkSet->typePixmap(*ittypes); 228 QPixmap pm = appLnkSet->typePixmap(*ittypes);
229 QPixmap bgPm = appLnkSet->typeBigPixmap(*ittypes); 229 QPixmap bgPm = appLnkSet->typeBigPixmap(*ittypes);
230 230
231 if (pm.isNull()) { 231 if (pm.isNull()) {
232 QImage img( Resource::loadImage( "UnknownDocument" ) ); 232 QImage img( Resource::loadImage( "UnknownDocument" ) );
233 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); 233 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() );
234 bgPm = img.smoothScale( AppLnk::bigIconSize(), AppLnk::bigIconSize() ); 234 bgPm = img.smoothScale( AppLnk::bigIconSize(), AppLnk::bigIconSize() );
235 } 235 }
236 236
237 //odebug << "adding type " << (*ittypes) << "" << oendl; 237 //odebug << "adding type " << (*ittypes) << "" << oendl;
238 238
239 // ### our current launcher expects docs tab to be last 239 // ### our current launcher expects docs tab to be last
240 d->serverGui->typeAdded( *ittypes, name.isNull() ? (*ittypes) : name, pm, bgPm ); 240 d->serverGui->typeAdded( *ittypes, name.isNull() ? (*ittypes) : name, pm, bgPm );
241 } 241 }
242 prevTypeList.remove(*ittypes); 242 prevTypeList.remove(*ittypes);
243 } 243 }
244 } 244 }
245 for ( QStringList::Iterator ittypes=prevTypeList.begin(); ittypes!=prevTypeList.end(); ++ittypes) { 245 for ( QStringList::Iterator ittypes=prevTypeList.begin(); ittypes!=prevTypeList.end(); ++ittypes) {
246 //odebug << "removing type " << (*ittypes) << "" << oendl; 246 //odebug << "removing type " << (*ittypes) << "" << oendl;
247 d->serverGui->typeRemoved(*ittypes); 247 d->serverGui->typeRemoved(*ittypes);
248 } 248 }
249 prevTypeList = types; 249 prevTypeList = types;
250 } 250 }
251 251
252 QListIterator<AppLnk> itapp( appLnkSet->children() ); 252 QListIterator<AppLnk> itapp( appLnkSet->children() );
253 AppLnk* l; 253 AppLnk* l;
254 while ( (l=itapp.current()) ) { 254 while ( (l=itapp.current()) ) {
255 ++itapp; 255 ++itapp;
256 if ( d->sendAppLnks && d->serverGui ) 256 if ( d->sendAppLnks && d->serverGui )
257 d->serverGui->applicationAdded( l->type(), *l ); 257 d->serverGui->applicationAdded( l->type(), *l );
258 } 258 }
259 259
260 if ( d->sendAppLnks && d->serverGui ) 260 if ( d->sendAppLnks && d->serverGui )
261 d->serverGui->applicationScanningProgress( 100 ); 261 d->serverGui->applicationScanningProgress( 100 );
262} 262}
263 263
264void DocumentList::reloadDocLnks() 264void DocumentList::reloadDocLnks()
265{ 265{
266 if ( !d->scanDocs ) 266 if ( !d->scanDocs )
267 return; 267 return;
268 268
269 if ( d->sendDocLnks && d->serverGui ) { 269 if ( d->sendDocLnks && d->serverGui ) {
270 d->serverGui->documentScanningProgress( 0 ); 270 d->serverGui->documentScanningProgress( 0 );
271 d->serverGui->allDocumentsRemoved(); 271 d->serverGui->allDocumentsRemoved();
272 } 272 }
273 273
274 rescan(); 274 rescan();
275} 275}
276 276
277void DocumentList::linkChanged( QString arg ) 277void DocumentList::linkChanged( QString arg )
278{ 278{
279 //odebug << "linkchanged( " << arg << " )" << oendl; 279 //odebug << "linkchanged( " << arg << " )" << oendl;
280 280
281 if ( arg.isNull() || OGlobal::isAppLnkFileName( arg ) ) { 281 if ( arg.isNull() || OGlobal::isAppLnkFileName( arg ) ) {
282 reloadAppLnks(); 282 reloadAppLnks();
283 } else { 283 } else {
284 284
285 const QList<DocLnk> &list = d->dls.children(); 285 const QList<DocLnk> &list = d->dls.children();
286 QListIterator<DocLnk> it( list ); 286 QListIterator<DocLnk> it( list );
287 while ( it.current() ) { 287 while ( it.current() ) {
288 DocLnk *doc = it.current(); 288 DocLnk *doc = it.current();
289 ++it; 289 ++it;
290 if ( ( doc->linkFileKnown() && doc->linkFile() == arg ) 290 if ( ( doc->linkFileKnown() && doc->linkFile() == arg )
291 || ( doc->fileKnown() && doc->file() == arg ) ) { 291 || ( doc->fileKnown() && doc->file() == arg ) ) {
292 //odebug << "found old link" << oendl; 292 //odebug << "found old link" << oendl;
293 DocLnk* dl = new DocLnk( arg ); 293 DocLnk* dl = new DocLnk( arg );
294 // add new one if it exists and matches the mimetype 294 // add new one if it exists and matches the mimetype
295 if ( d->store( dl ) ) { 295 if ( d->store( dl ) ) {
296 // Existing link has been changed, send old link ref and a ref 296 // Existing link has been changed, send old link ref and a ref
297 // to the new link 297 // to the new link
298 //odebug << "change case" << oendl; 298 //odebug << "change case" << oendl;
299 if ( d->serverGui ) 299 if ( d->serverGui )
300 d->serverGui->documentChanged( *doc, *dl ); 300 d->serverGui->documentChanged( *doc, *dl );
301 301
302 } else { 302 } else {
303 // Link has been removed or doesn't match the mimetypes any more 303 // Link has been removed or doesn't match the mimetypes any more
304 // so we aren't interested in it, so take it away from the list 304 // so we aren't interested in it, so take it away from the list
305 //odebug << "removal case" << oendl; 305 //odebug << "removal case" << oendl;
306 if ( d->serverGui ) 306 if ( d->serverGui )
307 d->serverGui->documentRemoved( *doc ); 307 d->serverGui->documentRemoved( *doc );
308 308
309 } 309 }
310 d->dls.remove( doc ); // remove old link from docLnkSet 310 d->dls.remove( doc ); // remove old link from docLnkSet
311 delete doc; 311 delete doc;
312 return; 312 return;
313 } 313 }
314 } 314 }
315 // Didn't find existing link, must be new 315 // Didn't find existing link, must be new
316 DocLnk* dl = new DocLnk( arg ); 316 DocLnk* dl = new DocLnk( arg );
317 if ( d->store( dl ) ) { 317 if ( d->store( dl ) ) {
318 // Add if it's a link we are interested in 318 // Add if it's a link we are interested in
319 //odebug << "add case" << oendl; 319 //odebug << "add case" << oendl;
320 add( *dl ); 320 add( *dl );
321 } 321 }
322 322
323 } 323 }
324} 324}
325 325
326void DocumentList::restoreDone() 326void DocumentList::restoreDone()
327{ 327{
328 reloadAppLnks(); 328 reloadAppLnks();
329 reloadDocLnks(); 329 reloadDocLnks();
330} 330}
331 331
332void DocumentList::DiffAppLnks()
333{
334 static AppLnkSet *appLnkSet2;
335
336 appLnkSet2 = new AppLnkSet( MimeType::appsFolderName() );
337
338 if ( d->sendAppLnks && d->serverGui ) {
339 static QStringList prevTypeList = appLnkSet->types();
340 QStringList types = appLnkSet2->types();
341 for ( QStringList::Iterator ittypes=types.begin(); ittypes!=types.end(); ++ittypes) {
342 if ( !(*ittypes).isEmpty() ) {
343 if ( !prevTypeList.contains(*ittypes) ) {
344 QString name = appLnkSet2->typeName(*ittypes);
345 QPixmap pm = appLnkSet2->typePixmap(*ittypes);
346 QPixmap bgPm = appLnkSet2->typeBigPixmap(*ittypes);
347
348 if (pm.isNull()) {
349 QImage img( Resource::loadImage( "UnknownDocument" ) );
350 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() );
351 bgPm = img.smoothScale( AppLnk::bigIconSize(), AppLnk::bigIconSize() );
352 }
353
354 odebug << "adding type " << (*ittypes) << "" << oendl;
355
356 // ### our current launcher expects docs tab to be last
357 d->serverGui->typeAdded( *ittypes, name.isNull() ? (*ittypes) : name, pm, bgPm );
358 }
359 prevTypeList.remove(*ittypes);
360 }
361 }
362 for ( QStringList::Iterator ittypes=prevTypeList.begin(); ittypes!=prevTypeList.end(); ++ittypes) {
363 odebug << "removing type " << (*ittypes) << "" << oendl;
364 d->serverGui->typeRemoved(*ittypes);
365 }
366 prevTypeList = types;
367 }
368
369
370 QListIterator<AppLnk> it1( appLnkSet->children() );
371 QListIterator<AppLnk> it2( appLnkSet2->children() );
372
373 AppLnk *i;
374 AppLnk *j;
375 bool found;
376
377 while ( (j=it2.current()) ) {
378 it1 = appLnkSet->children();
379 found = false;
380 while ( (i=it1.current()) ){
381 if (strcmp(i->name().ascii(),j->name().ascii()) == 0)
382 found = true;
383 ++it1;
384 }
385 if (!found) {
386 qDebug("Item %s needs to be added",j->name().ascii() );
387 d->serverGui->applicationAdded( j->type(), *j );
388 }
389 ++it2;
390 }
391
392 it1 = appLnkSet->children();
393 while ( (i=it1.current()) ) {
394 it2 = appLnkSet2->children();
395 found = false;
396 while ( (j=it2.current()) ){
397 if (strcmp(i->name().ascii(),j->name().ascii()) == 0)
398 found = true;
399 ++it2;
400 }
401 if (!found) {
402 qDebug("Item %s needs to be removed",i->name().ascii() );
403 d->serverGui->applicationRemoved( i->type(), *i );
404 }
405
406 ++it1;
407 }
408
409 delete appLnkSet;
410 appLnkSet = appLnkSet2;
411
412}
332void DocumentList::storageChanged() 413void DocumentList::storageChanged()
333{ 414{
415 QTime t;
334 // ### can implement better 416 // ### can implement better
335 reloadAppLnks(); 417
418 t.start();
419 DiffAppLnks();
420// reloadAppLnks();
421 qDebug("Reload App links took %i ms",t.elapsed() );
336 reloadDocLnks(); 422 reloadDocLnks();
337 // ### Optimization opportunity 423// odebug << "Reload links took " << t.elapsed() << " ms " << oendl;
424 qDebug("Reload All links took %i ms",t.elapsed() );
425// ### Optimization opportunity
338 // Could be a bit more intelligent and somehow work out which 426 // Could be a bit more intelligent and somehow work out which
339 // mtab entry has changed and then only scan that and add and remove 427 // mtab entry has changed and then only scan that and add and remove
340 // links appropriately. 428 // links appropriately.
341// rescan(); 429// rescan();
342} 430}
343 431
344void DocumentList::sendAllDocLinks() 432void DocumentList::sendAllDocLinks()
345{ 433{
346 if ( d->tid != 0 ) { 434 if ( d->tid != 0 ) {
347 // We are in the middle of scanning, set a flag so 435 // We are in the middle of scanning, set a flag so
348 // we do this when we finish our scanning 436 // we do this when we finish our scanning
349 d->needToSendAllDocLinks = true; 437 d->needToSendAllDocLinks = true;
350 return; 438 return;
351 } 439 }
352 440
353 QString contents; 441 QString contents;
354 Categories cats; 442 Categories cats;
355 for ( QListIterator<DocLnk> it( d->dls.children() ); it.current(); ++it ) { 443 for ( QListIterator<DocLnk> it( d->dls.children() ); it.current(); ++it ) {
356 DocLnk *doc = it.current(); 444 DocLnk *doc = it.current();
357 QFileInfo fi( doc->file() ); 445 QFileInfo fi( doc->file() );
358 if ( !fi.exists() ) 446 if ( !fi.exists() )
359 continue; 447 continue;
360 448
361 bool fake = !doc->linkFileKnown(); 449 bool fake = !doc->linkFileKnown();
362 if ( !fake ) { 450 if ( !fake ) {
363 QFile f( doc->linkFile() ); 451 QFile f( doc->linkFile() );
364 if ( f.open( IO_ReadOnly ) ) { 452 if ( f.open( IO_ReadOnly ) ) {
365 QTextStream ts( &f ); 453 QTextStream ts( &f );
366 ts.setEncoding( QTextStream::UnicodeUTF8 ); 454 ts.setEncoding( QTextStream::UnicodeUTF8 );
367 contents += ts.read(); 455 contents += ts.read();
368 f.close(); 456 f.close();
369 } else 457 } else
370 fake = TRUE; 458 fake = TRUE;
371 } 459 }
372 if (fake) { 460 if (fake) {
373 contents += "[Desktop Entry]\n"; // No tr 461 contents += "[Desktop Entry]\n"; // No tr
374 contents += "Categories = " + // No tr 462 contents += "Categories = " + // No tr
375 cats.labels("Document View",doc->categories()).join(";") + "\n"; // No tr 463 cats.labels("Document View",doc->categories()).join(";") + "\n"; // No tr
376 contents += "Name = "+doc->name()+"\n"; // No tr 464 contents += "Name = "+doc->name()+"\n"; // No tr
377 contents += "Type = "+doc->type()+"\n"; // No tr 465 contents += "Type = "+doc->type()+"\n"; // No tr
378 } 466 }
379 contents += "File = "+doc->file()+"\n"; // No tr // (resolves path) 467 contents += "File = "+doc->file()+"\n"; // No tr // (resolves path)
380 contents += QString("Size = %1\n").arg( fi.size() ); // No tr 468 contents += QString("Size = %1\n").arg( fi.size() ); // No tr
381 } 469 }
382 470
383 //odebug << "sending length " << contents.length() << "" << oendl; 471 //odebug << "sending length " << contents.length() << "" << oendl;
384#ifndef QT_NO_COP 472#ifndef QT_NO_COP
385 QCopEnvelope e( "QPE/Desktop", "docLinks(QString)" ); 473 QCopEnvelope e( "QPE/Desktop", "docLinks(QString)" );
386 e << contents; 474 e << contents;
387#endif 475#endif
388 //odebug << "================ \n\n" << contents << "\n\n===============" << oendl; 476 //odebug << "================ \n\n" << contents << "\n\n===============" << oendl;
389 477
390 d->needToSendAllDocLinks = false; 478 d->needToSendAllDocLinks = false;
391} 479}
392 480
393 481
394 482
395 483
396 484
397 485
398 486
399 487
400 488
401 489
402 490
403 491
404 492
405 493
406 494
407 495
408 496
409 497
410 498
411 499
412 500
413 501
414 502
415 503
416DocumentListPrivate::DocumentListPrivate( ServerInterface *gui ) 504DocumentListPrivate::DocumentListPrivate( ServerInterface *gui )
417{ 505{
418 storage = new StorageInfo( this ); 506 storage = new StorageInfo( this );
419 serverGui = gui; 507 serverGui = gui;
420 if ( serverGui ) { 508 if ( serverGui ) {
421 sendAppLnks = serverGui->requiresApplications(); 509 sendAppLnks = serverGui->requiresApplications();
422 sendDocLnks = serverGui->requiresDocuments(); 510 sendDocLnks = serverGui->requiresDocuments();
423 } else { 511 } else {
424 sendAppLnks = false; 512 sendAppLnks = false;
425 sendDocLnks = false; 513 sendDocLnks = false;
426 } 514 }
427 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ ) { 515 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ ) {
428 listDirs[i] = 0; 516 listDirs[i] = 0;
429 lists[i] = 0; 517 lists[i] = 0;
430 listPositions[i] = 0; 518 listPositions[i] = 0;
431 } 519 }
432 initialize(); 520 initialize();
433 tid = 0; 521 tid = 0;
434} 522}
435 523
436void DocumentListPrivate::appendDocpath(FileSystem*fs) 524void DocumentListPrivate::appendDocpath(FileSystem*fs)
437{ 525{
438 QDir defPath(fs->path()+"/Documents"); 526 QDir defPath(fs->path()+"/Documents");
439 QFileInfo f(fs->path()+"/.opiestorage.cf"); 527 QFileInfo f(fs->path()+"/.opiestorage.cf");
440 if (!f.exists()) { 528 if (!f.exists()) {
441 Mediadlg dlg(fs); 529 Mediadlg dlg(fs);
442 if (QDialog::Accepted != QPEApplication::execDialog( &dlg )) { 530 if (QDialog::Accepted != QPEApplication::execDialog( &dlg )) {
443 return; 531 return;
444 } 532 }
445 } 533 }
446 Config conf(f.filePath(), Config::File ); 534 Config conf(f.filePath(), Config::File );
447 conf.setGroup("main"); 535 conf.setGroup("main");
448 if (!conf.readBoolEntry("check",false)) { 536 if (!conf.readBoolEntry("check",false)) {
449 return; 537 return;
450 } 538 }
451 conf.setGroup("subdirs"); 539 conf.setGroup("subdirs");
452 bool read_all = conf.readBoolEntry("wholemedia",true); 540 bool read_all = conf.readBoolEntry("wholemedia",true);
453 if (read_all) { 541 if (read_all) {
454 docPaths+=fs->path(); 542 docPaths+=fs->path();
455 return; 543 return;
456 } 544 }
457 QStringList subDirs = conf.readListEntry("subdirs",':'); 545 QStringList subDirs = conf.readListEntry("subdirs",':');
458 if (subDirs.isEmpty()) { 546 if (subDirs.isEmpty()) {
459 if (defPath.exists()) { 547 if (defPath.exists()) {
460 docPaths+=defPath.path(); 548 docPaths+=defPath.path();
461 } 549 }
462 return; 550 return;
463 } 551 }
464 for (unsigned c = 0; c < subDirs.count();++c) { 552 for (unsigned c = 0; c < subDirs.count();++c) {
465 QDir docDir(QString(fs->path()+"/"+subDirs[c])); 553 QDir docDir(QString(fs->path()+"/"+subDirs[c]));
466 if (docDir.exists()) { 554 if (docDir.exists()) {
467 docPaths+=docDir.path(); 555 docPaths+=docDir.path();
468 } 556 }
469 } 557 }
470} 558}
471 559
472void DocumentListPrivate::initialize() 560void DocumentListPrivate::initialize()
473{ 561{
474 // Reset 562 // Reset
475 dls.clear(); 563 dls.clear();
476 docPaths.clear(); 564 docPaths.clear();
477 reference.clear(); 565 reference.clear();
478 566
479 QDir docDir( QPEApplication::documentDir() ); 567 QDir docDir( QPEApplication::documentDir() );
480 if ( docDir.exists() ) 568 if ( docDir.exists() )
481 docPaths += QPEApplication::documentDir(); 569 docPaths += QPEApplication::documentDir();
482 int i = 1; 570 int i = 1;
483 const QList<FileSystem> &fs = storage->fileSystems(); 571 const QList<FileSystem> &fs = storage->fileSystems();
484 QListIterator<FileSystem> it( fs ); 572 QListIterator<FileSystem> it( fs );
485 for ( ; it.current(); ++it ) { 573 for ( ; it.current(); ++it ) {
486 if ( (*it)->isRemovable() ) { 574 if ( (*it)->isRemovable() ) {
487 appendDocpath((*it)); 575 appendDocpath((*it));
488 ++i; 576 ++i;
489 } 577 }
490 } 578 }
491 579
492 for ( int i = 0; i < MAX_SEARCH_DEPTH; ++i ) { 580 for ( int i = 0; i < MAX_SEARCH_DEPTH; ++i ) {
493 if ( listDirs[i] ) { 581 if ( listDirs[i] ) {
494 delete listDirs[i]; 582 delete listDirs[i];
495 listDirs[i] = 0; 583 listDirs[i] = 0;
496 } 584 }
497 lists[i] = 0; 585 lists[i] = 0;
498 listPositions[i] = 0; 586 listPositions[i] = 0;
499 } 587 }
500 588
501 docPathsSearched = 0; 589 docPathsSearched = 0;
502 searchDepth = -1; 590 searchDepth = -1;
503 state = Find; 591 state = Find;
504 dit = 0; 592 dit = 0;
505} 593}
506 594
507 595
508DocumentListPrivate::~DocumentListPrivate() 596DocumentListPrivate::~DocumentListPrivate()
509{ 597{
510 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ ) 598 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ )
511 if ( listDirs[i] ) 599 if ( listDirs[i] )
512 delete listDirs[i]; 600 delete listDirs[i];
513 delete dit; 601 delete dit;
514} 602}
515 603
516 604
517void DocumentListPrivate::estimatedPercentScanned() 605void DocumentListPrivate::estimatedPercentScanned()
518{ 606{
519 double overallProgress = 0.0; 607 double overallProgress = 0.0;
520 double levelWeight = 75.0; 608 double levelWeight = 75.0;
521 609
522 int topCount = docPaths.count(); 610 int topCount = docPaths.count();
523 if ( topCount > 1 ) { 611 if ( topCount > 1 ) {
524 levelWeight = levelWeight / topCount; 612 levelWeight = levelWeight / topCount;
525 overallProgress += (docPathsSearched - 1) * levelWeight; 613 overallProgress += (docPathsSearched - 1) * levelWeight;
526 } 614 }
527 615
528 for ( int d = 0; d <= searchDepth; d++ ) { 616 for ( int d = 0; d <= searchDepth; d++ ) {
529 if ( listDirs[d] ) { 617 if ( listDirs[d] ) {
diff --git a/core/launcher/documentlist.h b/core/launcher/documentlist.h
index bd5c031..232bb6a 100644
--- a/core/launcher/documentlist.h
+++ b/core/launcher/documentlist.h
@@ -1,77 +1,78 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of the Qtopia Environment. 4** This file is part of the Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef DOCUMENT_LIST_H 20#ifndef DOCUMENT_LIST_H
21#define DOCUMENT_LIST_H 21#define DOCUMENT_LIST_H
22 22
23 23
24#include <qobject.h> 24#include <qobject.h>
25#include <qtopia/applnk.h> 25#include <qtopia/applnk.h>
26 26
27 27
28class DocumentListPrivate; 28class DocumentListPrivate;
29class ServerInterface; 29class ServerInterface;
30 30
31class DocumentList : public QObject { 31class DocumentList : public QObject {
32 Q_OBJECT 32 Q_OBJECT
33public: 33public:
34 DocumentList( ServerInterface *serverGui, bool scanDocs = TRUE, 34 DocumentList( ServerInterface *serverGui, bool scanDocs = TRUE,
35 QObject *parent = 0, const char *name = 0 ); 35 QObject *parent = 0, const char *name = 0 );
36 ~DocumentList(); 36 ~DocumentList();
37 37
38 void linkChanged( QString link ); 38 void linkChanged( QString link );
39 void restoreDone(); 39 void restoreDone();
40 void storageChanged(); 40 void storageChanged();
41 void sendAllDocLinks(); 41 void sendAllDocLinks();
42 42
43 void reloadAppLnks(); 43 void reloadAppLnks();
44 void reloadDocLnks(); 44 void reloadDocLnks();
45 void DiffAppLnks();
45 46
46// Orig DocList stuff 47// Orig DocList stuff
47 void start(); 48 void start();
48 void pause(); 49 void pause();
49 void resume(); 50 void resume();
50 void rescan(); 51 void rescan();
51 52
52 static AppLnkSet *appLnkSet; 53 static AppLnkSet *appLnkSet;
53 54
54/* 55/*
55 void resend(); 56 void resend();
56signals: 57signals:
57 void added( const DocLnk& doc ); 58 void added( const DocLnk& doc );
58 void removed( const DocLnk& doc ); 59 void removed( const DocLnk& doc );
59 void changed( const DocLnk& oldDoc, const DocLnk& newDoc ); 60 void changed( const DocLnk& oldDoc, const DocLnk& newDoc );
60 void allRemoved(); 61 void allRemoved();
61 void doneForNow(); 62 void doneForNow();
62private slots: 63private slots:
63 void resendWorker(); 64 void resendWorker();
64*/ 65*/
65private slots: 66private slots:
66 void startInitialScan(); 67 void startInitialScan();
67protected: 68protected:
68 void timerEvent( QTimerEvent *te ); 69 void timerEvent( QTimerEvent *te );
69private: 70private:
70 void add( const DocLnk& doc ); 71 void add( const DocLnk& doc );
71 DocumentListPrivate *d; 72 DocumentListPrivate *d;
72 73
73}; 74};
74 75
75 76
76#endif 77#endif
77 78