summaryrefslogtreecommitdiff
authorzecke <zecke>2002-03-24 19:30:27 (UTC)
committer zecke <zecke>2002-03-24 19:30:27 (UTC)
commit4802684dd785274be50b472c87e315da0e325449 (patch) (unidiff)
treee15bb479f443d5ce410ccbd9368e663213210517
parent6ce8bbff9eb16e0d731755010bda63e7fb43f70b (diff)
downloadopie-4802684dd785274be50b472c87e315da0e325449.zip
opie-4802684dd785274be50b472c87e315da0e325449.tar.gz
opie-4802684dd785274be50b472c87e315da0e325449.tar.bz2
Hija this adds the "Do you want to scan this device?"
to launcher and should speed up some things. Please test launcher and report bugs to me
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/launcher.cpp84
-rw-r--r--core/launcher/mediummountgui.cpp10
2 files changed, 66 insertions, 28 deletions
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp
index 1c38a05..cf1a3c8 100644
--- a/core/launcher/launcher.cpp
+++ b/core/launcher/launcher.cpp
@@ -15,128 +15,159 @@
15** See http://www.trolltech.com/gpl/ for GPL licensing information. 15** See http://www.trolltech.com/gpl/ for GPL licensing information.
16** 16**
17** Contact info@trolltech.com if any conditions of this licensing are 17** Contact info@trolltech.com if any conditions of this licensing are
18** not clear to you. 18** not clear to you.
19** 19**
20**********************************************************************/ 20**********************************************************************/
21 21
22// WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT 22// WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT
23// have this class. 23// have this class.
24#define QTOPIA_INTERNAL_FSLP 24#define QTOPIA_INTERNAL_FSLP
25 25
26#include <opie/oconfig.h> 26#include <opie/oconfig.h>
27#include <qpe/qcopenvelope_qws.h> 27#include <qpe/qcopenvelope_qws.h>
28#include <qpe/resource.h> 28#include <qpe/resource.h>
29#include <qpe/applnk.h> 29#include <qpe/applnk.h>
30#include <qpe/config.h> 30#include <qpe/config.h>
31#include <qpe/global.h> 31#include <qpe/global.h>
32#include <qpe/qpeapplication.h> 32#include <qpe/qpeapplication.h>
33#include <qpe/mimetype.h> 33#include <qpe/mimetype.h>
34#include <qpe/storage.h> 34#include <qpe/storage.h>
35#include <qpe/palmtoprecord.h> 35#include <qpe/palmtoprecord.h>
36 36
37#include <qdatetime.h> 37#include <qdatetime.h>
38#include <qdir.h> 38#include <qdir.h>
39#include <qwindowsystem_qws.h> 39#include <qwindowsystem_qws.h>
40#include <qtimer.h> 40#include <qtimer.h>
41#include <qcombobox.h> 41#include <qcombobox.h>
42#include <qvbox.h> 42#include <qvbox.h>
43#include <qlayout.h> 43#include <qlayout.h>
44#include <qstyle.h> 44#include <qstyle.h>
45#include <qpushbutton.h> 45#include <qpushbutton.h>
46#include <qtabbar.h> 46#include <qtabbar.h>
47#include <qwidgetstack.h> 47#include <qwidgetstack.h>
48#include <qlayout.h> 48#include <qlayout.h>
49#include <qregexp.h> 49#include <qregexp.h>
50#include <qmessagebox.h> 50#include <qmessagebox.h>
51#include <qframe.h> 51#include <qframe.h>
52#include <qpainter.h> 52#include <qpainter.h>
53#include <qlabel.h> 53#include <qlabel.h>
54#include <qtextstream.h> 54#include <qtextstream.h>
55 55
56#include "launcherview.h" 56#include "launcherview.h"
57#include "launcher.h" 57#include "launcher.h"
58#include "syncdialog.h" 58#include "syncdialog.h"
59#include "desktop.h" 59#include "desktop.h"
60#include <qpe/lnkproperties.h> 60#include <qpe/lnkproperties.h>
61#include "mrulist.h" 61#include "mrulist.h"
62#include "qrsync.h" 62#include "qrsync.h"
63#include <stdlib.h> 63#include <stdlib.h>
64#include <unistd.h> 64#include <unistd.h>
65 65
66#if defined(_OS_LINUX_) || defined(Q_OS_LINUX) 66#if defined(_OS_LINUX_) || defined(Q_OS_LINUX)
67#include <stdio.h> 67#include <stdio.h>
68#include <sys/vfs.h> 68#include <sys/vfs.h>
69#include <mntent.h> 69#include <mntent.h>
70#endif 70#endif
71 71
72#include <qpe/storage.h> 72#include <qpe/storage.h>
73#include "mediummountgui.h" 73#include "mediummountgui.h"
74//#define SHOW_ALL 74//#define SHOW_ALL
75 75
76// uidGen 76// uidGen
77 77
78// uidGen 78// uidGen
79namespace {
80 QStringList configToMime( Config *cfg ){
81 QStringList mimes;
82 bool tmpMime;
83 cfg->setGroup("mimetypes" );
84 tmpMime = cfg->readBoolEntry("all" ,false);
85 if( tmpMime ){
86 mimes << QString::null;
87 return mimes;
88 }else{
89 tmpMime = cfg->readBoolEntry("audio", true );
90 if(tmpMime )
91 mimes.append("audio//*" );
92
93 tmpMime = cfg->readBoolEntry("image", true );
94 if(tmpMime )
95 mimes.append("image//*" );
96
97 tmpMime = cfg->readBoolEntry("text", true );
98 if(tmpMime )
99 mimes.append("text//*");
100
101 tmpMime = cfg->readBoolEntry("video", true );
102 if(tmpMime )
103 mimes.append("video//*" );
104 }
105 return mimes;
106 }
107
108}
109
79 110
80CategoryTabWidget::CategoryTabWidget( QWidget* parent ) : 111CategoryTabWidget::CategoryTabWidget( QWidget* parent ) :
81 QVBox( parent ) 112 QVBox( parent )
82{ 113{
83 categoryBar = 0; 114 categoryBar = 0;
84 stack = 0; 115 stack = 0;
85} 116}
86 117
87void CategoryTabWidget::prevTab() 118void CategoryTabWidget::prevTab()
88{ 119{
89 if ( categoryBar ) { 120 if ( categoryBar ) {
90 int n = categoryBar->count(); 121 int n = categoryBar->count();
91 int tab = categoryBar->currentTab(); 122 int tab = categoryBar->currentTab();
92 if ( tab >= 0 ) 123 if ( tab >= 0 )
93 categoryBar->setCurrentTab( (tab - 1 + n)%n ); 124 categoryBar->setCurrentTab( (tab - 1 + n)%n );
94 } 125 }
95} 126}
96 127
97void CategoryTabWidget::nextTab() 128void CategoryTabWidget::nextTab()
98{ 129{
99 if ( categoryBar ) { 130 if ( categoryBar ) {
100 int n = categoryBar->count(); 131 int n = categoryBar->count();
101 int tab = categoryBar->currentTab(); 132 int tab = categoryBar->currentTab();
102 categoryBar->setCurrentTab( (tab + 1)%n ); 133 categoryBar->setCurrentTab( (tab + 1)%n );
103 } 134 }
104} 135}
105 136
106void CategoryTabWidget::addItem( const QString& linkfile ) 137void CategoryTabWidget::addItem( const QString& linkfile )
107{ 138{
108 int i=0; 139 int i=0;
109 AppLnk *app = new AppLnk(linkfile); 140 AppLnk *app = new AppLnk(linkfile);
110 if ( !app->isValid() ) { 141 if ( !app->isValid() ) {
111 delete app; 142 delete app;
112 return; 143 return;
113 } 144 }
114 if ( !app->file().isEmpty() ) { 145 if ( !app->file().isEmpty() ) {
115 // A document 146 // A document
116 delete app; 147 delete app;
117 app = new DocLnk(linkfile); 148 app = new DocLnk(linkfile);
118 ((LauncherView*)(stack->widget(ids.count()-1)))->addItem(app); 149 ((LauncherView*)(stack->widget(ids.count()-1)))->addItem(app);
119 return; 150 return;
120 } 151 }
121 for ( QStringList::Iterator it=ids.begin(); it!=ids.end(); ++it) { 152 for ( QStringList::Iterator it=ids.begin(); it!=ids.end(); ++it) {
122 if ( !(*it).isEmpty() ) { 153 if ( !(*it).isEmpty() ) {
123 QRegExp tf(*it,FALSE,TRUE); 154 QRegExp tf(*it,FALSE,TRUE);
124 if ( tf.match(app->type()) >= 0 ) { 155 if ( tf.match(app->type()) >= 0 ) {
125 ((LauncherView*)stack->widget(i))->addItem(app); 156 ((LauncherView*)stack->widget(i))->addItem(app);
126 return; 157 return;
127 } 158 }
128 i++; 159 i++;
129 } 160 }
130 } 161 }
131} 162}
132 163
133void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder, 164void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder,
134 AppLnkSet* docFolder, const QList<FileSystem> &fs) 165 AppLnkSet* docFolder, const QList<FileSystem> &fs)
135{ 166{
136 delete categoryBar; 167 delete categoryBar;
137 categoryBar = new CategoryTabBar( this ); 168 categoryBar = new CategoryTabBar( this );
138 QPalette pal = categoryBar->palette(); 169 QPalette pal = categoryBar->palette();
139 pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) ); 170 pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) );
140 pal.setColor( QColorGroup::Background, pal.active().background().light(110) ); 171 pal.setColor( QColorGroup::Background, pal.active().background().light(110) );
141 categoryBar->setPalette( pal ); 172 categoryBar->setPalette( pal );
142 173
@@ -365,260 +396,265 @@ void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const
365#if QT_VERSION >= 300 396#if QT_VERSION >= 300
366 t->identifier() == keyboardFocusTab() 397 t->identifier() == keyboardFocusTab()
367#else 398#else
368 t->identitifer() == keyboardFocusTab() 399 t->identitifer() == keyboardFocusTab()
369#endif 400#endif
370 ); 401 );
371} 402}
372 403
373 404
374void CategoryTabBar::paintLabel( QPainter* p, const QRect&, 405void CategoryTabBar::paintLabel( QPainter* p, const QRect&,
375 QTab* t, bool has_focus ) const 406 QTab* t, bool has_focus ) const
376{ 407{
377 QRect r = t->rect(); 408 QRect r = t->rect();
378 // if ( t->id != currentTab() ) 409 // if ( t->id != currentTab() )
379 //r.moveBy( 1, 1 ); 410 //r.moveBy( 1, 1 );
380 // 411 //
381 if ( t->iconSet() ) { 412 if ( t->iconSet() ) {
382 // the tab has an iconset, draw it in the right mode 413 // the tab has an iconset, draw it in the right mode
383 QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; 414 QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled;
384 if ( mode == QIconSet::Normal && has_focus ) 415 if ( mode == QIconSet::Normal && has_focus )
385 mode = QIconSet::Active; 416 mode = QIconSet::Active;
386 QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); 417 QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode );
387 int pixw = pixmap.width(); 418 int pixw = pixmap.width();
388 int pixh = pixmap.height(); 419 int pixh = pixmap.height();
389 p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); 420 p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap );
390 r.setLeft( r.left() + pixw + 5 ); 421 r.setLeft( r.left() + pixw + 5 );
391 } 422 }
392 423
393 QRect tr = r; 424 QRect tr = r;
394 425
395 if ( r.width() < 20 ) 426 if ( r.width() < 20 )
396 return; 427 return;
397 428
398 if ( t->isEnabled() && isEnabled() ) { 429 if ( t->isEnabled() && isEnabled() ) {
399#if defined(_WS_WIN32_) 430#if defined(_WS_WIN32_)
400 if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) 431 if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) )
401 p->setPen( colorGroup().buttonText() ); 432 p->setPen( colorGroup().buttonText() );
402 else 433 else
403 p->setPen( colorGroup().foreground() ); 434 p->setPen( colorGroup().foreground() );
404#else 435#else
405 p->setPen( colorGroup().foreground() ); 436 p->setPen( colorGroup().foreground() );
406#endif 437#endif
407 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); 438 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() );
408 } else { 439 } else {
409 p->setPen( palette().disabled().foreground() ); 440 p->setPen( palette().disabled().foreground() );
410 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); 441 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() );
411 } 442 }
412} 443}
413 444
414//--------------------------------------------------------------------------- 445//---------------------------------------------------------------------------
415 446
416Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) 447Launcher::Launcher( QWidget* parent, const char* name, WFlags fl )
417 : QMainWindow( parent, name, fl ) 448 : QMainWindow( parent, name, fl )
418{ 449{
419 setCaption( tr("Launcher") ); 450 setCaption( tr("Launcher") );
420 451
421 syncDialog = 0; 452 syncDialog = 0;
422 453
423 // we have a pretty good idea how big we'll be 454 // we have a pretty good idea how big we'll be
424 setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); 455 setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() );
425 456
426 tabs = 0; 457 tabs = 0;
427 rootFolder = 0; 458 rootFolder = 0;
428 docsFolder = 0; 459 docsFolder = 0;
429 int stamp = uidgen.generate(); 460 int stamp = uidgen.generate(); // this is our timestamp to see which devices we know
430 uidgen.store( stamp ); 461 //uidgen.store( stamp );
431 m_timeStamp = QString::number( stamp ); 462 m_timeStamp = QString::number( stamp );
432 463
433 tabs = new CategoryTabWidget( this ); 464 tabs = new CategoryTabWidget( this );
434 tabs->setMaximumWidth( qApp->desktop()->width() ); 465 tabs->setMaximumWidth( qApp->desktop()->width() );
435 setCentralWidget( tabs ); 466 setCentralWidget( tabs );
436 467
437 connect( tabs, SIGNAL(selected(const QString&)), 468 connect( tabs, SIGNAL(selected(const QString&)),
438 this, SLOT(viewSelected(const QString&)) ); 469 this, SLOT(viewSelected(const QString&)) );
439 connect( tabs, SIGNAL(clicked(const AppLnk*)), 470 connect( tabs, SIGNAL(clicked(const AppLnk*)),
440 this, SLOT(select(const AppLnk*))); 471 this, SLOT(select(const AppLnk*)));
441 connect( tabs, SIGNAL(rightPressed(AppLnk*)), 472 connect( tabs, SIGNAL(rightPressed(AppLnk*)),
442 this, SLOT(properties(AppLnk*))); 473 this, SLOT(properties(AppLnk*)));
443 474
444#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 475#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
445 QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); 476 QCopChannel* sysChannel = new QCopChannel( "QPE/System", this );
446 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), 477 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)),
447 this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); 478 this, SLOT(systemMessage( const QCString &, const QByteArray &)) );
448#endif 479#endif
449 480
450 storage = new StorageInfo( this ); 481 storage = new StorageInfo( this );
451 connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); 482 connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) );
452 483
453 updateTabs(); 484 updateTabs();
454 485
455 preloadApps(); 486 preloadApps();
456 487
457 in_lnk_props = FALSE; 488 in_lnk_props = FALSE;
458 got_lnk_change = FALSE; 489 got_lnk_change = FALSE;
459} 490}
460 491
461Launcher::~Launcher() 492Launcher::~Launcher()
462{ 493{
463} 494}
464 495
465static bool isVisibleWindow(int wid) 496static bool isVisibleWindow(int wid)
466{ 497{
467 const QList<QWSWindow> &list = qwsServer->clientWindows(); 498 const QList<QWSWindow> &list = qwsServer->clientWindows();
468 QWSWindow* w; 499 QWSWindow* w;
469 for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { 500 for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) {
470 if ( w->winId() == wid ) 501 if ( w->winId() == wid )
471 return !w->isFullyObscured(); 502 return !w->isFullyObscured();
472 } 503 }
473 return FALSE; 504 return FALSE;
474} 505}
475 506
476void Launcher::showMaximized() 507void Launcher::showMaximized()
477{ 508{
478 if ( isVisibleWindow( winId() ) ) 509 if ( isVisibleWindow( winId() ) )
479 doMaximize(); 510 doMaximize();
480 else 511 else
481 QTimer::singleShot( 20, this, SLOT(doMaximize()) ); 512 QTimer::singleShot( 20, this, SLOT(doMaximize()) );
482} 513}
483 514
484void Launcher::doMaximize() 515void Launcher::doMaximize()
485{ 516{
486 QMainWindow::showMaximized(); 517 QMainWindow::showMaximized();
487} 518}
488 519
489void Launcher::updateMimeTypes() 520void Launcher::updateMimeTypes()
490{ 521{
491 MimeType::clear(); 522 MimeType::clear();
492 updateMimeTypes(rootFolder); 523 updateMimeTypes(rootFolder);
493} 524}
494 525
495void Launcher::updateMimeTypes(AppLnkSet* folder) 526void Launcher::updateMimeTypes(AppLnkSet* folder)
496{ 527{
497 for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { 528 for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) {
498 AppLnk *app = it.current(); 529 AppLnk *app = it.current();
499 if ( app->type() == "Folder" ) 530 if ( app->type() == "Folder" )
500 updateMimeTypes((AppLnkSet *)app); 531 updateMimeTypes((AppLnkSet *)app);
501 else { 532 else {
502 MimeType::registerApp(*app); 533 MimeType::registerApp(*app);
503 } 534 }
504 } 535 }
505} 536}
506 537
507void Launcher::loadDocs() // ok here comes a hack belonging to Global:: 538void Launcher::loadDocs() // ok here comes a hack belonging to Global::
508{ 539{
509 qWarning("loading Documents" ); 540 qWarning("loading Documents" );
510 qWarning("The currentTimeStamp is: %s", m_timeStamp.latin1() ); 541 qWarning("The currentTimeStamp is: %s", m_timeStamp.latin1() );
511 delete docsFolder; 542 delete docsFolder;
512 docsFolder = new DocLnkSet; 543 docsFolder = new DocLnkSet;
513 qWarning("new DocLnkSet" ); 544 qWarning("new DocLnkSet" );
545 DocLnkSet *tmp = 0;
546 QString home = QString(getenv("HOME")) + "/Documents";
547 tmp = new DocLnkSet( home , QString::null);
548 docsFolder->appendFrom( *tmp );
549 delete tmp;
514 // find out wich filesystems are new in this round 550 // find out wich filesystems are new in this round
515 // We will do this by having a timestamp inside each mountpoint 551 // We will do this by having a timestamp inside each mountpoint
516 // if the current timestamp doesn't match this is a new file system and 552 // if the current timestamp doesn't match this is a new file system and
517 // come up with our MediumMountGui :) let the hacking begin 553 // come up with our MediumMountGui :) let the hacking begin
518 int stamp = uidgen.generate(); 554 int stamp = uidgen.generate();
519 555
520 QString newStamp = QString::number( stamp ); 556 QString newStamp = QString::number( stamp ); // generates newtime Stamp
521 qWarning("new time stamp is: %s", newStamp.latin1() );
522 StorageInfo storage; 557 StorageInfo storage;
523 const QList<FileSystem> &fileSystems = storage.fileSystems(); 558 const QList<FileSystem> &fileSystems = storage.fileSystems();
524 qWarning("QList<FileSystem>" );
525 QListIterator<FileSystem> it ( fileSystems ); 559 QListIterator<FileSystem> it ( fileSystems );
526 qWarning("iterator initiliazed" );
527 for ( ; it.current(); ++it ) { 560 for ( ; it.current(); ++it ) {
528 qWarning("inside for loop" );
529 qWarning("checking device %s", (*it)->path().latin1() );
530 if ( (*it)->isRemovable() ) { // let's find out if we should search on it 561 if ( (*it)->isRemovable() ) { // let's find out if we should search on it
531 qWarning("%s is removeable", (*it)->path().latin1() ); 562 qWarning("%s is removeable", (*it)->path().latin1() );
532 OConfig cfg( (*it)->path() + "/.opiestorage.cf"); 563 OConfig cfg( (*it)->path() + "/.opiestorage.cf");
533 cfg.setGroup("main"); 564 cfg.setGroup("main");
534 QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); 565 QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() );
535 if( stamp == m_timeStamp ){ // ok we know this card 566 if( stamp == m_timeStamp ){ // ok we know this card
536 qWarning("time stamp match" ); 567 cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp
537 cfg.writeEntry("timestamp", newStamp );
538 // we need to scan the list now. Hopefully the cache will be there 568 // we need to scan the list now. Hopefully the cache will be there
539 }else{ // come up with the gui 569 // read the mimetypes from the config and search for documents
540 qWarning("time stamp doesn't match" ); 570 QStringList mimetypes = configToMime( &cfg);
571 tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") );
572 docsFolder->appendFrom( *tmp );
573 delete tmp;
574
575 }else{ // come up with the gui cause this a new card
541 MediumMountGui medium((*it)->path() ); 576 MediumMountGui medium((*it)->path() );
542 qWarning("medium mount gui created" ); 577 if( medium.check() ){ // we did not ask before or ask again is off
543 if( medium.check() ){ 578 if( medium.exec() ){ // he clicked yes so search it
544 qWarning("need to check this device" );
545 if( medium.exec() ){ //ok
546 // speicher 579 // speicher
547 qWarning("execed" ); 580 cfg.read(); // cause of a race we need to reread
548 cfg.read();
549 cfg.writeEntry("timestamp", newStamp ); 581 cfg.writeEntry("timestamp", newStamp );
550 } 582 }// no else
551 }else{ 583 }else{ // we checked
552 qWarning("wrong :(" );
553 // do something different see what we need to do 584 // do something different see what we need to do
585 // let's see if we should check the device
586 cfg.setGroup("main" );
587 bool check = cfg.readBoolEntry("autocheck", true );
588 if( check ){ // find the documents
589 tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") );
590 docsFolder->appendFrom( *tmp );
591 delete tmp;
592 }
554 } 593 }
555 } 594 }
556 } 595 }
557 } 596 }
558 qWarning("findDocuments" );
559 Global::findDocuments(docsFolder); // get rid of this call later
560 qWarning("done" );
561 m_timeStamp = newStamp; 597 m_timeStamp = newStamp;
562} 598}
563 599
564void Launcher::updateTabs() 600void Launcher::updateTabs()
565{ 601{
566 MimeType::updateApplications(); // ### reads all applnks twice 602 MimeType::updateApplications(); // ### reads all applnks twice
567 603
568 delete rootFolder; 604 delete rootFolder;
569 rootFolder = new AppLnkSet( MimeType::appsFolderName() ); 605 rootFolder = new AppLnkSet( MimeType::appsFolderName() );
570 606
571 loadDocs(); 607 loadDocs();
572 608
573 tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); 609 tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems());
574} 610}
575 611
576void Launcher::updateDocs() 612void Launcher::updateDocs()
577{ 613{
578 loadDocs(); 614 loadDocs();
579 tabs->updateDocs(docsFolder,storage->fileSystems()); 615 tabs->updateDocs(docsFolder,storage->fileSystems());
580} 616}
581 617
582void Launcher::viewSelected(const QString& s) 618void Launcher::viewSelected(const QString& s)
583{ 619{
584 setCaption( s + tr(" - Launcher") ); 620 setCaption( s + tr(" - Launcher") );
585} 621}
586 622
587void Launcher::nextView() 623void Launcher::nextView()
588{ 624{
589 tabs->nextTab(); 625 tabs->nextTab();
590} 626}
591 627
592 628
593void Launcher::select( const AppLnk *appLnk ) 629void Launcher::select( const AppLnk *appLnk )
594{ 630{
595 if ( appLnk->type() == "Folder" ) { 631 if ( appLnk->type() == "Folder" ) {
596 // Not supported: flat is simpler for the user 632 // Not supported: flat is simpler for the user
597 } else { 633 } else {
598 if ( appLnk->exec().isNull() ) { 634 if ( appLnk->exec().isNull() ) {
599 QMessageBox::information(this,tr("No application"), 635 QMessageBox::information(this,tr("No application"),
600 tr("<p>No application is defined for this document." 636 tr("<p>No application is defined for this document."
601 "<p>Type is %1.").arg(appLnk->type())); 637 "<p>Type is %1.").arg(appLnk->type()));
602 return; 638 return;
603 } 639 }
604 tabs->setBusy(TRUE); 640 tabs->setBusy(TRUE);
605 emit executing( appLnk ); 641 emit executing( appLnk );
606 appLnk->execute(); 642 appLnk->execute();
607 } 643 }
608} 644}
609 645
610void Launcher::externalSelected(const AppLnk *appLnk) 646void Launcher::externalSelected(const AppLnk *appLnk)
611{ 647{
612 tabs->setBusy(TRUE); 648 tabs->setBusy(TRUE);
613 emit executing( appLnk ); 649 emit executing( appLnk );
614} 650}
615 651
616void Launcher::properties( AppLnk *appLnk ) 652void Launcher::properties( AppLnk *appLnk )
617{ 653{
618 if ( appLnk->type() == "Folder" ) { 654 if ( appLnk->type() == "Folder" ) {
619 // Not supported: flat is simpler for the user 655 // Not supported: flat is simpler for the user
620 } else { 656 } else {
621 in_lnk_props = TRUE; 657 in_lnk_props = TRUE;
622 got_lnk_change = FALSE; 658 got_lnk_change = FALSE;
623 LnkProperties prop(appLnk); 659 LnkProperties prop(appLnk);
624 connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); 660 connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *)));
diff --git a/core/launcher/mediummountgui.cpp b/core/launcher/mediummountgui.cpp
index e3fa5bd..f0de85b 100644
--- a/core/launcher/mediummountgui.cpp
+++ b/core/launcher/mediummountgui.cpp
@@ -19,149 +19,151 @@
19 19
20#include <qapplication.h> 20#include <qapplication.h>
21 21
22 22
23MediumMountGui::MediumMountGui( const QString &path ,QWidget* parent, const char* name, bool modal, WFlags fl ) 23MediumMountGui::MediumMountGui( const QString &path ,QWidget* parent, const char* name, bool modal, WFlags fl )
24 : QDialog( parent, name, true ) { 24 : QDialog( parent, name, true ) {
25 25
26 26
27 QWidget *d = QApplication::desktop(); 27 QWidget *d = QApplication::desktop();
28 int w=d->width(); 28 int w=d->width();
29 int h=d->height(); 29 int h=d->height();
30 resize( w , h ); 30 resize( w , h );
31 setCaption( tr( "Medium inserted" ) ); 31 setCaption( tr( "Medium inserted" ) );
32 32
33 mediumPath = path; 33 mediumPath = path;
34 readConfig(); 34 readConfig();
35 startGui(); 35 startGui();
36} 36}
37 37
38void MediumMountGui::readConfig(){ 38void MediumMountGui::readConfig(){
39 39
40 OConfig cfg (mediumPath +"/.opiestorage.cf"); 40 OConfig cfg (mediumPath +"/.opiestorage.cf");
41 cfg.setGroup("main"); 41 cfg.setGroup("main");
42 checkagain = cfg.readBoolEntry("check", false); 42 checkagain = cfg.readBoolEntry("check", false);
43 43
44 cfg.setGroup("mimetypes"); 44 cfg.setGroup("mimetypes");
45 checkmimeaudio = cfg.readBoolEntry("audio", true); 45 checkmimeaudio = cfg.readBoolEntry("audio", true);
46 checkmimeimage = cfg.readBoolEntry("image", true); 46 checkmimeimage = cfg.readBoolEntry("image", true);
47 checkmimetext = cfg.readBoolEntry("text", true); 47 checkmimetext = cfg.readBoolEntry("text", true);
48 checkmimevideo = cfg.readBoolEntry("video", true); 48 checkmimevideo = cfg.readBoolEntry("video", true);
49 checkmimeall = cfg.readBoolEntry("all", true); 49 checkmimeall = cfg.readBoolEntry("all", true);
50 50
51 cfg.setGroup("dirs"); 51 cfg.setGroup("dirs");
52 limittodirs = cfg.readEntry("dirs", ""); 52 limittodirs = cfg.readEntry("dirs", "");
53} 53}
54 54
55bool MediumMountGui::check() { 55bool MediumMountGui::check() {
56 return !checkagain; 56 return !checkagain;
57} 57}
58 58
59QStringList MediumMountGui::dirs() { 59QStringList MediumMountGui::dirs() {
60 QStringList list = QStringList::split(",", limittodirs ); 60 QStringList list = QStringList::split(",", limittodirs );
61 return list; 61 return list;
62} 62}
63 63
64void MediumMountGui::writeConfig(bool autocheck) { 64void MediumMountGui::writeConfig(bool autocheck) {
65 65
66 OConfig cfg (mediumPath +"/.opiestorage.cf"); 66 OConfig cfg (mediumPath +"/.opiestorage.cf");
67 cfg.setGroup("main"); 67 cfg.setGroup("main");
68 cfg.writeEntry("check", AskBox->isChecked() ); 68 cfg.writeEntry("check", AskBox->isChecked() );
69 cfg.writeEntry("autocheck", autocheck ); 69 cfg.writeEntry("autocheck", autocheck );
70 70
71 cfg.setGroup("mimetypes"); 71 cfg.setGroup("mimetypes");
72 72
73 cfg.writeEntry("audio", CheckBoxAudio->isChecked() ); 73 cfg.writeEntry("audio", CheckBoxAudio->isChecked() );
74 cfg.writeEntry("image",CheckBoxImage->isChecked() ); 74 cfg.writeEntry("image",CheckBoxImage->isChecked() );
75 cfg.writeEntry("text",CheckBoxImage->isChecked() ); 75 cfg.writeEntry("text",CheckBoxImage->isChecked() );
76 cfg.writeEntry("video",CheckBoxVideo->isChecked() ); 76 cfg.writeEntry("video",CheckBoxVideo->isChecked() );
77 cfg.writeEntry("all",CheckBoxAll->isChecked() ); 77 cfg.writeEntry("all",CheckBoxAll->isChecked() );
78 78
79 cfg.setGroup("dirs"); 79 cfg.setGroup("dirs");
80 cfg.writeEntry("dirs", ""); 80 cfg.writeEntry("dirs", "");
81 81
82 82
83 // if all is checked then add only "null" to the list. 83 // if all is checked then add only "QString::null" to the list.
84 if (checkmimeall) { 84 if (checkmimeall) {
85 mimeTypeList += ("null"); 85 mimeTypeList.clear();
86 mimeTypeList += QString::null;
86 } else { 87 } else {
87 if (checkmimeaudio) { 88 if (checkmimeaudio) {
88 mimeTypeList += ("audio//*"); 89 mimeTypeList += ("audio//*");
89 } 90 }
90 if (checkmimetext) { 91 if (checkmimetext) {
91 mimeTypeList += ("text//*"); 92 mimeTypeList += ("text//*");
92 } 93 }
93 if (checkmimevideo) { 94 if (checkmimevideo) {
94 mimeTypeList += ("video//*"); 95 mimeTypeList += ("video//*");
95 } 96 }
96 if (checkmimeimage) { 97 if (checkmimeimage) {
97 mimeTypeList += ("image//*"); 98 mimeTypeList += ("image//*");
98 } 99 }
99 if (checkmimeall) { 100 if (checkmimeall) {
100 mimeTypeList << ("null"); 101 mimeTypeList.clear();
102 mimeTypeList << QString::null;
101 } 103 }
102 } 104 }
103 cfg.write(); 105 cfg.write(); // not really needed here but just to be sure
104} 106}
105 107
106void MediumMountGui::startGui() { 108void MediumMountGui::startGui() {
107 109
108 QPixmap image = Resource::loadPixmap( "HelpBrowser"); 110 QPixmap image = Resource::loadPixmap( "HelpBrowser");
109 111
110 Text_2 = new QLabel( this ); 112 Text_2 = new QLabel( this );
111 Text_2->setGeometry( QRect( 10, 15, 40, 40 ) ); 113 Text_2->setGeometry( QRect( 10, 15, 40, 40 ) );
112 Text_2->setPixmap( image ); 114 Text_2->setPixmap( image );
113 115
114 Text = new QLabel( this, "Text" ); 116 Text = new QLabel( this, "Text" );
115 Text->setGeometry( QRect( 55, 11, this->width()-50, 50 ) ); 117 Text->setGeometry( QRect( 55, 11, this->width()-50, 50 ) );
116 Text->setText( tr( "A <b>storage medium</b> was inserted. Should it be scanned for media files?" ) ); 118 Text->setText( tr( "A <b>storage medium</b> was inserted. Should it be scanned for media files?" ) );
117 119
118 // media box 120 // media box
119 GroupBox1 = new QGroupBox( this, "GroupBox1" ); 121 GroupBox1 = new QGroupBox( this, "GroupBox1" );
120 GroupBox1->setGeometry( QRect( 10, 80, (this->width())-25, 80 ) ); 122 GroupBox1->setGeometry( QRect( 10, 80, (this->width())-25, 80 ) );
121 GroupBox1->setTitle( tr( "Which media files" ) ); 123 GroupBox1->setTitle( tr( "Which media files" ) );
122 124
123 CheckBoxAudio = new QCheckBox( GroupBox1, "CheckBoxAudio" ); 125 CheckBoxAudio = new QCheckBox( GroupBox1, "CheckBoxAudio" );
124 CheckBoxAudio->setGeometry( QRect( 10, 15, (GroupBox1->width()/2)-15 , 15 ) ); 126 CheckBoxAudio->setGeometry( QRect( 10, 15, (GroupBox1->width()/2)-15 , 15 ) );
125 CheckBoxAudio->setText( tr( "Audio" ) ); 127 CheckBoxAudio->setText( tr( "Audio" ) );
126 128
127 CheckBoxImage = new QCheckBox( GroupBox1, "CheckBoxImage" ); 129 CheckBoxImage = new QCheckBox( GroupBox1, "CheckBoxImage" );
128 CheckBoxImage->setGeometry( QRect( 10, 35,(GroupBox1->width()/2)-15, 15 ) ); 130 CheckBoxImage->setGeometry( QRect( 10, 35,(GroupBox1->width()/2)-15, 15 ) );
129 CheckBoxImage->setText( tr( "Image" ) ); 131 CheckBoxImage->setText( tr( "Image" ) );
130 132
131 CheckBoxText = new QCheckBox( GroupBox1, "CheckBoxText" ); 133 CheckBoxText = new QCheckBox( GroupBox1, "CheckBoxText" );
132 CheckBoxText->setGeometry( QRect((GroupBox1->width()/2) , 15, (GroupBox1->width()/2)-15, 15 ) ); 134 CheckBoxText->setGeometry( QRect((GroupBox1->width()/2) , 15, (GroupBox1->width()/2)-15, 15 ) );
133 CheckBoxText->setText( tr( "Text" ) ); 135 CheckBoxText->setText( tr( "Text" ) );
134 136
135 CheckBoxVideo = new QCheckBox( GroupBox1, "CheckBoxVideo" ); 137 CheckBoxVideo = new QCheckBox( GroupBox1, "CheckBoxVideo" );
136 CheckBoxVideo->setGeometry( QRect( (GroupBox1->width()/2), 35, (GroupBox1->width()/2)-15, 15 ) ); 138 CheckBoxVideo->setGeometry( QRect( (GroupBox1->width()/2), 35, (GroupBox1->width()/2)-15, 15 ) );
137 CheckBoxVideo->setText( tr( "Video" ) ); 139 CheckBoxVideo->setText( tr( "Video" ) );
138 140
139 CheckBoxAll = new QCheckBox ( GroupBox1); 141 CheckBoxAll = new QCheckBox ( GroupBox1);
140 CheckBoxAll->setGeometry( QRect( 10, 55, (GroupBox1->width()/2)-15, 15 ) ); 142 CheckBoxAll->setGeometry( QRect( 10, 55, (GroupBox1->width()/2)-15, 15 ) );
141 CheckBoxAll->setText( tr( "All" ) ); 143 CheckBoxAll->setText( tr( "All" ) );
142 QObject::connect( (QObject*)CheckBoxAll, SIGNAL( clicked() ), this, SLOT( deactivateOthers()) ); 144 QObject::connect( (QObject*)CheckBoxAll, SIGNAL( clicked() ), this, SLOT( deactivateOthers()) );
143 145
144 146
145 147
146 CheckBoxLink = new QCheckBox ( GroupBox1); 148 CheckBoxLink = new QCheckBox ( GroupBox1);
147 CheckBoxLink->setGeometry( QRect( (GroupBox1->width()/2), 55, (GroupBox1->width()/2)-15, 15 ) ); 149 CheckBoxLink->setGeometry( QRect( (GroupBox1->width()/2), 55, (GroupBox1->width()/2)-15, 15 ) );
148 CheckBoxLink->setText( tr( "Link apps" ) ); 150 CheckBoxLink->setText( tr( "Link apps" ) );
149 // as long as the feature is not supported 151 // as long as the feature is not supported
150 CheckBoxLink->setEnabled(false); 152 CheckBoxLink->setEnabled(false);
151 153
152 154
153 // select dirs 155 // select dirs
154 156
155 DirSelectText = new QLabel( this, "DirSelectText" ); 157 DirSelectText = new QLabel( this, "DirSelectText" );
156 DirSelectText->setGeometry( QRect( 10, 160,this->width() , 20 ) ); 158 DirSelectText->setGeometry( QRect( 10, 160,this->width() , 20 ) );
157 DirSelectText->setText( tr( "Limit search to dir: (not used yet)" ) ); 159 DirSelectText->setText( tr( "Limit search to dir: (not used yet)" ) );
158 160
159 LineEdit1 = new QLineEdit( this ); 161 LineEdit1 = new QLineEdit( this );
160 LineEdit1->setGeometry( QRect( 10, 180, (this->width())-60, 20 ) ); 162 LineEdit1->setGeometry( QRect( 10, 180, (this->width())-60, 20 ) );
161 163
162 PushButton3 = new QPushButton( this ); 164 PushButton3 = new QPushButton( this );
163 PushButton3->setGeometry( QRect( (this->width())-40, 180, 30, 20 ) ); 165 PushButton3->setGeometry( QRect( (this->width())-40, 180, 30, 20 ) );
164 PushButton3->setText( tr( "Add" ) ); 166 PushButton3->setText( tr( "Add" ) );
165 167
166 168
167 // decision 169 // decision