summaryrefslogtreecommitdiff
authorzecke <zecke>2002-03-22 23:09:26 (UTC)
committer zecke <zecke>2002-03-22 23:09:26 (UTC)
commit5c17e8b168cf27ac2922e7c118cb886b116eab42 (patch) (unidiff)
tree5ba4ad0f08f9e93c62b95545d97a462f6924e45c
parent232a5bed633ba2aa96fcab73ff991ab3a796ad76 (diff)
downloadopie-5c17e8b168cf27ac2922e7c118cb886b116eab42.zip
opie-5c17e8b168cf27ac2922e7c118cb886b116eab42.tar.gz
opie-5c17e8b168cf27ac2922e7c118cb886b116eab42.tar.bz2
make some people happy update
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/launcher.cpp1
-rw-r--r--core/launcher/mediummountgui.cpp1
-rw-r--r--libopie/oconfig.h2
3 files changed, 3 insertions, 1 deletions
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp
index dcc3ba1..1c38a05 100644
--- a/core/launcher/launcher.cpp
+++ b/core/launcher/launcher.cpp
@@ -356,384 +356,385 @@ void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const
356 int ih = 0; 356 int ih = 0;
357 if ( t->iconSet() != 0 ) { 357 if ( t->iconSet() != 0 ) {
358 iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; 358 iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2;
359 ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); 359 ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height();
360 } 360 }
361 int w = iw + p->fontMetrics().width( t->text() ) + 4; 361 int w = iw + p->fontMetrics().width( t->text() ) + 4;
362 int h = QMAX(p->fontMetrics().height() + 4, ih ); 362 int h = QMAX(p->fontMetrics().height() + 4, ih );
363 paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, 363 paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3,
364 r.top() + (r.height()-h)/2, w, h ), t, 364 r.top() + (r.height()-h)/2, w, h ), t,
365#if QT_VERSION >= 300 365#if QT_VERSION >= 300
366 t->identifier() == keyboardFocusTab() 366 t->identifier() == keyboardFocusTab()
367#else 367#else
368 t->identitifer() == keyboardFocusTab() 368 t->identitifer() == keyboardFocusTab()
369#endif 369#endif
370 ); 370 );
371} 371}
372 372
373 373
374void CategoryTabBar::paintLabel( QPainter* p, const QRect&, 374void CategoryTabBar::paintLabel( QPainter* p, const QRect&,
375 QTab* t, bool has_focus ) const 375 QTab* t, bool has_focus ) const
376{ 376{
377 QRect r = t->rect(); 377 QRect r = t->rect();
378 // if ( t->id != currentTab() ) 378 // if ( t->id != currentTab() )
379 //r.moveBy( 1, 1 ); 379 //r.moveBy( 1, 1 );
380 // 380 //
381 if ( t->iconSet() ) { 381 if ( t->iconSet() ) {
382 // the tab has an iconset, draw it in the right mode 382 // the tab has an iconset, draw it in the right mode
383 QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; 383 QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled;
384 if ( mode == QIconSet::Normal && has_focus ) 384 if ( mode == QIconSet::Normal && has_focus )
385 mode = QIconSet::Active; 385 mode = QIconSet::Active;
386 QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); 386 QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode );
387 int pixw = pixmap.width(); 387 int pixw = pixmap.width();
388 int pixh = pixmap.height(); 388 int pixh = pixmap.height();
389 p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); 389 p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap );
390 r.setLeft( r.left() + pixw + 5 ); 390 r.setLeft( r.left() + pixw + 5 );
391 } 391 }
392 392
393 QRect tr = r; 393 QRect tr = r;
394 394
395 if ( r.width() < 20 ) 395 if ( r.width() < 20 )
396 return; 396 return;
397 397
398 if ( t->isEnabled() && isEnabled() ) { 398 if ( t->isEnabled() && isEnabled() ) {
399#if defined(_WS_WIN32_) 399#if defined(_WS_WIN32_)
400 if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) 400 if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) )
401 p->setPen( colorGroup().buttonText() ); 401 p->setPen( colorGroup().buttonText() );
402 else 402 else
403 p->setPen( colorGroup().foreground() ); 403 p->setPen( colorGroup().foreground() );
404#else 404#else
405 p->setPen( colorGroup().foreground() ); 405 p->setPen( colorGroup().foreground() );
406#endif 406#endif
407 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); 407 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() );
408 } else { 408 } else {
409 p->setPen( palette().disabled().foreground() ); 409 p->setPen( palette().disabled().foreground() );
410 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); 410 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() );
411 } 411 }
412} 412}
413 413
414//--------------------------------------------------------------------------- 414//---------------------------------------------------------------------------
415 415
416Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) 416Launcher::Launcher( QWidget* parent, const char* name, WFlags fl )
417 : QMainWindow( parent, name, fl ) 417 : QMainWindow( parent, name, fl )
418{ 418{
419 setCaption( tr("Launcher") ); 419 setCaption( tr("Launcher") );
420 420
421 syncDialog = 0; 421 syncDialog = 0;
422 422
423 // we have a pretty good idea how big we'll be 423 // we have a pretty good idea how big we'll be
424 setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); 424 setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() );
425 425
426 tabs = 0; 426 tabs = 0;
427 rootFolder = 0; 427 rootFolder = 0;
428 docsFolder = 0; 428 docsFolder = 0;
429 int stamp = uidgen.generate(); 429 int stamp = uidgen.generate();
430 uidgen.store( stamp ); 430 uidgen.store( stamp );
431 m_timeStamp = QString::number( stamp ); 431 m_timeStamp = QString::number( stamp );
432 432
433 tabs = new CategoryTabWidget( this ); 433 tabs = new CategoryTabWidget( this );
434 tabs->setMaximumWidth( qApp->desktop()->width() ); 434 tabs->setMaximumWidth( qApp->desktop()->width() );
435 setCentralWidget( tabs ); 435 setCentralWidget( tabs );
436 436
437 connect( tabs, SIGNAL(selected(const QString&)), 437 connect( tabs, SIGNAL(selected(const QString&)),
438 this, SLOT(viewSelected(const QString&)) ); 438 this, SLOT(viewSelected(const QString&)) );
439 connect( tabs, SIGNAL(clicked(const AppLnk*)), 439 connect( tabs, SIGNAL(clicked(const AppLnk*)),
440 this, SLOT(select(const AppLnk*))); 440 this, SLOT(select(const AppLnk*)));
441 connect( tabs, SIGNAL(rightPressed(AppLnk*)), 441 connect( tabs, SIGNAL(rightPressed(AppLnk*)),
442 this, SLOT(properties(AppLnk*))); 442 this, SLOT(properties(AppLnk*)));
443 443
444#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 444#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
445 QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); 445 QCopChannel* sysChannel = new QCopChannel( "QPE/System", this );
446 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), 446 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)),
447 this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); 447 this, SLOT(systemMessage( const QCString &, const QByteArray &)) );
448#endif 448#endif
449 449
450 storage = new StorageInfo( this ); 450 storage = new StorageInfo( this );
451 connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); 451 connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) );
452 452
453 updateTabs(); 453 updateTabs();
454 454
455 preloadApps(); 455 preloadApps();
456 456
457 in_lnk_props = FALSE; 457 in_lnk_props = FALSE;
458 got_lnk_change = FALSE; 458 got_lnk_change = FALSE;
459} 459}
460 460
461Launcher::~Launcher() 461Launcher::~Launcher()
462{ 462{
463} 463}
464 464
465static bool isVisibleWindow(int wid) 465static bool isVisibleWindow(int wid)
466{ 466{
467 const QList<QWSWindow> &list = qwsServer->clientWindows(); 467 const QList<QWSWindow> &list = qwsServer->clientWindows();
468 QWSWindow* w; 468 QWSWindow* w;
469 for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { 469 for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) {
470 if ( w->winId() == wid ) 470 if ( w->winId() == wid )
471 return !w->isFullyObscured(); 471 return !w->isFullyObscured();
472 } 472 }
473 return FALSE; 473 return FALSE;
474} 474}
475 475
476void Launcher::showMaximized() 476void Launcher::showMaximized()
477{ 477{
478 if ( isVisibleWindow( winId() ) ) 478 if ( isVisibleWindow( winId() ) )
479 doMaximize(); 479 doMaximize();
480 else 480 else
481 QTimer::singleShot( 20, this, SLOT(doMaximize()) ); 481 QTimer::singleShot( 20, this, SLOT(doMaximize()) );
482} 482}
483 483
484void Launcher::doMaximize() 484void Launcher::doMaximize()
485{ 485{
486 QMainWindow::showMaximized(); 486 QMainWindow::showMaximized();
487} 487}
488 488
489void Launcher::updateMimeTypes() 489void Launcher::updateMimeTypes()
490{ 490{
491 MimeType::clear(); 491 MimeType::clear();
492 updateMimeTypes(rootFolder); 492 updateMimeTypes(rootFolder);
493} 493}
494 494
495void Launcher::updateMimeTypes(AppLnkSet* folder) 495void Launcher::updateMimeTypes(AppLnkSet* folder)
496{ 496{
497 for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { 497 for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) {
498 AppLnk *app = it.current(); 498 AppLnk *app = it.current();
499 if ( app->type() == "Folder" ) 499 if ( app->type() == "Folder" )
500 updateMimeTypes((AppLnkSet *)app); 500 updateMimeTypes((AppLnkSet *)app);
501 else { 501 else {
502 MimeType::registerApp(*app); 502 MimeType::registerApp(*app);
503 } 503 }
504 } 504 }
505} 505}
506 506
507void Launcher::loadDocs() // ok here comes a hack belonging to Global:: 507void Launcher::loadDocs() // ok here comes a hack belonging to Global::
508{ 508{
509 qWarning("loading Documents" ); 509 qWarning("loading Documents" );
510 qWarning("The currentTimeStamp is: %s", m_timeStamp.latin1() ); 510 qWarning("The currentTimeStamp is: %s", m_timeStamp.latin1() );
511 delete docsFolder; 511 delete docsFolder;
512 docsFolder = new DocLnkSet; 512 docsFolder = new DocLnkSet;
513 qWarning("new DocLnkSet" ); 513 qWarning("new DocLnkSet" );
514 // find out wich filesystems are new in this round 514 // find out wich filesystems are new in this round
515 // We will do this by having a timestamp inside each mountpoint 515 // 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 516 // if the current timestamp doesn't match this is a new file system and
517 // come up with our MediumMountGui :) let the hacking begin 517 // come up with our MediumMountGui :) let the hacking begin
518 int stamp = uidgen.generate(); 518 int stamp = uidgen.generate();
519 519
520 QString newStamp = QString::number( stamp ); 520 QString newStamp = QString::number( stamp );
521 qWarning("new time stamp is: %s", newStamp.latin1() ); 521 qWarning("new time stamp is: %s", newStamp.latin1() );
522 StorageInfo storage; 522 StorageInfo storage;
523 const QList<FileSystem> &fileSystems = storage.fileSystems(); 523 const QList<FileSystem> &fileSystems = storage.fileSystems();
524 qWarning("QList<FileSystem>" ); 524 qWarning("QList<FileSystem>" );
525 QListIterator<FileSystem> it ( fileSystems ); 525 QListIterator<FileSystem> it ( fileSystems );
526 qWarning("iterator initiliazed" ); 526 qWarning("iterator initiliazed" );
527 for ( ; it.current(); ++it ) { 527 for ( ; it.current(); ++it ) {
528 qWarning("inside for loop" ); 528 qWarning("inside for loop" );
529 qWarning("checking device %s", (*it)->path().latin1() ); 529 qWarning("checking device %s", (*it)->path().latin1() );
530 if ( (*it)->isRemovable() ) { // let's find out if we should search on it 530 if ( (*it)->isRemovable() ) { // let's find out if we should search on it
531 qWarning("%s is removeable", (*it)->path().latin1() ); 531 qWarning("%s is removeable", (*it)->path().latin1() );
532 OConfig cfg( (*it)->path() + "/.opiestorage.cf"); 532 OConfig cfg( (*it)->path() + "/.opiestorage.cf");
533 cfg.setGroup("main"); 533 cfg.setGroup("main");
534 QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); 534 QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() );
535 if( stamp == m_timeStamp ){ // ok we know this card 535 if( stamp == m_timeStamp ){ // ok we know this card
536 qWarning("time stamp match" ); 536 qWarning("time stamp match" );
537 cfg.writeEntry("timestamp", newStamp ); 537 cfg.writeEntry("timestamp", newStamp );
538 // we need to scan the list now. Hopefully the cache will be there 538 // we need to scan the list now. Hopefully the cache will be there
539 }else{ // come up with the gui 539 }else{ // come up with the gui
540 qWarning("time stamp doesn't match" ); 540 qWarning("time stamp doesn't match" );
541 MediumMountGui medium((*it)->path() ); 541 MediumMountGui medium((*it)->path() );
542 qWarning("medium mount gui created" ); 542 qWarning("medium mount gui created" );
543 if( medium.check() ){ 543 if( medium.check() ){
544 qWarning("need to check this device" ); 544 qWarning("need to check this device" );
545 if( medium.exec() ){ //ok 545 if( medium.exec() ){ //ok
546 // speicher 546 // speicher
547 qWarning("execed" ); 547 qWarning("execed" );
548 cfg.read();
548 cfg.writeEntry("timestamp", newStamp ); 549 cfg.writeEntry("timestamp", newStamp );
549 } 550 }
550 }else{ 551 }else{
551 qWarning("wrong :(" ); 552 qWarning("wrong :(" );
552 // do something different see what we need to do 553 // do something different see what we need to do
553 } 554 }
554 } 555 }
555 } 556 }
556 } 557 }
557 qWarning("findDocuments" ); 558 qWarning("findDocuments" );
558 Global::findDocuments(docsFolder); // get rid of this call later 559 Global::findDocuments(docsFolder); // get rid of this call later
559 qWarning("done" ); 560 qWarning("done" );
560 m_timeStamp = newStamp; 561 m_timeStamp = newStamp;
561} 562}
562 563
563void Launcher::updateTabs() 564void Launcher::updateTabs()
564{ 565{
565 MimeType::updateApplications(); // ### reads all applnks twice 566 MimeType::updateApplications(); // ### reads all applnks twice
566 567
567 delete rootFolder; 568 delete rootFolder;
568 rootFolder = new AppLnkSet( MimeType::appsFolderName() ); 569 rootFolder = new AppLnkSet( MimeType::appsFolderName() );
569 570
570 loadDocs(); 571 loadDocs();
571 572
572 tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); 573 tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems());
573} 574}
574 575
575void Launcher::updateDocs() 576void Launcher::updateDocs()
576{ 577{
577 loadDocs(); 578 loadDocs();
578 tabs->updateDocs(docsFolder,storage->fileSystems()); 579 tabs->updateDocs(docsFolder,storage->fileSystems());
579} 580}
580 581
581void Launcher::viewSelected(const QString& s) 582void Launcher::viewSelected(const QString& s)
582{ 583{
583 setCaption( s + tr(" - Launcher") ); 584 setCaption( s + tr(" - Launcher") );
584} 585}
585 586
586void Launcher::nextView() 587void Launcher::nextView()
587{ 588{
588 tabs->nextTab(); 589 tabs->nextTab();
589} 590}
590 591
591 592
592void Launcher::select( const AppLnk *appLnk ) 593void Launcher::select( const AppLnk *appLnk )
593{ 594{
594 if ( appLnk->type() == "Folder" ) { 595 if ( appLnk->type() == "Folder" ) {
595 // Not supported: flat is simpler for the user 596 // Not supported: flat is simpler for the user
596 } else { 597 } else {
597 if ( appLnk->exec().isNull() ) { 598 if ( appLnk->exec().isNull() ) {
598 QMessageBox::information(this,tr("No application"), 599 QMessageBox::information(this,tr("No application"),
599 tr("<p>No application is defined for this document." 600 tr("<p>No application is defined for this document."
600 "<p>Type is %1.").arg(appLnk->type())); 601 "<p>Type is %1.").arg(appLnk->type()));
601 return; 602 return;
602 } 603 }
603 tabs->setBusy(TRUE); 604 tabs->setBusy(TRUE);
604 emit executing( appLnk ); 605 emit executing( appLnk );
605 appLnk->execute(); 606 appLnk->execute();
606 } 607 }
607} 608}
608 609
609void Launcher::externalSelected(const AppLnk *appLnk) 610void Launcher::externalSelected(const AppLnk *appLnk)
610{ 611{
611 tabs->setBusy(TRUE); 612 tabs->setBusy(TRUE);
612 emit executing( appLnk ); 613 emit executing( appLnk );
613} 614}
614 615
615void Launcher::properties( AppLnk *appLnk ) 616void Launcher::properties( AppLnk *appLnk )
616{ 617{
617 if ( appLnk->type() == "Folder" ) { 618 if ( appLnk->type() == "Folder" ) {
618 // Not supported: flat is simpler for the user 619 // Not supported: flat is simpler for the user
619 } else { 620 } else {
620 in_lnk_props = TRUE; 621 in_lnk_props = TRUE;
621 got_lnk_change = FALSE; 622 got_lnk_change = FALSE;
622 LnkProperties prop(appLnk); 623 LnkProperties prop(appLnk);
623 connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); 624 connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *)));
624 prop.showMaximized(); 625 prop.showMaximized();
625 prop.exec(); 626 prop.exec();
626 in_lnk_props = FALSE; 627 in_lnk_props = FALSE;
627 if ( got_lnk_change ) { 628 if ( got_lnk_change ) {
628 updateLink(lnk_change); 629 updateLink(lnk_change);
629 } 630 }
630 } 631 }
631} 632}
632 633
633void Launcher::updateLink(const QString& link) 634void Launcher::updateLink(const QString& link)
634{ 635{
635 if (link.isNull()) 636 if (link.isNull())
636 updateTabs(); 637 updateTabs();
637 else if (link.isEmpty()) 638 else if (link.isEmpty())
638 updateDocs(); 639 updateDocs();
639 else 640 else
640 tabs->updateLink(link); 641 tabs->updateLink(link);
641} 642}
642 643
643void Launcher::systemMessage( const QCString &msg, const QByteArray &data) 644void Launcher::systemMessage( const QCString &msg, const QByteArray &data)
644{ 645{
645 QDataStream stream( data, IO_ReadOnly ); 646 QDataStream stream( data, IO_ReadOnly );
646 if ( msg == "linkChanged(QString)" ) { 647 if ( msg == "linkChanged(QString)" ) {
647 QString link; 648 QString link;
648 stream >> link; 649 stream >> link;
649 if ( in_lnk_props ) { 650 if ( in_lnk_props ) {
650 got_lnk_change = TRUE; 651 got_lnk_change = TRUE;
651 lnk_change = link; 652 lnk_change = link;
652 } else { 653 } else {
653 updateLink(link); 654 updateLink(link);
654 } 655 }
655 } else if ( msg == "busy()" ) { 656 } else if ( msg == "busy()" ) {
656 emit busy(); 657 emit busy();
657 } else if ( msg == "notBusy(QString)" ) { 658 } else if ( msg == "notBusy(QString)" ) {
658 QString app; 659 QString app;
659 stream >> app; 660 stream >> app;
660 tabs->setBusy(FALSE); 661 tabs->setBusy(FALSE);
661 emit notBusy(app); 662 emit notBusy(app);
662 } else if ( msg == "mkdir(QString)" ) { 663 } else if ( msg == "mkdir(QString)" ) {
663 QString dir; 664 QString dir;
664 stream >> dir; 665 stream >> dir;
665 if ( !dir.isEmpty() ) 666 if ( !dir.isEmpty() )
666 mkdir( dir ); 667 mkdir( dir );
667 } else if ( msg == "rdiffGenSig(QString,QString)" ) { 668 } else if ( msg == "rdiffGenSig(QString,QString)" ) {
668 QString baseFile, sigFile; 669 QString baseFile, sigFile;
669 stream >> baseFile >> sigFile; 670 stream >> baseFile >> sigFile;
670 QRsync::generateSignature( baseFile, sigFile ); 671 QRsync::generateSignature( baseFile, sigFile );
671 } else if ( msg == "rdiffGenDiff(QString,QString,QString)" ) { 672 } else if ( msg == "rdiffGenDiff(QString,QString,QString)" ) {
672 QString baseFile, sigFile, deltaFile; 673 QString baseFile, sigFile, deltaFile;
673 stream >> baseFile >> sigFile >> deltaFile; 674 stream >> baseFile >> sigFile >> deltaFile;
674 QRsync::generateDiff( baseFile, sigFile, deltaFile ); 675 QRsync::generateDiff( baseFile, sigFile, deltaFile );
675 } else if ( msg == "rdiffApplyPatch(QString,QString)" ) { 676 } else if ( msg == "rdiffApplyPatch(QString,QString)" ) {
676 QString baseFile, deltaFile; 677 QString baseFile, deltaFile;
677 stream >> baseFile >> deltaFile; 678 stream >> baseFile >> deltaFile;
678 if ( !QFile::exists( baseFile ) ) { 679 if ( !QFile::exists( baseFile ) ) {
679 QFile f( baseFile ); 680 QFile f( baseFile );
680 f.open( IO_WriteOnly ); 681 f.open( IO_WriteOnly );
681 f.close(); 682 f.close();
682 } 683 }
683 QRsync::applyDiff( baseFile, deltaFile ); 684 QRsync::applyDiff( baseFile, deltaFile );
684 QCopEnvelope e( "QPE/Desktop", "patchApplied(QString)" ); 685 QCopEnvelope e( "QPE/Desktop", "patchApplied(QString)" );
685 e << baseFile; 686 e << baseFile;
686 } else if ( msg == "rdiffCleanup()" ) { 687 } else if ( msg == "rdiffCleanup()" ) {
687 mkdir( "/tmp/rdiff" ); 688 mkdir( "/tmp/rdiff" );
688 QDir dir; 689 QDir dir;
689 dir.setPath( "/tmp/rdiff" ); 690 dir.setPath( "/tmp/rdiff" );
690 QStringList entries = dir.entryList(); 691 QStringList entries = dir.entryList();
691 for ( QStringList::Iterator it = entries.begin(); it != entries.end(); ++it ) 692 for ( QStringList::Iterator it = entries.begin(); it != entries.end(); ++it )
692 dir.remove( *it ); 693 dir.remove( *it );
693 } else if ( msg == "sendHandshakeInfo()" ) { 694 } else if ( msg == "sendHandshakeInfo()" ) {
694 QString home = getenv( "HOME" ); 695 QString home = getenv( "HOME" );
695 QCopEnvelope e( "QPE/Desktop", "handshakeInfo(QString,bool)" ); 696 QCopEnvelope e( "QPE/Desktop", "handshakeInfo(QString,bool)" );
696 e << home; 697 e << home;
697 int locked = (int) Desktop::screenLocked(); 698 int locked = (int) Desktop::screenLocked();
698 e << locked; 699 e << locked;
699 // register an app for autostart 700 // register an app for autostart
700 // if clear is send the list is cleared. 701 // if clear is send the list is cleared.
701 } else if ( msg == "autoStart(QString)" ) { 702 } else if ( msg == "autoStart(QString)" ) {
702 QString appName; 703 QString appName;
703 stream >> appName; 704 stream >> appName;
704 Config cfg( "autostart" ); 705 Config cfg( "autostart" );
705 cfg.setGroup( "AutoStart" ); 706 cfg.setGroup( "AutoStart" );
706 if ( appName.compare("clear") == 0){ 707 if ( appName.compare("clear") == 0){
707 cfg.writeEntry("Apps", ""); 708 cfg.writeEntry("Apps", "");
708 } 709 }
709 } else if ( msg == "autoStart(QString,QString)" ) { 710 } else if ( msg == "autoStart(QString,QString)" ) {
710 QString modifier, appName; 711 QString modifier, appName;
711 stream >> modifier >> appName; 712 stream >> modifier >> appName;
712 Config cfg( "autostart" ); 713 Config cfg( "autostart" );
713 cfg.setGroup( "AutoStart" ); 714 cfg.setGroup( "AutoStart" );
714 if ( modifier.compare("add") == 0 ){ 715 if ( modifier.compare("add") == 0 ){
715 // only add it appname is entered 716 // only add it appname is entered
716 if (!appName.isEmpty()) { 717 if (!appName.isEmpty()) {
717 cfg.writeEntry("Apps", appName); 718 cfg.writeEntry("Apps", appName);
718 } 719 }
719 } else if (modifier.compare("remove") == 0 ) { 720 } else if (modifier.compare("remove") == 0 ) {
720 // need to change for multiple entries 721 // need to change for multiple entries
721 // actually remove is right now simular to clear, but in future there 722 // actually remove is right now simular to clear, but in future there
722 // should be multiple apps in autostart possible. 723 // should be multiple apps in autostart possible.
723 QString checkName; 724 QString checkName;
724 checkName = cfg.readEntry("Apps", ""); 725 checkName = cfg.readEntry("Apps", "");
725 if (checkName == appName) { 726 if (checkName == appName) {
726 cfg.writeEntry("Apps", ""); 727 cfg.writeEntry("Apps", "");
727 } 728 }
728 } 729 }
729 } else if ( msg == "sendCardInfo()" ) { 730 } else if ( msg == "sendCardInfo()" ) {
730 QCopEnvelope e( "QPE/Desktop", "cardInfo(QString)" ); 731 QCopEnvelope e( "QPE/Desktop", "cardInfo(QString)" );
731 const QList<FileSystem> &fs = storage->fileSystems(); 732 const QList<FileSystem> &fs = storage->fileSystems();
732 QListIterator<FileSystem> it ( fs ); 733 QListIterator<FileSystem> it ( fs );
733 QString s; 734 QString s;
734 QString homeDir = getenv("HOME"); 735 QString homeDir = getenv("HOME");
735 QString hardDiskHome; 736 QString hardDiskHome;
736 for ( ; it.current(); ++it ) { 737 for ( ; it.current(); ++it ) {
737 if ( (*it)->isRemovable() ) 738 if ( (*it)->isRemovable() )
738 s += (*it)->name() + "=" + (*it)->path() + "/Documents " 739 s += (*it)->name() + "=" + (*it)->path() + "/Documents "
739 + QString::number( (*it)->availBlocks() * (*it)->blockSize() ) 740 + QString::number( (*it)->availBlocks() * (*it)->blockSize() )
diff --git a/core/launcher/mediummountgui.cpp b/core/launcher/mediummountgui.cpp
index 5225711..e3fa5bd 100644
--- a/core/launcher/mediummountgui.cpp
+++ b/core/launcher/mediummountgui.cpp
@@ -1,232 +1,233 @@
1 1
2#include "mediummountgui.h" 2#include "mediummountgui.h"
3 3
4#include <qvariant.h> 4#include <qvariant.h>
5#include <qcheckbox.h> 5#include <qcheckbox.h>
6#include <qgroupbox.h> 6#include <qgroupbox.h>
7#include <qlabel.h> 7#include <qlabel.h>
8#include <qlineedit.h> 8#include <qlineedit.h>
9#include <qpushbutton.h> 9#include <qpushbutton.h>
10#include <qlayout.h> 10#include <qlayout.h>
11#include <qtooltip.h> 11#include <qtooltip.h>
12#include <qwhatsthis.h> 12#include <qwhatsthis.h>
13#include <qimage.h> 13#include <qimage.h>
14#include <qpixmap.h> 14#include <qpixmap.h>
15 15
16#include <qpe/resource.h> 16#include <qpe/resource.h>
17#include <opie/oconfig.h> 17#include <opie/oconfig.h>
18 18
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 "null" to the list.
84 if (checkmimeall) { 84 if (checkmimeall) {
85 mimeTypeList += ("null"); 85 mimeTypeList += ("null");
86 } else { 86 } else {
87 if (checkmimeaudio) { 87 if (checkmimeaudio) {
88 mimeTypeList += ("audio//*"); 88 mimeTypeList += ("audio//*");
89 } 89 }
90 if (checkmimetext) { 90 if (checkmimetext) {
91 mimeTypeList += ("text//*"); 91 mimeTypeList += ("text//*");
92 } 92 }
93 if (checkmimevideo) { 93 if (checkmimevideo) {
94 mimeTypeList += ("video//*"); 94 mimeTypeList += ("video//*");
95 } 95 }
96 if (checkmimeimage) { 96 if (checkmimeimage) {
97 mimeTypeList += ("image//*"); 97 mimeTypeList += ("image//*");
98 } 98 }
99 if (checkmimeall) { 99 if (checkmimeall) {
100 mimeTypeList << ("null"); 100 mimeTypeList << ("null");
101 } 101 }
102 } 102 }
103 cfg.write();
103} 104}
104 105
105void MediumMountGui::startGui() { 106void MediumMountGui::startGui() {
106 107
107 QPixmap image = Resource::loadPixmap( "HelpBrowser"); 108 QPixmap image = Resource::loadPixmap( "HelpBrowser");
108 109
109 Text_2 = new QLabel( this ); 110 Text_2 = new QLabel( this );
110 Text_2->setGeometry( QRect( 10, 15, 40, 40 ) ); 111 Text_2->setGeometry( QRect( 10, 15, 40, 40 ) );
111 Text_2->setPixmap( image ); 112 Text_2->setPixmap( image );
112 113
113 Text = new QLabel( this, "Text" ); 114 Text = new QLabel( this, "Text" );
114 Text->setGeometry( QRect( 55, 11, this->width()-50, 50 ) ); 115 Text->setGeometry( QRect( 55, 11, this->width()-50, 50 ) );
115 Text->setText( tr( "A <b>storage medium</b> was inserted. Should it be scanned for media files?" ) ); 116 Text->setText( tr( "A <b>storage medium</b> was inserted. Should it be scanned for media files?" ) );
116 117
117 // media box 118 // media box
118 GroupBox1 = new QGroupBox( this, "GroupBox1" ); 119 GroupBox1 = new QGroupBox( this, "GroupBox1" );
119 GroupBox1->setGeometry( QRect( 10, 80, (this->width())-25, 80 ) ); 120 GroupBox1->setGeometry( QRect( 10, 80, (this->width())-25, 80 ) );
120 GroupBox1->setTitle( tr( "Which media files" ) ); 121 GroupBox1->setTitle( tr( "Which media files" ) );
121 122
122 CheckBoxAudio = new QCheckBox( GroupBox1, "CheckBoxAudio" ); 123 CheckBoxAudio = new QCheckBox( GroupBox1, "CheckBoxAudio" );
123 CheckBoxAudio->setGeometry( QRect( 10, 15, (GroupBox1->width()/2)-15 , 15 ) ); 124 CheckBoxAudio->setGeometry( QRect( 10, 15, (GroupBox1->width()/2)-15 , 15 ) );
124 CheckBoxAudio->setText( tr( "Audio" ) ); 125 CheckBoxAudio->setText( tr( "Audio" ) );
125 126
126 CheckBoxImage = new QCheckBox( GroupBox1, "CheckBoxImage" ); 127 CheckBoxImage = new QCheckBox( GroupBox1, "CheckBoxImage" );
127 CheckBoxImage->setGeometry( QRect( 10, 35,(GroupBox1->width()/2)-15, 15 ) ); 128 CheckBoxImage->setGeometry( QRect( 10, 35,(GroupBox1->width()/2)-15, 15 ) );
128 CheckBoxImage->setText( tr( "Image" ) ); 129 CheckBoxImage->setText( tr( "Image" ) );
129 130
130 CheckBoxText = new QCheckBox( GroupBox1, "CheckBoxText" ); 131 CheckBoxText = new QCheckBox( GroupBox1, "CheckBoxText" );
131 CheckBoxText->setGeometry( QRect((GroupBox1->width()/2) , 15, (GroupBox1->width()/2)-15, 15 ) ); 132 CheckBoxText->setGeometry( QRect((GroupBox1->width()/2) , 15, (GroupBox1->width()/2)-15, 15 ) );
132 CheckBoxText->setText( tr( "Text" ) ); 133 CheckBoxText->setText( tr( "Text" ) );
133 134
134 CheckBoxVideo = new QCheckBox( GroupBox1, "CheckBoxVideo" ); 135 CheckBoxVideo = new QCheckBox( GroupBox1, "CheckBoxVideo" );
135 CheckBoxVideo->setGeometry( QRect( (GroupBox1->width()/2), 35, (GroupBox1->width()/2)-15, 15 ) ); 136 CheckBoxVideo->setGeometry( QRect( (GroupBox1->width()/2), 35, (GroupBox1->width()/2)-15, 15 ) );
136 CheckBoxVideo->setText( tr( "Video" ) ); 137 CheckBoxVideo->setText( tr( "Video" ) );
137 138
138 CheckBoxAll = new QCheckBox ( GroupBox1); 139 CheckBoxAll = new QCheckBox ( GroupBox1);
139 CheckBoxAll->setGeometry( QRect( 10, 55, (GroupBox1->width()/2)-15, 15 ) ); 140 CheckBoxAll->setGeometry( QRect( 10, 55, (GroupBox1->width()/2)-15, 15 ) );
140 CheckBoxAll->setText( tr( "All" ) ); 141 CheckBoxAll->setText( tr( "All" ) );
141 QObject::connect( (QObject*)CheckBoxAll, SIGNAL( clicked() ), this, SLOT( deactivateOthers()) ); 142 QObject::connect( (QObject*)CheckBoxAll, SIGNAL( clicked() ), this, SLOT( deactivateOthers()) );
142 143
143 144
144 145
145 CheckBoxLink = new QCheckBox ( GroupBox1); 146 CheckBoxLink = new QCheckBox ( GroupBox1);
146 CheckBoxLink->setGeometry( QRect( (GroupBox1->width()/2), 55, (GroupBox1->width()/2)-15, 15 ) ); 147 CheckBoxLink->setGeometry( QRect( (GroupBox1->width()/2), 55, (GroupBox1->width()/2)-15, 15 ) );
147 CheckBoxLink->setText( tr( "Link apps" ) ); 148 CheckBoxLink->setText( tr( "Link apps" ) );
148 // as long as the feature is not supported 149 // as long as the feature is not supported
149 CheckBoxLink->setEnabled(false); 150 CheckBoxLink->setEnabled(false);
150 151
151 152
152 // select dirs 153 // select dirs
153 154
154 DirSelectText = new QLabel( this, "DirSelectText" ); 155 DirSelectText = new QLabel( this, "DirSelectText" );
155 DirSelectText->setGeometry( QRect( 10, 160,this->width() , 20 ) ); 156 DirSelectText->setGeometry( QRect( 10, 160,this->width() , 20 ) );
156 DirSelectText->setText( tr( "Limit search to dir: (not used yet)" ) ); 157 DirSelectText->setText( tr( "Limit search to dir: (not used yet)" ) );
157 158
158 LineEdit1 = new QLineEdit( this ); 159 LineEdit1 = new QLineEdit( this );
159 LineEdit1->setGeometry( QRect( 10, 180, (this->width())-60, 20 ) ); 160 LineEdit1->setGeometry( QRect( 10, 180, (this->width())-60, 20 ) );
160 161
161 PushButton3 = new QPushButton( this ); 162 PushButton3 = new QPushButton( this );
162 PushButton3->setGeometry( QRect( (this->width())-40, 180, 30, 20 ) ); 163 PushButton3->setGeometry( QRect( (this->width())-40, 180, 30, 20 ) );
163 PushButton3->setText( tr( "Add" ) ); 164 PushButton3->setText( tr( "Add" ) );
164 165
165 166
166 // decision 167 // decision
167 DirSelectText_2 = new QLabel( this ); 168 DirSelectText_2 = new QLabel( this );
168 DirSelectText_2->setGeometry( QRect( 10,240,this->width(), 15 ) ); 169 DirSelectText_2->setGeometry( QRect( 10,240,this->width(), 15 ) );
169 DirSelectText_2->setText( tr( "Your decision will be stored on the medium." ) ); 170 DirSelectText_2->setText( tr( "Your decision will be stored on the medium." ) );
170 171
171 // ask again 172 // ask again
172 AskBox = new QCheckBox( this ); 173 AskBox = new QCheckBox( this );
173 AskBox->setGeometry( QRect( 10, 215, (this->width())-15 , 15 ) ); 174 AskBox->setGeometry( QRect( 10, 215, (this->width())-15 , 15 ) );
174 AskBox->setText( tr( "Do not ask again for this medium" ) ); 175 AskBox->setText( tr( "Do not ask again for this medium" ) );
175 176
176 177
177 AskBox->setChecked(checkagain); 178 AskBox->setChecked(checkagain);
178 CheckBoxAudio->setChecked(checkmimeaudio); 179 CheckBoxAudio->setChecked(checkmimeaudio);
179 CheckBoxImage->setChecked(checkmimeimage); 180 CheckBoxImage->setChecked(checkmimeimage);
180 CheckBoxText->setChecked(checkmimetext); 181 CheckBoxText->setChecked(checkmimetext);
181 CheckBoxVideo->setChecked(checkmimevideo); 182 CheckBoxVideo->setChecked(checkmimevideo);
182 183
183 // buttons 184 // buttons
184 quit = new QPushButton( this ); 185 quit = new QPushButton( this );
185 quit->setGeometry( QRect( (this->width()/2)- 90 , 260, 80, 22 ) ); 186 quit->setGeometry( QRect( (this->width()/2)- 90 , 260, 80, 22 ) );
186 quit->setFocus(); 187 quit->setFocus();
187 quit->setText( tr( "Yes" ) ); 188 quit->setText( tr( "Yes" ) );
188 189
189 quit_2 = new QPushButton( this ); 190 quit_2 = new QPushButton( this );
190 quit_2->setGeometry( QRect((this->width()/2) , 260, 80, 22 ) ); 191 quit_2->setGeometry( QRect((this->width()/2) , 260, 80, 22 ) );
191 quit_2->setText( tr( "No" ) ); 192 quit_2->setText( tr( "No" ) );
192 193
193 QObject::connect( (QObject*)quit, SIGNAL( clicked() ), this, SLOT(yesPressed() ) ); 194 QObject::connect( (QObject*)quit, SIGNAL( clicked() ), this, SLOT(yesPressed() ) );
194 QObject::connect( (QObject*)quit_2, SIGNAL( clicked() ), this, SLOT(noPressed() ) ); 195 QObject::connect( (QObject*)quit_2, SIGNAL( clicked() ), this, SLOT(noPressed() ) );
195 196
196 197
197} 198}
198 199
199 200
200void MediumMountGui::deactivateOthers() { 201void MediumMountGui::deactivateOthers() {
201 bool mod = !(CheckBoxAll->isChecked()); 202 bool mod = !(CheckBoxAll->isChecked());
202 203
203 //if (!CheckBoxVideo->isChecked()){ 204 //if (!CheckBoxVideo->isChecked()){
204 // mod = false; 205 // mod = false;
205 //} else { 206 //} else {
206 // mod = true; 207 // mod = true;
207 //} 208 //}
208 CheckBoxVideo->setEnabled(mod); 209 CheckBoxVideo->setEnabled(mod);
209 CheckBoxAudio->setEnabled(mod); 210 CheckBoxAudio->setEnabled(mod);
210 CheckBoxText->setEnabled(mod); 211 CheckBoxText->setEnabled(mod);
211 CheckBoxImage->setEnabled(mod); 212 CheckBoxImage->setEnabled(mod);
212} 213}
213 214
214void MediumMountGui::yesPressed() { 215void MediumMountGui::yesPressed() {
215 writeConfig(true); 216 writeConfig(true);
216 // and do something 217 // and do something
217 accept(); 218 accept();
218} 219}
219 220
220 221
221QStringList MediumMountGui::mimeTypes(){ 222QStringList MediumMountGui::mimeTypes(){
222 return mimeTypeList; 223 return mimeTypeList;
223} 224}
224 225
225void MediumMountGui::noPressed() { 226void MediumMountGui::noPressed() {
226 writeConfig(false); 227 writeConfig(false);
227 reject(); 228 reject();
228} 229}
229 230
230MediumMountGui::~MediumMountGui(){ 231MediumMountGui::~MediumMountGui(){
231} 232}
232 233
diff --git a/libopie/oconfig.h b/libopie/oconfig.h
index c97fb6a..f6227d1 100644
--- a/libopie/oconfig.h
+++ b/libopie/oconfig.h
@@ -1,48 +1,48 @@
1/* 1/*
2               =. This file is part of the OPIE Project 2               =. This file is part of the OPIE Project
3             .=l. Copyright (c) 2002 Holger 'zecke' Freyther<freyther@kde.org> 3             .=l. Copyright (c) 2002 Holger 'zecke' Freyther<freyther@kde.org>
4           .>+-= 4           .>+-=
5 _;:,     .>    :=|. This library is free software; you can 5 _;:,     .>    :=|. This library is free software; you can
6.> <`_,   >  .   <= redistribute it and/or modify it under 6.> <`_,   >  .   <= redistribute it and/or modify it under
7:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 7:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
8.="- .-=="i,     .._ License as published by the Free Software 8.="- .-=="i,     .._ License as published by the Free Software
9 - .   .-<_>     .<> Foundation; either version 2 of the License, 9 - .   .-<_>     .<> Foundation; either version 2 of the License,
10     ._= =}       : or (at your option) any later version. 10     ._= =}       : or (at your option) any later version.
11    .%`+i>       _;_. 11    .%`+i>       _;_.
12    .i_,=:_.      -<s. This library is distributed in the hope that 12    .i_,=:_.      -<s. This library is distributed in the hope that
13     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 13     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
14    : ..    .:,     . . . without even the implied warranty of 14    : ..    .:,     . . . without even the implied warranty of
15    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 15    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
16  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 16  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
17..}^=.=       =       ; Library General Public License for more 17..}^=.=       =       ; Library General Public License for more
18++=   -.     .`     .: details. 18++=   -.     .`     .: details.
19 :     =  ...= . :.=- 19 :     =  ...= . :.=-
20 -.   .:....=;==+<; You should have received a copy of the GNU 20 -.   .:....=;==+<; You should have received a copy of the GNU
21  -_. . .   )=.  = Library General Public License along with 21  -_. . .   )=.  = Library General Public License along with
22    --        :-=` this library; see the file COPYING.LIB. 22    --        :-=` this library; see the file COPYING.LIB.
23 If not, write to the Free Software Foundation, 23 If not, write to the Free Software Foundation,
24 Inc., 59 Temple Place - Suite 330, 24 Inc., 59 Temple Place - Suite 330,
25 Boston, MA 02111-1307, USA. 25 Boston, MA 02111-1307, USA.
26 26
27*/ 27*/
28 28
29 29
30#include <qpe/config.h> 30#include <qpe/config.h>
31 31
32#ifndef opieconfig_h 32#ifndef opieconfig_h
33#define opieconfig_h 33#define opieconfig_h
34 34
35/** It supports all Config items + it lets you decide 35/** It supports all Config items + it lets you decide
36 * which file to use. 36 * which file to use.
37 */ 37 */
38 38
39class OConfig : public Config { 39class OConfig : public Config {
40 public: 40 public:
41 OConfig( const QString &filename ); 41 OConfig( const QString &filename );
42 ~OConfig(); 42 ~OConfig();
43 QString fileName() const; 43 QString fileName() const;
44 44 void read( ) { Config::read(); };
45}; 45};
46 46
47#endif 47#endif
48 48