summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/playlistwidget.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.cpp b/noncore/multimedia/opieplayer2/playlistwidget.cpp
index 83eb83b..98326a8 100644
--- a/noncore/multimedia/opieplayer2/playlistwidget.cpp
+++ b/noncore/multimedia/opieplayer2/playlistwidget.cpp
@@ -673,192 +673,198 @@ void PlayListWidget::openURL() {
673 lnk.setName( filename ); //sets name 673 lnk.setName( filename ); //sets name
674 lnk.setFile( filename ); //sets file name 674 lnk.setFile( filename ); //sets file name
675 675
676// lnk.setIcon("opieplayer2/musicfile"); 676// lnk.setIcon("opieplayer2/musicfile");
677 677
678 d->selectedFiles->addToSelection( lnk ); 678 d->selectedFiles->addToSelection( lnk );
679 writeCurrentM3u(); 679 writeCurrentM3u();
680 d->selectedFiles->setSelectedItem( lnk.name()); 680 d->selectedFiles->setSelectedItem( lnk.name());
681 } 681 }
682 else if( filename.right( 3) == "m3u" || filename.right(3) == "pls" ) { 682 else if( filename.right( 3) == "m3u" || filename.right(3) == "pls" ) {
683 readListFromFile( filename ); 683 readListFromFile( filename );
684 } else { 684 } else {
685 lnk.setName( QFileInfo(filename).baseName() ); //sets name 685 lnk.setName( QFileInfo(filename).baseName() ); //sets name
686 lnk.setFile( filename ); //sets file name 686 lnk.setFile( filename ); //sets file name
687 d->selectedFiles->addToSelection( lnk); 687 d->selectedFiles->addToSelection( lnk);
688 writeCurrentM3u(); 688 writeCurrentM3u();
689 d->selectedFiles->setSelectedItem( lnk.name()); 689 d->selectedFiles->setSelectedItem( lnk.name());
690 } 690 }
691 } 691 }
692 692
693 693
694 delete fileDlg; 694 delete fileDlg;
695} 695}
696 696
697 697
698static MimeTypes fileSelectorMimeTypes() { 698static MimeTypes fileSelectorMimeTypes() {
699 MimeTypes types; 699 MimeTypes types;
700 QStringList audio, video, all; 700 QStringList audio, video, all;
701 audio << "audio/*"; 701 audio << "audio/*";
702 audio << "playlist/plain"; 702 audio << "playlist/plain";
703 audio << "audio/x-ogg"; 703 audio << "audio/x-ogg";
704 audio << "audio/x-mpegurl"; 704 audio << "audio/x-mpegurl";
705 705
706 video << "video/*"; 706 video << "video/*";
707 video << "playlist/plain"; 707 video << "playlist/plain";
708 708
709 all += audio; 709 all += audio;
710 all += video; 710 all += video;
711 types.insert("All Media Files", all ); 711 types.insert("All Media Files", all );
712 types.insert("Audio", audio ); 712 types.insert("Audio", audio );
713 types.insert("Video", video ); 713 types.insert("Video", video );
714 714
715 return types; 715 return types;
716} 716}
717 717
718void PlayListWidget::openFile() { 718void PlayListWidget::openFile() {
719 719
720 QString filename, name; 720 QString filename, name;
721 721
722 Config cfg( "OpiePlayer" ); 722 Config cfg( "OpiePlayer" );
723 cfg.setGroup("Dialog"); 723 cfg.setGroup("Dialog");
724 MimeTypes types = fileSelectorMimeTypes(); 724 MimeTypes types = fileSelectorMimeTypes();
725 725
726 726
727 QString str = OFileDialog::getOpenFileName( 1, QString::null, 727 QString str = OFileDialog::getOpenFileName( 1, QString::null,
728 QString::null, types, 0, 728 QString::null, types, 0,
729 tr("Add File to Playlist") ); 729 tr("Add File to Playlist") );
730 730
731 if( str.isEmpty() ) 731 if( str.isEmpty() )
732 return; 732 return;
733 733
734 if(str.left(2) == "//") str=str.right(str.length()-1); 734 if(str.left(2) == "//") str=str.right(str.length()-1);
735 735
736 736
737 if( str.right( 3) == "m3u" || str.right(3) == "pls" ) { 737 if( str.right( 3) == "m3u" || str.right(3) == "pls" ) {
738 readListFromFile( str ); 738 readListFromFile( str );
739 } else { 739 } else {
740 QFileInfo info( str ); 740 QFileInfo info( str );
741 DocLnk lnk = addFileToPlaylist( str, info.baseName() ); 741 DocLnk lnk = addFileToPlaylist( str, info.baseName() );
742 d->selectedFiles->setSelectedItem( lnk.name() ); 742 d->selectedFiles->setSelectedItem( lnk.name() );
743 } 743 }
744 744
745 setButtons(); 745 setButtons();
746} 746}
747 747
748void PlayListWidget::openDirectory() { 748void PlayListWidget::openDirectory() {
749 QString str = OFileDialog::getDirectory( OFileSelector::DirectorySelector, 749 QString str = OFileDialog::getDirectory( OFileSelector::DirectorySelector,
750 QString::null, 0, 750 QString::null, 0,
751 tr( "Add Files from Directory")); 751 tr( "Add Files from Directory"));
752 752
753 if(str.isEmpty() ) 753 if(str.isEmpty() )
754 return; 754 return;
755 755
756 if(str.left(2) == "//") str=str.right(str.length()-1); 756 if(str.left(2) == "//") str=str.right(str.length()-1);
757 QDir dir( str ); 757 QDir dir( str );
758 QStringList lst = dir.entryList(QDir::Files|QDir::Readable); 758 QStringList lst = dir.entryList(QDir::Files|QDir::Readable);
759 759
760 for ( QStringList::Iterator it = lst.begin(); it != lst.end(); ++it ) { 760 for ( QStringList::Iterator it = lst.begin(); it != lst.end(); ++it ) {
761 QString filename = str + "/" + *it; 761 QString filename = str + "/" + *it;
762 762
763 if( filename.right( 3) == "m3u" || filename.right(3) == "pls" ) 763 if( filename.right( 3) == "m3u" || filename.right(3) == "pls" )
764 readListFromFile( filename ); 764 readListFromFile( filename );
765 else { 765 else {
766 addFileToPlaylist( filename, QFileInfo(*it).baseName() ); 766 addFileToPlaylist( filename, QFileInfo(*it).baseName() );
767 } 767 }
768 } 768 }
769
770 if (!d->selectedFiles->isEmpty()) {
771 d->selectedFiles->first();
772
773 setButtons();
774 }
769} 775}
770 776
771void PlayListWidget::readListFromFile( const QString &filename ) { 777void PlayListWidget::readListFromFile( const QString &filename ) {
772 odebug << "read list filename " + filename << oendl; 778 odebug << "read list filename " + filename << oendl;
773 QFileInfo fi(filename); 779 QFileInfo fi(filename);
774 Om3u *m3uList; 780 Om3u *m3uList;
775 QString s, name; 781 QString s, name;
776 m3uList = new Om3u( filename, IO_ReadOnly ); 782 m3uList = new Om3u( filename, IO_ReadOnly );
777 if(fi.extension(false).find("m3u",0,false) != -1 ) 783 if(fi.extension(false).find("m3u",0,false) != -1 )
778 m3uList->readM3u(); 784 m3uList->readM3u();
779 else if(fi.extension(false).find("pls",0,false) != -1 ) 785 else if(fi.extension(false).find("pls",0,false) != -1 )
780 m3uList->readPls(); 786 m3uList->readPls();
781 787
782 DocLnk lnk; 788 DocLnk lnk;
783 for ( QStringList::ConstIterator it = m3uList->begin(); it != m3uList->end(); ++it ) { 789 for ( QStringList::ConstIterator it = m3uList->begin(); it != m3uList->end(); ++it ) {
784 s = *it; 790 s = *it;
785 // odebug << s << oendl; 791 // odebug << s << oendl;
786 if(s.left(4)=="http") { 792 if(s.left(4)=="http") {
787 lnk.setName( s ); //sets file name 793 lnk.setName( s ); //sets file name
788 lnk.setIcon("opieplayer2/musicfile"); 794 lnk.setIcon("opieplayer2/musicfile");
789 lnk.setFile( s ); //sets file name 795 lnk.setFile( s ); //sets file name
790 796
791 } else { //is file 797 } else { //is file
792 lnk.setName( QFileInfo(s).baseName()); 798 lnk.setName( QFileInfo(s).baseName());
793 if(s.left(1) != "/") { 799 if(s.left(1) != "/") {
794 800
795 lnk.setFile( QFileInfo(filename).dirPath()+"/"+s); 801 lnk.setFile( QFileInfo(filename).dirPath()+"/"+s);
796 } else { 802 } else {
797 lnk.setFile( s); 803 lnk.setFile( s);
798 } 804 }
799 } 805 }
800 d->selectedFiles->addToSelection( lnk ); 806 d->selectedFiles->addToSelection( lnk );
801 } 807 }
802 Config config( "OpiePlayer" ); 808 Config config( "OpiePlayer" );
803 config.setGroup( "PlayList" ); 809 config.setGroup( "PlayList" );
804 810
805 config.writeEntry("CurrentPlaylist",filename); 811 config.writeEntry("CurrentPlaylist",filename);
806 config.write(); 812 config.write();
807 currentPlayList=filename; 813 currentPlayList=filename;
808 814
809 m3uList->close(); 815 m3uList->close();
810 delete m3uList; 816 delete m3uList;
811 817
812 d->selectedFiles->setSelectedItem( s); 818 d->selectedFiles->setSelectedItem( s);
813 setCaption(tr("OpiePlayer: ")+ QFileInfo(filename).baseName()); 819 setCaption(tr("OpiePlayer: ")+ QFileInfo(filename).baseName());
814 820
815 setButtons(); 821 setButtons();
816} 822}
817 823
818// writes current playlist to current m3u file */ 824// writes current playlist to current m3u file */
819 void PlayListWidget::writeCurrentM3u() { 825 void PlayListWidget::writeCurrentM3u() {
820 odebug << "writing to current m3u" << oendl; 826 odebug << "writing to current m3u" << oendl;
821 Config cfg( "OpiePlayer" ); 827 Config cfg( "OpiePlayer" );
822 cfg.setGroup("PlayList"); 828 cfg.setGroup("PlayList");
823 QString currentPlaylist = cfg.readEntry("CurrentPlaylist","default"); 829 QString currentPlaylist = cfg.readEntry("CurrentPlaylist","default");
824 830
825 Om3u *m3uList; 831 Om3u *m3uList;
826 m3uList = new Om3u( currentPlaylist, IO_ReadWrite | IO_Truncate ); 832 m3uList = new Om3u( currentPlaylist, IO_ReadWrite | IO_Truncate );
827 if( d->selectedFiles->first()) { 833 if( d->selectedFiles->first()) {
828 834
829 do { 835 do {
830 // odebug << "add writeCurrentM3u " +d->selectedFiles->current()->file() << oendl; 836 // odebug << "add writeCurrentM3u " +d->selectedFiles->current()->file() << oendl;
831 m3uList->add( d->selectedFiles->current()->file() ); 837 m3uList->add( d->selectedFiles->current()->file() );
832 } 838 }
833 while ( d->selectedFiles->next() ); 839 while ( d->selectedFiles->next() );
834 // odebug << "<<<<<<<<<<<<>>>>>>>>>>>>>>>>>" << oendl; 840 // odebug << "<<<<<<<<<<<<>>>>>>>>>>>>>>>>>" << oendl;
835 m3uList->write(); 841 m3uList->write();
836 m3uList->close(); 842 m3uList->close();
837 } 843 }
838 delete m3uList; 844 delete m3uList;
839 845
840 } 846 }
841 847
842 /* 848 /*
843 writes current playlist to m3u file */ 849 writes current playlist to m3u file */
844void PlayListWidget::writem3u() { 850void PlayListWidget::writem3u() {
845 851
846 Config cfg( "OpiePlayer" ); 852 Config cfg( "OpiePlayer" );
847 cfg.setGroup("Dialog"); 853 cfg.setGroup("Dialog");
848 MimeTypes types = fileSelectorMimeTypes(); 854 MimeTypes types = fileSelectorMimeTypes();
849 855
850 QString str = OFileDialog::getOpenFileName( 1, QString::null, 856 QString str = OFileDialog::getOpenFileName( 1, QString::null,
851 QString::null, types, 0, 857 QString::null, types, 0,
852 tr( "Save Playlist" )); 858 tr( "Save Playlist" ));
853 859
854 if(str.left(2) == "//") str=str.right(str.length()-1); 860 if(str.left(2) == "//") str=str.right(str.length()-1);
855 861
856 QString name, filename, list; 862 QString name, filename, list;
857 Om3u *m3uList; 863 Om3u *m3uList;
858 864
859 if( !str.isEmpty() ) { 865 if( !str.isEmpty() ) {
860 name = str; 866 name = str;
861 // name = fileDlg->text(); 867 // name = fileDlg->text();
862// odebug << filename << oendl; 868// odebug << filename << oendl;
863 if( name.find("/",0,true) != -1) {// assume they specify a file path 869 if( name.find("/",0,true) != -1) {// assume they specify a file path
864 filename = name; 870 filename = name;