summaryrefslogtreecommitdiff
authorkergoth <kergoth>2002-05-15 16:44:53 (UTC)
committer kergoth <kergoth>2002-05-15 16:44:53 (UTC)
commitaa5d79399aa991aa84eb8b4f48d55202473990ef (patch) (unidiff)
treedda2b43b5ad001435175cce1ec943df21ef63c43
parent7844e2aebcb289f55bf10f22ea1250773c8ad7bd (diff)
downloadopie-aa5d79399aa991aa84eb8b4f48d55202473990ef.zip
opie-aa5d79399aa991aa84eb8b4f48d55202473990ef.tar.gz
opie-aa5d79399aa991aa84eb8b4f48d55202473990ef.tar.bz2
hmm, we dont need the same things in here twice. Compiles again.
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/unsupported/filebrowser/filebrowser.cpp38
1 files changed, 0 insertions, 38 deletions
diff --git a/noncore/unsupported/filebrowser/filebrowser.cpp b/noncore/unsupported/filebrowser/filebrowser.cpp
index 7dabdb6..d16e771 100644
--- a/noncore/unsupported/filebrowser/filebrowser.cpp
+++ b/noncore/unsupported/filebrowser/filebrowser.cpp
@@ -352,403 +352,384 @@ void FileView::generateDir( const QString & dir )
352 352
353} 353}
354 354
355void FileView::rename() 355void FileView::rename()
356{ 356{
357 itemToRename = (FileItem *) currentItem(); 357 itemToRename = (FileItem *) currentItem();
358 const QPixmap * pm; 358 const QPixmap * pm;
359 int pmw; 359 int pmw;
360 360
361 if( itemToRename == NULL ) return; 361 if( itemToRename == NULL ) return;
362 362
363 if( ( pm = itemToRename->pixmap( 0 ) ) == NULL ) 363 if( ( pm = itemToRename->pixmap( 0 ) ) == NULL )
364 pmw = 0; 364 pmw = 0;
365 else 365 else
366 pmw = pm->width(); 366 pmw = pm->width();
367 367
368 ensureItemVisible( itemToRename ); 368 ensureItemVisible( itemToRename );
369 horizontalScrollBar()->setValue( 0 ); 369 horizontalScrollBar()->setValue( 0 );
370 horizontalScrollBar()->setEnabled( FALSE ); 370 horizontalScrollBar()->setEnabled( FALSE );
371 verticalScrollBar()->setEnabled( FALSE ); 371 verticalScrollBar()->setEnabled( FALSE );
372 372
373 selected = isSelected( itemToRename ); 373 selected = isSelected( itemToRename );
374 setSelected( itemToRename, FALSE ); 374 setSelected( itemToRename, FALSE );
375 375
376 if( le == NULL ){ 376 if( le == NULL ){
377 le = new InlineEdit( this ); 377 le = new InlineEdit( this );
378 le->setFrame( FALSE ); 378 le->setFrame( FALSE );
379 connect( le, SIGNAL( lostFocus() ), SLOT( endRenaming() ) ); 379 connect( le, SIGNAL( lostFocus() ), SLOT( endRenaming() ) );
380 } 380 }
381 381
382 QRect r = itemRect( itemToRename ); 382 QRect r = itemRect( itemToRename );
383 r.setTop( r.top() + frameWidth() + 1 ); 383 r.setTop( r.top() + frameWidth() + 1 );
384 r.setLeft( r.left() + frameWidth() + pmw ); 384 r.setLeft( r.left() + frameWidth() + pmw );
385 r.setBottom( r.bottom() + frameWidth() ); 385 r.setBottom( r.bottom() + frameWidth() );
386 r.setWidth( columnWidth( 0 ) - pmw ); 386 r.setWidth( columnWidth( 0 ) - pmw );
387 387
388 le->setGeometry( r ); 388 le->setGeometry( r );
389 le->setText( itemToRename->text( 0 ) ); 389 le->setText( itemToRename->text( 0 ) );
390 le->selectAll(); 390 le->selectAll();
391 le->show(); 391 le->show();
392 le->setFocus(); 392 le->setFocus();
393} 393}
394 394
395void FileView::endRenaming() 395void FileView::endRenaming()
396{ 396{
397 if( le && itemToRename ){ 397 if( le && itemToRename ){
398 le->hide(); 398 le->hide();
399 setSelected( itemToRename, selected ); 399 setSelected( itemToRename, selected );
400 400
401 if( !itemToRename->rename( le->text() ) ){ 401 if( !itemToRename->rename( le->text() ) ){
402 QMessageBox::warning( this, tr( "Rename file" ), 402 QMessageBox::warning( this, tr( "Rename file" ),
403 tr( "Rename failed!" ), tr( "&Ok" ) ); 403 tr( "Rename failed!" ), tr( "&Ok" ) );
404 } else { 404 } else {
405 updateDir(); 405 updateDir();
406 } 406 }
407 itemToRename = NULL; 407 itemToRename = NULL;
408 horizontalScrollBar()->setEnabled( TRUE ); 408 horizontalScrollBar()->setEnabled( TRUE );
409 verticalScrollBar()->setEnabled( TRUE ); 409 verticalScrollBar()->setEnabled( TRUE );
410 } 410 }
411} 411}
412 412
413void FileView::copy() 413void FileView::copy()
414{ 414{
415 // dont keep cut files any longer than necessary 415 // dont keep cut files any longer than necessary
416 // ##### a better inmplementation might be to rename the CUT file 416 // ##### a better inmplementation might be to rename the CUT file
417 // ##### to ".QPE-FILEBROWSER-MOVING" rather than copying it. 417 // ##### to ".QPE-FILEBROWSER-MOVING" rather than copying it.
418 system ( "rm -rf /tmp/qpemoving" ); 418 system ( "rm -rf /tmp/qpemoving" );
419 419
420 FileItem * i; 420 FileItem * i;
421 421
422 if((i = (FileItem *) firstChild()) == 0) return; 422 if((i = (FileItem *) firstChild()) == 0) return;
423 423
424 flist.clear(); 424 flist.clear();
425 while( i ){ 425 while( i ){
426 if( i->isSelected() /*&& !i->isDir()*/ ){ 426 if( i->isSelected() /*&& !i->isDir()*/ ){
427 flist += i->getFilePath(); 427 flist += i->getFilePath();
428 } 428 }
429 i = (FileItem *) i->nextSibling(); 429 i = (FileItem *) i->nextSibling();
430 } 430 }
431} 431}
432 432
433void FileView::paste() 433void FileView::paste()
434{ 434{
435 int i, err; 435 int i, err;
436 QString cmd, dest, basename, cd = currentDir; 436 QString cmd, dest, basename, cd = currentDir;
437 437
438 if(cd == "/") cd = ""; 438 if(cd == "/") cd = "";
439 439
440 for ( QStringList::Iterator it = flist.begin(); it != flist.end(); ++it ) { 440 for ( QStringList::Iterator it = flist.begin(); it != flist.end(); ++it ) {
441 basename = (*it).mid((*it).findRev("/") + 1, (*it).length()); 441 basename = (*it).mid((*it).findRev("/") + 1, (*it).length());
442 442
443 dest = cd + "/" + basename; 443 dest = cd + "/" + basename;
444 if( QFile( dest ).exists() ){ 444 if( QFile( dest ).exists() ){
445 i = 1; 445 i = 1;
446 dest = cd + "/Copy of " + basename; 446 dest = cd + "/Copy of " + basename;
447 while( QFile( dest ).exists() ){ 447 while( QFile( dest ).exists() ){
448 dest.sprintf( "%s/Copy (%d) of %s", (const char *) cd, i++, 448 dest.sprintf( "%s/Copy (%d) of %s", (const char *) cd, i++,
449 (const char *) basename ); 449 (const char *) basename );
450 } 450 }
451 } 451 }
452 452
453 // 453 //
454 // Copy a directory recursively using the "cp" command - 454 // Copy a directory recursively using the "cp" command -
455 // may have to be changed 455 // may have to be changed
456 // 456 //
457 if( QFileInfo( (*it) ).isDir() ){ 457 if( QFileInfo( (*it) ).isDir() ){
458 cmd = "/bin/cp -fpR \"" + (*it) +"\" " + "\"" + dest + "\""; 458 cmd = "/bin/cp -fpR \"" + (*it) +"\" " + "\"" + dest + "\"";
459 err = system( (const char *) cmd ); 459 err = system( (const char *) cmd );
460 } else if( !copyFile( dest, (*it) ) ){ 460 } else if( !copyFile( dest, (*it) ) ){
461 err = -1; 461 err = -1;
462 } else { 462 } else {
463 err = 0; 463 err = 0;
464 } 464 }
465 465
466 if ( err != 0 ) { 466 if ( err != 0 ) {
467 QMessageBox::warning( this, tr("Paste file"), tr("Paste failed!"), 467 QMessageBox::warning( this, tr("Paste file"), tr("Paste failed!"),
468 tr("Ok") ); 468 tr("Ok") );
469 break; 469 break;
470 } else { 470 } else {
471 updateDir(); 471 updateDir();
472 QListViewItem * i = firstChild(); 472 QListViewItem * i = firstChild();
473 basename = dest.mid( dest.findRev("/") + 1, dest.length() ); 473 basename = dest.mid( dest.findRev("/") + 1, dest.length() );
474 474
475 while( i ){ 475 while( i ){
476 if( i->text(0) == basename ){ 476 if( i->text(0) == basename ){
477 setCurrentItem( i ); 477 setCurrentItem( i );
478 ensureItemVisible( i ); 478 ensureItemVisible( i );
479 break; 479 break;
480 } 480 }
481 i = i->nextSibling(); 481 i = i->nextSibling();
482 } 482 }
483 } 483 }
484 } 484 }
485} 485}
486 486
487bool FileView::copyFile( const QString & dest, const QString & src ) 487bool FileView::copyFile( const QString & dest, const QString & src )
488{ 488{
489 char bf[ 50000 ]; 489 char bf[ 50000 ];
490 int bytesRead; 490 int bytesRead;
491 bool success = TRUE; 491 bool success = TRUE;
492 struct stat status; 492 struct stat status;
493 493
494 QFile s( src ); 494 QFile s( src );
495 QFile d( dest ); 495 QFile d( dest );
496 496
497 if( s.open( IO_ReadOnly | IO_Raw ) && 497 if( s.open( IO_ReadOnly | IO_Raw ) &&
498 d.open( IO_WriteOnly | IO_Raw ) ) 498 d.open( IO_WriteOnly | IO_Raw ) )
499 { 499 {
500 while( (bytesRead = s.readBlock( bf, sizeof( bf ) )) == 500 while( (bytesRead = s.readBlock( bf, sizeof( bf ) )) ==
501 sizeof( bf ) ) 501 sizeof( bf ) )
502 { 502 {
503 if( d.writeBlock( bf, sizeof( bf ) ) != sizeof( bf ) ){ 503 if( d.writeBlock( bf, sizeof( bf ) ) != sizeof( bf ) ){
504 success = FALSE; 504 success = FALSE;
505 break; 505 break;
506 } 506 }
507 } 507 }
508 if( success && (bytesRead > 0) ){ 508 if( success && (bytesRead > 0) ){
509 d.writeBlock( bf, bytesRead ); 509 d.writeBlock( bf, bytesRead );
510 } 510 }
511 } else { 511 } else {
512 success = FALSE; 512 success = FALSE;
513 } 513 }
514 514
515 // Set file permissions 515 // Set file permissions
516 if( stat( (const char *) src, &status ) == 0 ){ 516 if( stat( (const char *) src, &status ) == 0 ){
517 chmod( (const char *) dest, status.st_mode ); 517 chmod( (const char *) dest, status.st_mode );
518 } 518 }
519 519
520 return success; 520 return success;
521} 521}
522 522
523void FileView::cut() 523void FileView::cut()
524{ 524{
525 int err; 525 int err;
526 // ##### a better inmplementation might be to rename the CUT file 526 // ##### a better inmplementation might be to rename the CUT file
527 // ##### to ".QPE-FILEBROWSER-MOVING" rather than copying it. 527 // ##### to ".QPE-FILEBROWSER-MOVING" rather than copying it.
528 QString cmd, dest, basename, cd = "/tmp/qpemoving"; 528 QString cmd, dest, basename, cd = "/tmp/qpemoving";
529 QStringList newflist; 529 QStringList newflist;
530 newflist.clear(); 530 newflist.clear();
531 531
532 cmd = "rm -rf " + cd; 532 cmd = "rm -rf " + cd;
533 system ( (const char *) cmd ); 533 system ( (const char *) cmd );
534 cmd = "mkdir " + cd; 534 cmd = "mkdir " + cd;
535 system( (const char *) cmd ); 535 system( (const char *) cmd );
536 536
537// get the names of the files to cut 537// get the names of the files to cut
538 FileItem * item; 538 FileItem * item;
539 539
540 if((item = (FileItem *) firstChild()) == 0) return; 540 if((item = (FileItem *) firstChild()) == 0) return;
541 541
542 flist.clear(); 542 flist.clear();
543 while( item ){ 543 while( item ){
544 if( ite
545 // ##### a better inmplementation might be to rename the CUT file
546 // ##### to ".QPE-FILEBROWSER-MOVING" rather than copying it.
547 QString cmd, dest, basename, cd = "/tmp/qpemoving";
548 QStringList newflist;
549 newflist.clear();
550
551 cmd = "rm -rf " + cd;
552 system ( (const char *) cmd );
553 cmd = "mkdir " + cd;
554 system( (const char *) cmd );
555
556// get the names of the files to cut
557 FileItem * item;
558
559 if((item = (FileItem *) firstChild()) == 0) return;
560
561 flist.clear();
562 while( item ){
563 if( item->isSelected() /*&& !item->isDir()*/ ){ 544 if( item->isSelected() /*&& !item->isDir()*/ ){
564 flist += item->getFilePath(); 545 flist += item->getFilePath();
565 } 546 }
566 item = (FileItem *) item->nextSibling(); 547 item = (FileItem *) item->nextSibling();
567 } 548 }
568 549
569// move these files into a tmp dir 550// move these files into a tmp dir
570 for ( QStringList::Iterator it = flist.begin(); it != flist.end(); ++it ) { 551 for ( QStringList::Iterator it = flist.begin(); it != flist.end(); ++it ) {
571 basename = (*it).mid((*it).findRev("/") + 1, (*it).length()); 552 basename = (*it).mid((*it).findRev("/") + 1, (*it).length());
572 553
573 dest = cd + "/" + basename; 554 dest = cd + "/" + basename;
574 555
575 newflist += dest; 556 newflist += dest;
576 557
577 cmd = "/bin/mv -f \"" + (*it) +"\" " + "\"" + dest + "\""; 558 cmd = "/bin/mv -f \"" + (*it) +"\" " + "\"" + dest + "\"";
578 err = system( (const char *) cmd ); 559 err = system( (const char *) cmd );
579 560
580 if ( err != 0 ) { 561 if ( err != 0 ) {
581 QMessageBox::warning( this, tr("Cut file"), tr("Cut failed!"), 562 QMessageBox::warning( this, tr("Cut file"), tr("Cut failed!"),
582 tr("Ok") ); 563 tr("Ok") );
583 break; 564 break;
584 } else { 565 } else {
585 updateDir(); 566 updateDir();
586 QListViewItem * im = firstChild(); 567 QListViewItem * im = firstChild();
587 basename = dest.mid( dest.findRev("/") + 1, dest.length() ); 568 basename = dest.mid( dest.findRev("/") + 1, dest.length() );
588 569
589 while( im ){ 570 while( im ){
590 if( im->text(0) == basename ){ 571 if( im->text(0) == basename ){
591 setCurrentItem( im ); 572 setCurrentItem( im );
592 ensureItemVisible( im ); 573 ensureItemVisible( im );
593 break; 574 break;
594 } 575 }
595 im = im->nextSibling(); 576 im = im->nextSibling();
596 } 577 }
597 } 578 }
598 } 579 }
599 580
600 // update the filelist to point to tmp dir so paste works nicely 581 // update the filelist to point to tmp dir so paste works nicely
601 flist = newflist; 582 flist = newflist;
602} 583}
603 584
604void FileView::del() 585void FileView::del()
605{ 586{
606 FileItem * i; 587 FileItem * i;
607 QStringList fl; 588 QStringList fl;
608 QString cmd; 589 QString cmd;
609 int err; 590 int err;
610 591
611 if((i = (FileItem *) firstChild()) == 0) return; 592 if((i = (FileItem *) firstChild()) == 0) return;
612 593
613 while( i ){ 594 while( i ){
614 if( i->isSelected() ){ 595 if( i->isSelected() ){
615 fl += i->getFilePath(); 596 fl += i->getFilePath();
616 } 597 }
617 i = (FileItem *) i->nextSibling(); 598 i = (FileItem *) i->nextSibling();
618 } 599 }
619 if( fl.count() < 1 ) return; 600 if( fl.count() < 1 ) return;
620 601
621 if( QMessageBox::warning( this, tr("Delete"), tr("Are you sure?"), 602 if( QMessageBox::warning( this, tr("Delete"), tr("Are you sure?"),
622 tr("Yes"), tr("No") ) == 0) 603 tr("Yes"), tr("No") ) == 0)
623 { 604 {
624 // 605 //
625 // Dependant upon the "rm" command - will probably have to be replaced 606 // Dependant upon the "rm" command - will probably have to be replaced
626 // 607 //
627 for ( QStringList::Iterator it = fl.begin(); it != fl.end(); ++it ) { 608 for ( QStringList::Iterator it = fl.begin(); it != fl.end(); ++it ) {
628 cmd = "/bin/rm -rf \"" + (*it) + "\""; 609 cmd = "/bin/rm -rf \"" + (*it) + "\"";
629 err = system( (const char *) cmd ); 610 err = system( (const char *) cmd );
630 if ( err != 0 ) { 611 if ( err != 0 ) {
631 QMessageBox::warning( this, tr("Delete"), tr("Delete failed!"), 612 QMessageBox::warning( this, tr("Delete"), tr("Delete failed!"),
632 tr("Ok") ); 613 tr("Ok") );
633 break; 614 break;
634 } 615 }
635 } 616 }
636 updateDir(); 617 updateDir();
637 } 618 }
638} 619}
639 620
640void FileView::newFolder() 621void FileView::newFolder()
641{ 622{
642 int t = 1; 623 int t = 1;
643 FileItem * i; 624 FileItem * i;
644 QString nd = currentDir + "/NewFolder"; 625 QString nd = currentDir + "/NewFolder";
645 626
646 while( QFile( nd ).exists() ){ 627 while( QFile( nd ).exists() ){
647 nd.sprintf( "%s/NewFolder (%d)", (const char *) currentDir, t++ ); 628 nd.sprintf( "%s/NewFolder (%d)", (const char *) currentDir, t++ );
648 } 629 }
649 630
650 if( mkdir( (const char *) nd, 0777 ) != 0){ 631 if( mkdir( (const char *) nd, 0777 ) != 0){
651 QMessageBox::warning( this, tr( "New folder" ), 632 QMessageBox::warning( this, tr( "New folder" ),
652 tr( "Folder creation failed!" ), 633 tr( "Folder creation failed!" ),
653 tr( "Ok" ) ); 634 tr( "Ok" ) );
654 return; 635 return;
655 } 636 }
656 updateDir(); 637 updateDir();
657 638
658 if((i = (FileItem *) firstChild()) == 0) return; 639 if((i = (FileItem *) firstChild()) == 0) return;
659 640
660 while( i ){ 641 while( i ){
661 if( i->isDir() && ( i->getFilePath() == nd ) ){ 642 if( i->isDir() && ( i->getFilePath() == nd ) ){
662 setCurrentItem( i ); 643 setCurrentItem( i );
663 rename(); 644 rename();
664 break; 645 break;
665 } 646 }
666 i = (FileItem *) i->nextSibling(); 647 i = (FileItem *) i->nextSibling();
667 } 648 }
668} 649}
669 650
670void FileView::viewAsText() 651void FileView::viewAsText()
671{ 652{
672 FileItem * i = (FileItem *) currentItem(); 653 FileItem * i = (FileItem *) currentItem();
673 QCopEnvelope e("QPE/Application/textedit","setDocument(QString)"); 654 QCopEnvelope e("QPE/Application/textedit","setDocument(QString)");
674 e << i->getFilePath(); 655 e << i->getFilePath();
675// Global::execute( "textedit -f ", i->getFilePath() ); 656// Global::execute( "textedit -f ", i->getFilePath() );
676} 657}
677 658
678void FileView::itemClicked( QListViewItem * i) 659void FileView::itemClicked( QListViewItem * i)
679{ 660{
680 FileItem * t = (FileItem *) i; 661 FileItem * t = (FileItem *) i;
681 662
682 if( t == NULL ) return; 663 if( t == NULL ) return;
683 if( t->isDir() ){ 664 if( t->isDir() ){
684 setDir( t->getFilePath() ); 665 setDir( t->getFilePath() );
685 } 666 }
686} 667}
687 668
688void FileView::itemDblClicked( QListViewItem * i) 669void FileView::itemDblClicked( QListViewItem * i)
689{ 670{
690 if(menuKeepsOpen){ 671 if(menuKeepsOpen){
691 cancelMenuTimer(); 672 cancelMenuTimer();
692 } 673 }
693 674
694 FileItem * t = (FileItem *) i; 675 FileItem * t = (FileItem *) i;
695 676
696 if(t == NULL) return; 677 if(t == NULL) return;
697 if(t->launch() == -1){ 678 if(t->launch() == -1){
698 QMessageBox::warning( this, tr( "Launch Application" ), 679 QMessageBox::warning( this, tr( "Launch Application" ),
699 tr( "Launch failed!" ), tr( "Ok" ) ); 680 tr( "Launch failed!" ), tr( "Ok" ) );
700 } 681 }
701} 682}
702 683
703void FileView::parentDir() 684void FileView::parentDir()
704{ 685{
705 setDir( currentDir + "./.." ); 686 setDir( currentDir + "./.." );
706} 687}
707 688
708void FileView::lastDir() 689void FileView::lastDir()
709{ 690{
710 if( dirHistory.count() == 0 ) return; 691 if( dirHistory.count() == 0 ) return;
711 692
712 QString newDir = dirHistory.last(); 693 QString newDir = dirHistory.last();
713 dirHistory.remove( dirHistory.last() ); 694 dirHistory.remove( dirHistory.last() );
714 generateDir( newDir ); 695 generateDir( newDir );
715} 696}
716 697
717void FileView::contentsMousePressEvent( QMouseEvent * e ) 698void FileView::contentsMousePressEvent( QMouseEvent * e )
718{ 699{
719 QListView::contentsMousePressEvent( e ); 700 QListView::contentsMousePressEvent( e );
720 menuTimer.start( 750, TRUE ); 701 menuTimer.start( 750, TRUE );
721} 702}
722 703
723void FileView::contentsMouseReleaseEvent( QMouseEvent * e ) 704void FileView::contentsMouseReleaseEvent( QMouseEvent * e )
724{ 705{
725 QListView::contentsMouseReleaseEvent( e ); 706 QListView::contentsMouseReleaseEvent( e );
726 if(!menuKeepsOpen){ 707 if(!menuKeepsOpen){
727 menuTimer.stop(); 708 menuTimer.stop();
728 } 709 }
729 710
730} 711}
731 712
732void FileView::cancelMenuTimer() 713void FileView::cancelMenuTimer()
733{ 714{
734 if( menuTimer.isActive() ) 715 if( menuTimer.isActive() )
735 menuTimer.stop(); 716 menuTimer.stop();
736} 717}
737 718
738void FileView::addToDocuments() 719void FileView::addToDocuments()
739{ 720{
740 FileItem * i = (FileItem *) currentItem(); 721 FileItem * i = (FileItem *) currentItem();
741 DocLnk f; 722 DocLnk f;
742 QString n = i->text(0); 723 QString n = i->text(0);
743 n.replace(QRegExp("\\..*"),""); 724 n.replace(QRegExp("\\..*"),"");
744 f.setName( n ); 725 f.setName( n );
745 f.setFile( i->getFilePath() ); 726 f.setFile( i->getFilePath() );
746 f.writeLink(); 727 f.writeLink();
747} 728}
748 729
749void FileView::run() 730void FileView::run()
750{ 731{
751 FileItem * i = (FileItem *) currentItem(); 732 FileItem * i = (FileItem *) currentItem();
752 i->launch(); 733 i->launch();
753} 734}
754 735
@@ -919,211 +900,192 @@ void FileBrowser::init(const QString & dir)
919 pasteAction = new QAction( tr("Paste"), Resource::loadPixmap( "paste" ), 900 pasteAction = new QAction( tr("Paste"), Resource::loadPixmap( "paste" ),
920 QString::null, 0, this, 0 ); 901 QString::null, 0, this, 0 );
921 connect( pasteAction, SIGNAL( activated() ), fileView, SLOT( paste() ) ); 902 connect( pasteAction, SIGNAL( activated() ), fileView, SLOT( paste() ) );
922 pasteAction->addTo( toolBar ); 903 pasteAction->addTo( toolBar );
923 904
924// dirLabel = new QLabel(this, "DirLabel"); 905// dirLabel = new QLabel(this, "DirLabel");
925 906
926 connect( fileView, SIGNAL( dirChanged() ), SLOT( updateDirMenu() ) ); 907 connect( fileView, SIGNAL( dirChanged() ), SLOT( updateDirMenu() ) );
927 updateDirMenu(); 908 updateDirMenu();
928 909
929 QCopChannel* pcmciaChannel = new QCopChannel( "QPE/Card", this ); 910 QCopChannel* pcmciaChannel = new QCopChannel( "QPE/Card", this );
930 connect( pcmciaChannel, SIGNAL(received(const QCString &, const QByteArray &)), 911 connect( pcmciaChannel, SIGNAL(received(const QCString &, const QByteArray &)),
931 this, SLOT(pcmciaMessage( const QCString &, const QByteArray &)) ); 912 this, SLOT(pcmciaMessage( const QCString &, const QByteArray &)) );
932} 913}
933 914
934void FileBrowser::pcmciaMessage( const QCString &msg, const QByteArray &) 915void FileBrowser::pcmciaMessage( const QCString &msg, const QByteArray &)
935{ 916{
936 if ( msg == "mtabChanged()" ) { 917 if ( msg == "mtabChanged()" ) {
937 // ## Only really needed if current dir is on a card 918 // ## Only really needed if current dir is on a card
938 fileView->updateDir(); 919 fileView->updateDir();
939 } 920 }
940} 921}
941 922
942void FileBrowser::changeCaption(const QString & dir) { 923void FileBrowser::changeCaption(const QString & dir) {
943 setCaption( dir); 924 setCaption( dir);
944} 925}
945 926
946void FileBrowser::dirSelected( int id ) 927void FileBrowser::dirSelected( int id )
947{ 928{
948 int i = 0, j; 929 int i = 0, j;
949 QString dir; 930 QString dir;
950 931
951 // Bulid target dir from menu 932 // Bulid target dir from menu
952 while( (j = dirMenu->idAt( i )) != id ){ 933 while( (j = dirMenu->idAt( i )) != id ){
953 dir += dirMenu->text( j ).stripWhiteSpace(); 934 dir += dirMenu->text( j ).stripWhiteSpace();
954 if( dirMenu->text( j ) != "/" ) dir += "/"; 935 if( dirMenu->text( j ) != "/" ) dir += "/";
955 i++; 936 i++;
956 } 937 }
957 dir += dirMenu->text( dirMenu->idAt( i ) ).stripWhiteSpace(); 938 dir += dirMenu->text( dirMenu->idAt( i ) ).stripWhiteSpace();
958 939
959 fileView->setDir( dir ); 940 fileView->setDir( dir );
960} 941}
961 942
962void FileBrowser::updateDirMenu() 943void FileBrowser::updateDirMenu()
963{ 944{
964 QString spc, cd = fileView->cd(); 945 QString spc, cd = fileView->cd();
965 QStringList l = QStringList::split( "/", cd ); 946 QStringList l = QStringList::split( "/", cd );
966 int i = 0; 947 int i = 0;
967 948
968 dirMenu->clear(); 949 dirMenu->clear();
969 dirMenu->insertItem( tr( "/" ), this, SLOT( dirSelected(int) ) ); 950 dirMenu->insertItem( tr( "/" ), this, SLOT( dirSelected(int) ) );
970 951
971 for ( QStringList::Iterator it = l.begin(); it != l.end(); ++it ) { 952 for ( QStringList::Iterator it = l.begin(); it != l.end(); ++it ) {
972 spc.fill( ' ', i++); 953 spc.fill( ' ', i++);
973 dirMenu->insertItem( spc + (*it), this, 954 dirMenu->insertItem( spc + (*it), this,
974 SLOT( dirSelected(int) ) ); 955 SLOT( dirSelected(int) ) );
975 } 956 }
976 dirMenu->setItemChecked( dirMenu->idAt( l.count() ), TRUE ); 957 dirMenu->setItemChecked( dirMenu->idAt( l.count() ), TRUE );
977 958
978 lastAction->setEnabled( fileView->history().count() != 0 ); 959 lastAction->setEnabled( fileView->history().count() != 0 );
979 upAction->setEnabled( cd != "/" ); 960 upAction->setEnabled( cd != "/" );
980} 961}
981 962
982void FileBrowser::sortName() 963void FileBrowser::sortName()
983{ 964{
984 fileView->setSorting( 0, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) ); 965 fileView->setSorting( 0, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) );
985 fileView->sort(); 966 fileView->sort();
986 sortMenu->setItemChecked( sortMenu->idAt( 0 ), TRUE ); 967 sortMenu->setItemChecked( sortMenu->idAt( 0 ), TRUE );
987 sortMenu->setItemChecked( sortMenu->idAt( 1 ), FALSE ); 968 sortMenu->setItemChecked( sortMenu->idAt( 1 ), FALSE );
988 sortMenu->setItemChecked( sortMenu->idAt( 2 ), FALSE ); 969 sortMenu->setItemChecked( sortMenu->idAt( 2 ), FALSE );
989 sortMenu->setItemChecked( sortMenu->idAt( 3 ), FALSE ); 970 sortMenu->setItemChecked( sortMenu->idAt( 3 ), FALSE );
990} 971}
991 972
992void FileBrowser::sortSize() 973void FileBrowser::sortSize()
993{ 974{
994 fileView->setSorting( 1, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) ); 975 fileView->setSorting( 1, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) );
995 fileView->sort(); 976 fileView->sort();
996 sortMenu->setItemChecked( sortMenu->idAt( 0 ), FALSE ); 977 sortMenu->setItemChecked( sortMenu->idAt( 0 ), FALSE );
997 sortMenu->setItemChecked( sortMenu->idAt( 1 ), TRUE ); 978 sortMenu->setItemChecked( sortMenu->idAt( 1 ), TRUE );
998 sortMenu->setItemChecked( sortMenu->idAt( 2 ), FALSE ); 979 sortMenu->setItemChecked( sortMenu->idAt( 2 ), FALSE );
999 sortMenu->setItemChecked( sortMenu->idAt( 3 ), FALSE ); 980 sortMenu->setItemChecked( sortMenu->idAt( 3 ), FALSE );
1000} 981}
1001 982
1002void FileBrowser::sortDate() 983void FileBrowser::sortDate()
1003{ 984{
1004 fileView->setSorting( 2, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) ); 985 fileView->setSorting( 2, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) );
1005 fileView->sort(); 986 fileView->sort();
1006 sortMenu->setItemChecked( sortMenu->idAt( 0 ), FALSE ); 987 sortMenu->setItemChecked( sortMenu->idAt( 0 ), FALSE );
1007 sortMenu->setItemChecked( sortMenu->idAt( 1 ), FALSE ); 988 sortMenu->setItemChecked( sortMenu->idAt( 1 ), FALSE );
1008 sortMenu->setItemChecked( sortMenu->idAt( 2 ), TRUE ); 989 sortMenu->setItemChecked( sortMenu->idAt( 2 ), TRUE );
1009 sortMenu->setItemChecked( sortMenu->idAt( 3 ), FALSE ); 990 sortMenu->setItemChecked( sortMenu->idAt( 3 ), FALSE );
1010} 991}
1011 992
1012void FileBrowser::sortType() 993void FileBrowser::sortType()
1013{ 994{
1014 fileView->setSorting( 3, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) ); 995 fileView->setSorting( 3, sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) );
1015 fileView->sort(); 996 fileView->sort();
1016 sortMenu->setItemChecked( sortMenu->idAt( 0 ), FALSE ); 997 sortMenu->setItemChecked( sortMenu->idAt( 0 ), FALSE );
1017 sortMenu->setItemChecked( sortMenu->idAt( 1 ), FALSE ); 998 sortMenu->setItemChecked( sortMenu->idAt( 1 ), FALSE );
1018 sortMenu->setItemChecked( sortMenu->idAt( 2 ), FALSE ); 999 sortMenu->setItemChecked( sortMenu->idAt( 2 ), FALSE );
1019 sortMenu->setItemChecked( sortMenu->idAt( 3 ), TRUE ); 1000 sortMenu->setItemChecked( sortMenu->idAt( 3 ), TRUE );
1020} 1001}
1021 1002
1022void FileBrowser::updateSorting() 1003void FileBrowser::updateSorting()
1023{ 1004{
1024 sortMenu->setItemChecked( sortMenu->idAt( 5 ), !sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) ); 1005 sortMenu->setItemChecked( sortMenu->idAt( 5 ), !sortMenu->isItemChecked( sortMenu->idAt( 5 ) ) );
1025 1006
1026 if ( sortMenu->isItemChecked( sortMenu->idAt( 0 ) ) ) 1007 if ( sortMenu->isItemChecked( sortMenu->idAt( 0 ) ) )
1027 sortName(); 1008 sortName();
1028 else if ( sortMenu->isItemChecked( sortMenu->idAt( 1 ) ) ) 1009 else if ( sortMenu->isItemChecked( sortMenu->idAt( 1 ) ) )
1029 sortSize(); 1010 sortSize();
1030 else if ( sortMenu->isItemChecked( sortMenu->idAt( 2 ) ) ) 1011 else if ( sortMenu->isItemChecked( sortMenu->idAt( 2 ) ) )
1031 sortDate(); 1012 sortDate();
1032 else 1013 else
1033 sortType(); 1014 sortType();
1034} 1015}
1035 1016
1036void FileView::chPerm() { 1017void FileView::chPerm() {
1037 FileItem * i; 1018 FileItem * i;
1038 QStringList fl; 1019 QStringList fl;
1039 QString cmd; 1020 QString cmd;
1040 1021
1041 if((i = (FileItem *) firstChild()) == 0) return; 1022 if((i = (FileItem *) firstChild()) == 0) return;
1042 1023
1043 while( i ){ 1024 while( i ){
1044 if( i->isSelected() ){ 1025 if( i->isSelected() ){
1045 fl += i->getFilePath(); 1026 fl += i->getFilePath();
1046 } 1027 }
1047 i = (FileItem *) i->nextSibling(); 1028 i = (FileItem *) i->nextSibling();
1048 } 1029 }
1049 if( fl.count() < 1 ) return; 1030 if( fl.count() < 1 ) return;
1050 if( QMessageBox::warning( this, tr("Change permissions"), tr("Are you sure?"), 1031 if( QMessageBox::warning( this, tr("Change permissions"), tr("Are you sure?"),
1051 tr("Yes"), tr("No") ) == 0) { 1032 tr("Yes"), tr("No") ) == 0) {
1052 for ( QStringList::Iterator it = fl.begin(); it != fl.end(); ++it ) { 1033 for ( QStringList::Iterator it = fl.begin(); it != fl.end(); ++it ) {
1053 filePermissions *filePerm; 1034 filePermissions *filePerm;
1054 filePerm = new filePermissions(this, "Permissions",true,0,(const QString &)(*it)); 1035 filePerm = new filePermissions(this, "Permissions",true,0,(const QString &)(*it));
1055 filePerm->exec(); 1036 filePerm->exec();
1056 if( filePerm) 1037 if( filePerm)
1057 delete filePerm; 1038 delete filePerm;
1058 break; 1039 break;
1059 } 1040 }
1060 updateDir(); 1041 updateDir();
1061 } 1042 }
1062} 1043}
1063 1044
1064void FileBrowser::updateShowHidden() 1045void FileBrowser::updateShowHidden()
1065{ 1046{
1066 bool valShowHidden=viewMenu->isItemChecked( viewMenu->idAt( 0 ) ); 1047 bool valShowHidden=viewMenu->isItemChecked( viewMenu->idAt( 0 ) );
1067 valShowHidden=!valShowHidden; 1048 valShowHidden=!valShowHidden;
1068 viewMenu->setItemChecked( viewMenu->idAt( 0 ), valShowHidden ); 1049 viewMenu->setItemChecked( viewMenu->idAt( 0 ), valShowHidden );
1069 fileView->setShowHidden(valShowHidden); 1050 fileView->setShowHidden(valShowHidden);
1070 1051
1071 Config cfg("Filebrowser"); 1052 Config cfg("Filebrowser");
1072 cfg.setGroup("View"); 1053 cfg.setGroup("View");
1073 cfg.writeEntry("Hidden",valShowHidden?"TRUE":"FALSE"); 1054 cfg.writeEntry("Hidden",valShowHidden?"TRUE":"FALSE");
1074 1055
1075 fileView->updateDir(); 1056 fileView->updateDir();
1076} 1057}
1077 1058
1078void FileBrowser::updateShowSymlinks() 1059void FileBrowser::updateShowSymlinks()
1079{ 1060{
1080 bool valShowSymlinks=viewMenu->isItemChecked( viewMenu->idAt( 1 ) ); 1061 bool valShowSymlinks=viewMenu->isItemChecked( viewMenu->idAt( 1 ) );
1081 valShowSymlinks=!valShowSymlinks; 1062 valShowSymlinks=!valShowSymlinks;
1082 viewMenu->setItemChecked( viewMenu->idAt( 1 ), valShowSymlinks ); 1063 viewMenu->setItemChecked( viewMenu->idAt( 1 ), valShowSymlinks );
1083 fileView->setShowSymlinks(valShowSymlinks); 1064 fileView->setShowSymlinks(valShowSymlinks);
1084 1065
1085 Config cfg("Filebrowser"); 1066 Config cfg("Filebrowser");
1086 cfg.setGroup("View"); 1067 cfg.setGroup("View");
1087 cfg.writeEntry("Symlinks",valShowSymlinks?"TRUE":"FALSE"); 1068 cfg.writeEntry("Symlinks",valShowSymlinks?"TRUE":"FALSE");
1088 1069
1089 fileView->updateDir(); 1070 fileView->updateDir();
1090} 1071}
1091 1072
1092void FileBrowser::updateShowThumbnails() 1073void FileBrowser::updateShowThumbnails()
1093{ 1074{
1094 bool valShowThumbnails=viewMenu->isItemChecked( viewMenu->idAt( 2 ) ); 1075 bool valShowThumbnails=viewMenu->isItemChecked( viewMenu->idAt( 2 ) );
1095 valShowThumbnails=!valShowThumbnails; 1076 valShowThumbnails=!valShowThumbnails;
1096 viewMenu->setItemChecked( viewMenu->idAt( 2 ), valShowThumbnails ); 1077 viewMenu->setItemChecked( viewMenu->idAt( 2 ), valShowThumbnails );
1097 fileView->setShowThumbnails(valShowThumbnails); 1078 fileView->setShowThumbnails(valShowThumbnails);
1098 1079
1099 Config cfg("Filebrowser"); 1080 Config cfg("Filebrowser");
1100 cfg.setGroup("View"); 1081 cfg.setGroup("View");
1101 cfg.writeEntry("Thumbnails",valShowThumbnails?"TRUE":"FALSE"); 1082 cfg.writeEntry("Thumbnails",valShowThumbnails?"TRUE":"FALSE");
1102 1083
1103 fileView->updateDir(); 1084 fileView->updateDir();
1104} 1085}
1105 1086
1106void FileBrowser::cleanUp() { 1087void FileBrowser::cleanUp() {
1107 QString cmdr = "rm -rf /tmp/filebrowserThumbnailCache"; 1088 QString cmdr = "rm -rf /tmp/filebrowserThumbnailCache";
1108// qDebug("exit"); 1089// qDebug("exit");
1109 system(cmdr.latin1()); 1090 system(cmdr.latin1());
1110} 1091}
1111
1112{
1113 bool valShowThumbnails=viewMenu->isItemChecked( viewMenu->idAt( 2 ) );
1114 valShowThumbnails=!valShowThumbnails;
1115 viewMenu->setItemChecked( viewMenu->idAt( 2 ), valShowThumbnails );
1116 fileView->setShowThumbnails(valShowThumbnails);
1117
1118 Config cfg("Filebrowser");
1119 cfg.setGroup("View");
1120 cfg.writeEntry("Thumbnails",valShowThumbnails?"TRUE":"FALSE");
1121
1122 fileView->updateDir();
1123}
1124
1125void FileBrowser::cleanUp() {
1126 QString cmdr = "rm -rf /tmp/filebrowserThumbnailCache";
1127// qDebug("exit");
1128 system(cmdr.latin1());
1129}