-rw-r--r-- | core/launcher/launcher.cpp | 84 | ||||
-rw-r--r-- | core/launcher/mediummountgui.cpp | 10 |
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 |
79 | namespace { | ||
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 | ||
80 | CategoryTabWidget::CategoryTabWidget( QWidget* parent ) : | 111 | CategoryTabWidget::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 | ||
87 | void CategoryTabWidget::prevTab() | 118 | void 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 | ||
97 | void CategoryTabWidget::nextTab() | 128 | void 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 | ||
106 | void CategoryTabWidget::addItem( const QString& linkfile ) | 137 | void 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 | ||
133 | void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder, | 164 | void 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 | ||
374 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, | 405 | void 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 | ||
416 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) | 447 | Launcher::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 | ||
461 | Launcher::~Launcher() | 492 | Launcher::~Launcher() |
462 | { | 493 | { |
463 | } | 494 | } |
464 | 495 | ||
465 | static bool isVisibleWindow(int wid) | 496 | static 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 | ||
476 | void Launcher::showMaximized() | 507 | void 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 | ||
484 | void Launcher::doMaximize() | 515 | void Launcher::doMaximize() |
485 | { | 516 | { |
486 | QMainWindow::showMaximized(); | 517 | QMainWindow::showMaximized(); |
487 | } | 518 | } |
488 | 519 | ||
489 | void Launcher::updateMimeTypes() | 520 | void Launcher::updateMimeTypes() |
490 | { | 521 | { |
491 | MimeType::clear(); | 522 | MimeType::clear(); |
492 | updateMimeTypes(rootFolder); | 523 | updateMimeTypes(rootFolder); |
493 | } | 524 | } |
494 | 525 | ||
495 | void Launcher::updateMimeTypes(AppLnkSet* folder) | 526 | void 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 | ||
507 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: | 538 | void 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 | ||
564 | void Launcher::updateTabs() | 600 | void 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 | ||
576 | void Launcher::updateDocs() | 612 | void Launcher::updateDocs() |
577 | { | 613 | { |
578 | loadDocs(); | 614 | loadDocs(); |
579 | tabs->updateDocs(docsFolder,storage->fileSystems()); | 615 | tabs->updateDocs(docsFolder,storage->fileSystems()); |
580 | } | 616 | } |
581 | 617 | ||
582 | void Launcher::viewSelected(const QString& s) | 618 | void Launcher::viewSelected(const QString& s) |
583 | { | 619 | { |
584 | setCaption( s + tr(" - Launcher") ); | 620 | setCaption( s + tr(" - Launcher") ); |
585 | } | 621 | } |
586 | 622 | ||
587 | void Launcher::nextView() | 623 | void Launcher::nextView() |
588 | { | 624 | { |
589 | tabs->nextTab(); | 625 | tabs->nextTab(); |
590 | } | 626 | } |
591 | 627 | ||
592 | 628 | ||
593 | void Launcher::select( const AppLnk *appLnk ) | 629 | void 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 | ||
610 | void Launcher::externalSelected(const AppLnk *appLnk) | 646 | void 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 | ||
616 | void Launcher::properties( AppLnk *appLnk ) | 652 | void 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 | ||
23 | MediumMountGui::MediumMountGui( const QString &path ,QWidget* parent, const char* name, bool modal, WFlags fl ) | 23 | MediumMountGui::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 | ||
38 | void MediumMountGui::readConfig(){ | 38 | void 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 | ||
55 | bool MediumMountGui::check() { | 55 | bool MediumMountGui::check() { |
56 | return !checkagain; | 56 | return !checkagain; |
57 | } | 57 | } |
58 | 58 | ||
59 | QStringList MediumMountGui::dirs() { | 59 | QStringList MediumMountGui::dirs() { |
60 | QStringList list = QStringList::split(",", limittodirs ); | 60 | QStringList list = QStringList::split(",", limittodirs ); |
61 | return list; | 61 | return list; |
62 | } | 62 | } |
63 | 63 | ||
64 | void MediumMountGui::writeConfig(bool autocheck) { | 64 | void 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 | ||
106 | void MediumMountGui::startGui() { | 108 | void 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 |