author | llornkcor <llornkcor> | 2002-10-16 15:17:00 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-10-16 15:17:00 (UTC) |
commit | 61f2f6ef32685002710f197dc8990fd9e99d83a5 (patch) (unidiff) | |
tree | 5fa57efbff0e83a326f6e055c3c59be71d4328bd | |
parent | ee8da0d0b70318c24ee2417bbccd9b7cd6e1404e (diff) | |
download | opie-61f2f6ef32685002710f197dc8990fd9e99d83a5.zip opie-61f2f6ef32685002710f197dc8990fd9e99d83a5.tar.gz opie-61f2f6ef32685002710f197dc8990fd9e99d83a5.tar.bz2 |
fix for popup menu crash.. didnt like loading executable pixmap
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.cpp | 59 |
1 files changed, 31 insertions, 28 deletions
diff --git a/noncore/apps/advancedfm/advancedfm.cpp b/noncore/apps/advancedfm/advancedfm.cpp index d7bad51..b6e7a30 100644 --- a/noncore/apps/advancedfm/advancedfm.cpp +++ b/noncore/apps/advancedfm/advancedfm.cpp | |||
@@ -663,158 +663,161 @@ void AdvancedFm::parsetab(const QString &fileName) { | |||
663 | FILE *mntfp = setmntent( fileName.latin1(), "r" ); | 663 | FILE *mntfp = setmntent( fileName.latin1(), "r" ); |
664 | if ( mntfp ) { | 664 | if ( mntfp ) { |
665 | while ( (me = getmntent( mntfp )) != 0 ) { | 665 | while ( (me = getmntent( mntfp )) != 0 ) { |
666 | QString deviceName = me->mnt_fsname; | 666 | QString deviceName = me->mnt_fsname; |
667 | QString filesystemType = me->mnt_type; | 667 | QString filesystemType = me->mnt_type; |
668 | QString mountDir = me->mnt_dir; | 668 | QString mountDir = me->mnt_dir; |
669 | if(deviceName != "none") { | 669 | if(deviceName != "none") { |
670 | if( fsList.contains(filesystemType) == 0 | 670 | if( fsList.contains(filesystemType) == 0 |
671 | & filesystemType.find("proc",0,TRUE) == -1 | 671 | & filesystemType.find("proc",0,TRUE) == -1 |
672 | & filesystemType.find("cramfs",0,TRUE) == -1 | 672 | & filesystemType.find("cramfs",0,TRUE) == -1 |
673 | & filesystemType.find("auto",0,TRUE) == -1) | 673 | & filesystemType.find("auto",0,TRUE) == -1) |
674 | fsList << filesystemType; | 674 | fsList << filesystemType; |
675 | fileSystemTypeList << mountDir+"::"+filesystemType; | 675 | fileSystemTypeList << mountDir+"::"+filesystemType; |
676 | } | 676 | } |
677 | } | 677 | } |
678 | } | 678 | } |
679 | endmntent( mntfp ); | 679 | endmntent( mntfp ); |
680 | } | 680 | } |
681 | 681 | ||
682 | QString AdvancedFm::getFileSystemType(const QString ¤tText) { | 682 | QString AdvancedFm::getFileSystemType(const QString ¤tText) { |
683 | parsetab("/etc/mtab"); //why did TT forget filesystem type? | 683 | parsetab("/etc/mtab"); //why did TT forget filesystem type? |
684 | QString current = currentText;//.right( currentText.length()-1); | 684 | QString current = currentText;//.right( currentText.length()-1); |
685 | QString baseFs; | 685 | QString baseFs; |
686 | for ( QStringList::Iterator it = fileSystemTypeList.begin(); it != fileSystemTypeList.end(); ++it ) { | 686 | for ( QStringList::Iterator it = fileSystemTypeList.begin(); it != fileSystemTypeList.end(); ++it ) { |
687 | QString temp = (*it); | 687 | QString temp = (*it); |
688 | QString path = temp.left(temp.find("::",0,TRUE) ); | 688 | QString path = temp.left(temp.find("::",0,TRUE) ); |
689 | path = path.right( path.length()-1); | 689 | path = path.right( path.length()-1); |
690 | if(path.isEmpty()) baseFs = temp.right( temp.length() - temp.find("::",0,TRUE) - 2); | 690 | if(path.isEmpty()) baseFs = temp.right( temp.length() - temp.find("::",0,TRUE) - 2); |
691 | if( current.find( path,0,TRUE) != -1 && !path.isEmpty()) { | 691 | if( current.find( path,0,TRUE) != -1 && !path.isEmpty()) { |
692 | return temp.right( temp.length() - temp.find("::",0,TRUE) - 2); | 692 | return temp.right( temp.length() - temp.find("::",0,TRUE) - 2); |
693 | } | 693 | } |
694 | } | 694 | } |
695 | return baseFs; | 695 | return baseFs; |
696 | } | 696 | } |
697 | 697 | ||
698 | QString AdvancedFm::getDiskSpace( const QString &path) { | 698 | QString AdvancedFm::getDiskSpace( const QString &path) { |
699 | struct statfs fss; | 699 | struct statfs fss; |
700 | if ( !statfs( path.latin1(), &fss ) ) { | 700 | if ( !statfs( path.latin1(), &fss ) ) { |
701 | int blkSize = fss.f_bsize; | 701 | int blkSize = fss.f_bsize; |
702 | // int totalBlks = fs.f_blocks; | 702 | // int totalBlks = fs.f_blocks; |
703 | int availBlks = fss.f_bavail; | 703 | int availBlks = fss.f_bavail; |
704 | 704 | ||
705 | long mult = blkSize / 1024; | 705 | long mult = blkSize / 1024; |
706 | long div = 1024 / blkSize; | 706 | long div = 1024 / blkSize; |
707 | if ( !mult ) mult = 1; | 707 | if ( !mult ) mult = 1; |
708 | if ( !div ) div = 1; | 708 | if ( !div ) div = 1; |
709 | 709 | ||
710 | return QString::number(availBlks * mult / div); | 710 | return QString::number(availBlks * mult / div); |
711 | } | 711 | } |
712 | return ""; | 712 | return ""; |
713 | } | 713 | } |
714 | 714 | ||
715 | 715 | ||
716 | void AdvancedFm::showFileMenu() { | 716 | void AdvancedFm::showFileMenu() { |
717 | 717 | ||
718 | QString curApp; | 718 | QString curApp; |
719 | bool isLocalView = false; | 719 | bool isLocalView = false; |
720 | if (TabWidget->currentPageIndex() == 0) { | 720 | if (TabWidget->currentPageIndex() == 0) { |
721 | isLocalView = TRUE; | 721 | isLocalView = TRUE; |
722 | curApp = Local_View->currentItem()->text(0); | 722 | curApp = Local_View->currentItem()->text(0); |
723 | } else { | 723 | } else { |
724 | curApp = Remote_View->currentItem()->text(0); | 724 | curApp = Remote_View->currentItem()->text(0); |
725 | } | 725 | } |
726 | 726 | ||
727 | MimeType mt( curApp ); | 727 | MimeType mt( curApp ); |
728 | const AppLnk* app = mt.application(); | ||
729 | QFile fi(curApp); | ||
730 | |||
731 | QPopupMenu *m = new QPopupMenu(0); | ||
732 | QPopupMenu *n = new QPopupMenu(0); | ||
733 | // QPopupMenu *o = new QPopupMenu(0); | ||
734 | |||
735 | m->insertItem( tr( "Show Hidden Files" ), this, SLOT( showHidden() )); | ||
736 | if ( !QFileInfo(fi).isDir() ) { | ||
737 | // m->insertSeparator(); | ||
738 | // m->insertItem( tr( "Change Directory" ), this, SLOT( doLocalCd() )); | ||
739 | // } else { | ||
740 | |||
741 | if ( app ) | ||
742 | m->insertItem( app->pixmap(), tr( "Open in " | ||
743 | + app->name() ), this, SLOT( runThis() ) ); | ||
744 | else if( QFileInfo(fi).isExecutable() ) | ||
745 | m->insertItem( Resource::loadPixmap( app->name()), tr( "Execute" ), this, SLOT( runThis() ) ); | ||
746 | |||
747 | m->insertItem( Resource::loadPixmap( "txt" ), tr( "Open as text" ),this, SLOT( runText() ) ); | ||
748 | } | ||
749 | 728 | ||
750 | m->insertItem(tr("Actions"),n); | 729 | const AppLnk* app = mt.application(); |
751 | if(isLocalView) | ||
752 | n->insertItem( tr( "Make Directory" ), this, SLOT( localMakDir() )); | ||
753 | else | ||
754 | n->insertItem( tr( "Make Directory" ), this, SLOT( remoteMakDir() )); | ||
755 | 730 | ||
756 | n->insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); | 731 | QFile fi(curApp); |
732 | |||
733 | QPopupMenu *m = new QPopupMenu(0); | ||
734 | QPopupMenu *n = new QPopupMenu(0); | ||
735 | // QPopupMenu *o = new QPopupMenu(0); | ||
736 | |||
737 | m->insertItem( tr( "Show Hidden Files" ), this, SLOT( showHidden() )); | ||
738 | |||
739 | if ( QFileInfo(fi).isDir() ) { | ||
740 | m->insertSeparator(); | ||
741 | m->insertItem( tr( "Change Directory" ), this, SLOT( doLocalCd() )); | ||
742 | } else { | ||
743 | |||
744 | if ( app ) | ||
745 | m->insertItem( app->pixmap(), tr( "Open in " | ||
746 | + app->name() ), this, SLOT( runThis() ) ); | ||
747 | else if( QFileInfo(fi).isExecutable() ) //damn opie doesnt like this | ||
748 | m->insertItem( /*Resource::loadPixmap( app->name()),*/ tr( "Execute" ), this, SLOT( runThis() ) ); | ||
749 | |||
750 | m->insertItem( Resource::loadPixmap( "txt" ), tr( "Open as text" ),this, SLOT( runText() ) ); | ||
751 | } | ||
752 | |||
753 | m->insertItem(tr("Actions"),n); | ||
754 | if(isLocalView) | ||
755 | n->insertItem( tr( "Make Directory" ), this, SLOT( localMakDir() )); | ||
756 | else | ||
757 | n->insertItem( tr( "Make Directory" ), this, SLOT( remoteMakDir() )); | ||
758 | |||
759 | n->insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); | ||
757 | 760 | ||
758 | n->insertSeparator(); | 761 | n->insertSeparator(); |
759 | 762 | ||
760 | 763 | ||
761 | if(isLocalView) | 764 | if(isLocalView) |
762 | n->insertItem( tr( "Rename" ), this, SLOT( localRename() )); | 765 | n->insertItem( tr( "Rename" ), this, SLOT( localRename() )); |
763 | else | 766 | else |
764 | n->insertItem( tr( "Rename" ), this, SLOT( remoteRename() )); | 767 | n->insertItem( tr( "Rename" ), this, SLOT( remoteRename() )); |
765 | 768 | ||
766 | n->insertItem( tr( "Copy" ), this, SLOT( copy() )); | 769 | n->insertItem( tr( "Copy" ), this, SLOT( copy() )); |
767 | n->insertItem( tr( "Copy As" ), this, SLOT( copyAs() )); | 770 | n->insertItem( tr( "Copy As" ), this, SLOT( copyAs() )); |
768 | n->insertItem( tr( "Copy Same Dir" ), this, SLOT( copySameDir() )); | 771 | n->insertItem( tr( "Copy Same Dir" ), this, SLOT( copySameDir() )); |
769 | n->insertItem( tr( "Move" ), this, SLOT( move() )); | 772 | n->insertItem( tr( "Move" ), this, SLOT( move() )); |
770 | 773 | ||
771 | n->insertSeparator(); | 774 | n->insertSeparator(); |
772 | 775 | ||
773 | if(isLocalView) | 776 | if(isLocalView) |
774 | n->insertItem( tr( "Delete" ), this, SLOT( localDelete() )); | 777 | n->insertItem( tr( "Delete" ), this, SLOT( localDelete() )); |
775 | else | 778 | else |
776 | n->insertItem( tr( "Delete" ), this, SLOT( remoteDelete() )); | 779 | n->insertItem( tr( "Delete" ), this, SLOT( remoteDelete() )); |
777 | 780 | ||
778 | 781 | ||
779 | m->insertItem( tr( "Add To Documents" ), this, SLOT( addToDocs() )); | 782 | m->insertItem( tr( "Add To Documents" ), this, SLOT( addToDocs() )); |
780 | 783 | ||
781 | m->insertItem( tr( "Run Command" ), this, SLOT( runCommand() )); | 784 | m->insertItem( tr( "Run Command" ), this, SLOT( runCommand() )); |
782 | m->insertItem( tr( "File Info" ), this, SLOT( fileStatus() )); | 785 | m->insertItem( tr( "File Info" ), this, SLOT( fileStatus() )); |
783 | 786 | ||
784 | m->insertSeparator(); | 787 | m->insertSeparator(); |
785 | m->insertItem( tr( "Set Permissions" ), this, SLOT( filePerms() )); | 788 | m->insertItem( tr( "Set Permissions" ), this, SLOT( filePerms() )); |
786 | 789 | ||
787 | #if defined(QT_QWS_OPIE) | 790 | #if defined(QT_QWS_OPIE) |
788 | m->insertItem( tr( "Properties" ), this, SLOT( doProperties() )); | 791 | m->insertItem( tr( "Properties" ), this, SLOT( doProperties() )); |
789 | #endif | 792 | #endif |
790 | m->setCheckable(TRUE); | 793 | m->setCheckable(TRUE); |
791 | if (!b) | 794 | if (!b) |
792 | m->setItemChecked(m->idAt(0),TRUE); | 795 | m->setItemChecked(m->idAt(0),TRUE); |
793 | else | 796 | else |
794 | m->setItemChecked(m->idAt(0),FALSE); | 797 | m->setItemChecked(m->idAt(0),FALSE); |
795 | 798 | ||
796 | if(Ir::supported()) | 799 | if(Ir::supported()) |
797 | m->insertItem( tr( "Beam File" ), this, SLOT( doBeam() )); | 800 | m->insertItem( tr( "Beam File" ), this, SLOT( doBeam() )); |
798 | m->setFocus(); | 801 | m->setFocus(); |
799 | m->exec( QCursor::pos() ); | 802 | m->exec( QCursor::pos() ); |
800 | sleep(1); | 803 | sleep(1); |
801 | if(m) delete m; | 804 | if(m) delete m; |
802 | } | 805 | } |
803 | 806 | ||
804 | 807 | ||
805 | void AdvancedFm::cancelMenuTimer() { | 808 | void AdvancedFm::cancelMenuTimer() { |
806 | 809 | ||
807 | // qDebug("selectionChanged: cancel menu timer"); | 810 | // qDebug("selectionChanged: cancel menu timer"); |
808 | if( menuTimer.isActive() ) | 811 | if( menuTimer.isActive() ) |
809 | menuTimer.stop(); | 812 | menuTimer.stop(); |
810 | } | 813 | } |
811 | 814 | ||
812 | QString AdvancedFm::checkDiskSpace(const QString &path) { | 815 | QString AdvancedFm::checkDiskSpace(const QString &path) { |
813 | struct statfs fss; | 816 | struct statfs fss; |
814 | if ( !statfs( path.latin1(), &fss ) ) { | 817 | if ( !statfs( path.latin1(), &fss ) ) { |
815 | int blkSize = fss.f_bsize; | 818 | int blkSize = fss.f_bsize; |
816 | // int totalBlks = fs.f_blocks; | 819 | // int totalBlks = fs.f_blocks; |
817 | int availBlks = fss.f_bavail; | 820 | int availBlks = fss.f_bavail; |
818 | 821 | ||
819 | long mult = blkSize / 1024; | 822 | long mult = blkSize / 1024; |
820 | long div = 1024 / blkSize; | 823 | long div = 1024 / blkSize; |