-rw-r--r-- | core/multimedia/opieplayer/playlistwidget.cpp | 27 |
1 files changed, 9 insertions, 18 deletions
diff --git a/core/multimedia/opieplayer/playlistwidget.cpp b/core/multimedia/opieplayer/playlistwidget.cpp index 26103c3..65dc5fb 100644 --- a/core/multimedia/opieplayer/playlistwidget.cpp +++ b/core/multimedia/opieplayer/playlistwidget.cpp | |||
@@ -404,192 +404,194 @@ void PlayListWidget::writeConfig( Config& cfg ) const { | |||
404 | "Your playlist " | 404 | "Your playlist " |
405 | "may be missing some entries\n" | 405 | "may be missing some entries\n" |
406 | "the next time you start it." ) | 406 | "the next time you start it." ) |
407 | ); | 407 | ); |
408 | } | 408 | } |
409 | } | 409 | } |
410 | noOfFiles++; | 410 | noOfFiles++; |
411 | } | 411 | } |
412 | } | 412 | } |
413 | while ( d->selectedFiles->next() ); | 413 | while ( d->selectedFiles->next() ); |
414 | cfg.writeEntry("NumberOfFiles", noOfFiles ); | 414 | cfg.writeEntry("NumberOfFiles", noOfFiles ); |
415 | } | 415 | } |
416 | 416 | ||
417 | 417 | ||
418 | void PlayListWidget::addToSelection( const DocLnk& lnk ) { | 418 | void PlayListWidget::addToSelection( const DocLnk& lnk ) { |
419 | // qDebug("add"); | 419 | // qDebug("add"); |
420 | // if( lnk.file().find(" ",0,TRUE) != -1 || lnk.file().find("%20",0,TRUE) != -1) { | 420 | // if( lnk.file().find(" ",0,TRUE) != -1 || lnk.file().find("%20",0,TRUE) != -1) { |
421 | // QMessageBox::message("Note","You are trying to play\na malformed url."); | 421 | // QMessageBox::message("Note","You are trying to play\na malformed url."); |
422 | 422 | ||
423 | // } else { | 423 | // } else { |
424 | 424 | ||
425 | d->setDocumentUsed = FALSE; | 425 | d->setDocumentUsed = FALSE; |
426 | if ( mediaPlayerState->playlist() ) { | 426 | if ( mediaPlayerState->playlist() ) { |
427 | if(QFileInfo(lnk.file()).exists() || lnk.file().left(4) == "http" ) | 427 | if(QFileInfo(lnk.file()).exists() || lnk.file().left(4) == "http" ) |
428 | d->selectedFiles->addToSelection( lnk ); | 428 | d->selectedFiles->addToSelection( lnk ); |
429 | } | 429 | } |
430 | else | 430 | else |
431 | mediaPlayerState->setPlaying( TRUE ); | 431 | mediaPlayerState->setPlaying( TRUE ); |
432 | // } | 432 | // } |
433 | } | 433 | } |
434 | 434 | ||
435 | 435 | ||
436 | void PlayListWidget::clearList() { | 436 | void PlayListWidget::clearList() { |
437 | while ( first() ) | 437 | while ( first() ) |
438 | d->selectedFiles->removeSelected(); | 438 | d->selectedFiles->removeSelected(); |
439 | } | 439 | } |
440 | 440 | ||
441 | 441 | ||
442 | void PlayListWidget::addAllToList() { | 442 | void PlayListWidget::addAllToList() { |
443 | DocLnkSet filesAll; | 443 | DocLnkSet filesAll; |
444 | Global::findDocuments(&filesAll, "video/*;audio/*"); | 444 | Global::findDocuments(&filesAll, "video/*;audio/*"); |
445 | QListIterator<DocLnk> Adit( filesAll.children() ); | 445 | QListIterator<DocLnk> Adit( filesAll.children() ); |
446 | for ( ; Adit.current(); ++Adit ) | 446 | for ( ; Adit.current(); ++Adit ) |
447 | if(QFileInfo(Adit.current()->file()).exists()) | 447 | if(QFileInfo(Adit.current()->file()).exists()) |
448 | d->selectedFiles->addToSelection( **Adit ); | 448 | d->selectedFiles->addToSelection( **Adit ); |
449 | } | 449 | } |
450 | 450 | ||
451 | 451 | ||
452 | void PlayListWidget::addAllMusicToList() { | 452 | void PlayListWidget::addAllMusicToList() { |
453 | QListIterator<DocLnk> dit( files.children() ); | 453 | QListIterator<DocLnk> dit( files.children() ); |
454 | for ( ; dit.current(); ++dit ) | 454 | for ( ; dit.current(); ++dit ) |
455 | if(QFileInfo(dit.current()->file()).exists()) | 455 | if(QFileInfo(dit.current()->file()).exists()) |
456 | d->selectedFiles->addToSelection( **dit ); | 456 | d->selectedFiles->addToSelection( **dit ); |
457 | } | 457 | } |
458 | 458 | ||
459 | 459 | ||
460 | void PlayListWidget::addAllVideoToList() { | 460 | void PlayListWidget::addAllVideoToList() { |
461 | QListIterator<DocLnk> dit( vFiles.children() ); | 461 | QListIterator<DocLnk> dit( vFiles.children() ); |
462 | for ( ; dit.current(); ++dit ) | 462 | for ( ; dit.current(); ++dit ) |
463 | if(QFileInfo( dit.current()->file()).exists()) | 463 | if(QFileInfo( dit.current()->file()).exists()) |
464 | d->selectedFiles->addToSelection( **dit ); | 464 | d->selectedFiles->addToSelection( **dit ); |
465 | } | 465 | } |
466 | 466 | ||
467 | 467 | ||
468 | void PlayListWidget::setDocument(const QString& fileref) { | 468 | void PlayListWidget::setDocument(const QString& fileref) { |
469 | qDebug(fileref); | 469 | qDebug(fileref); |
470 | fromSetDocument = TRUE; | 470 | fromSetDocument = TRUE; |
471 | if ( fileref.isNull() ) { | 471 | if ( fileref.isNull() ) { |
472 | QMessageBox::critical( 0, tr( "Invalid File" ), tr( "There was a problem in getting the file." ) ); | 472 | QMessageBox::critical( 0, tr( "Invalid File" ), tr( "There was a problem in getting the file." ) ); |
473 | return; | 473 | return; |
474 | } | 474 | } |
475 | // qDebug("setDocument "+fileref); | 475 | // qDebug("setDocument "+fileref); |
476 | if(fileref.find("m3u",0,TRUE) != -1) { //is m3u | 476 | if(fileref.find("m3u",0,TRUE) != -1) { //is m3u |
477 | readm3u( fileref); | 477 | readm3u( fileref); |
478 | } | 478 | } |
479 | else if(fileref.find("pls",0,TRUE) != -1) { //is pls | 479 | else if(fileref.find("pls",0,TRUE) != -1) { //is pls |
480 | readPls( fileref); | 480 | readPls( fileref); |
481 | } | 481 | } |
482 | else if(fileref.find("playlist",0,TRUE) != -1) {//is playlist | 482 | else if(fileref.find("playlist",0,TRUE) != -1) {//is playlist |
483 | clearList(); | 483 | clearList(); |
484 | loadList(DocLnk(fileref)); | 484 | loadList(DocLnk(fileref)); |
485 | d->selectedFiles->first(); | 485 | d->selectedFiles->first(); |
486 | } else { | 486 | } else { |
487 | clearList(); | 487 | clearList(); |
488 | addToSelection( DocLnk( fileref ) ); | 488 | addToSelection( DocLnk( fileref ) ); |
489 | d->setDocumentUsed = TRUE; | 489 | d->setDocumentUsed = TRUE; |
490 | mediaPlayerState->setPlaying( FALSE ); | 490 | mediaPlayerState->setPlaying( FALSE ); |
491 | qApp->processEvents(); | 491 | qApp->processEvents(); |
492 | mediaPlayerState->setPlaying( TRUE ); | 492 | mediaPlayerState->setPlaying( TRUE ); |
493 | qApp->processEvents(); | 493 | qApp->processEvents(); |
494 | setCaption(tr("OpiePlayer")); | 494 | setCaption(tr("OpiePlayer")); |
495 | } | 495 | } |
496 | } | 496 | } |
497 | 497 | ||
498 | 498 | ||
499 | void PlayListWidget::setActiveWindow() { | 499 | void PlayListWidget::setActiveWindow() { |
500 | qDebug("SETTING active window"); | ||
501 | |||
500 | // When we get raised we need to ensure that it switches views | 502 | // When we get raised we need to ensure that it switches views |
501 | char origView = mediaPlayerState->view(); | 503 | char origView = mediaPlayerState->view(); |
502 | mediaPlayerState->setView( 'l' ); // invalidate | 504 | mediaPlayerState->setView( 'l' ); // invalidate |
503 | mediaPlayerState->setView( origView ); // now switch back | 505 | mediaPlayerState->setView( origView ); // now switch back |
504 | } | 506 | } |
505 | 507 | ||
506 | 508 | ||
507 | void PlayListWidget::useSelectedDocument() { | 509 | void PlayListWidget::useSelectedDocument() { |
508 | d->setDocumentUsed = FALSE; | 510 | d->setDocumentUsed = FALSE; |
509 | } | 511 | } |
510 | 512 | ||
511 | 513 | ||
512 | const DocLnk *PlayListWidget::current() { // this is fugly | 514 | const DocLnk *PlayListWidget::current() { // this is fugly |
513 | 515 | ||
514 | // if( fromSetDocument) { | 516 | // if( fromSetDocument) { |
515 | // qDebug("from setDoc"); | 517 | // qDebug("from setDoc"); |
516 | // DocLnkSet files; | 518 | // DocLnkSet files; |
517 | // Global::findDocuments(&files, "video/*;audio/*"); | 519 | // Global::findDocuments(&files, "video/*;audio/*"); |
518 | // QListIterator<DocLnk> dit( files.children() ); | 520 | // QListIterator<DocLnk> dit( files.children() ); |
519 | // for ( ; dit.current(); ++dit ) { | 521 | // for ( ; dit.current(); ++dit ) { |
520 | // if(dit.current()->linkFile() == setDocFileRef) { | 522 | // if(dit.current()->linkFile() == setDocFileRef) { |
521 | // qDebug(setDocFileRef); | 523 | // qDebug(setDocFileRef); |
522 | // return dit; | 524 | // return dit; |
523 | // } | 525 | // } |
524 | // } | 526 | // } |
525 | // } else | 527 | // } else |
526 | 528 | ||
527 | 529 | ||
528 | switch (tabWidget->currentPageIndex()) { | 530 | switch (tabWidget->currentPageIndex()) { |
529 | case 0: //playlist | 531 | case 0: //playlist |
530 | { | 532 | { |
531 | qDebug("playlist"); | 533 | qDebug("playlist"); |
532 | if ( mediaPlayerState->playlist() ) { | 534 | if ( mediaPlayerState->playlist() ) { |
533 | return d->selectedFiles->current(); | 535 | return d->selectedFiles->current(); |
534 | } | 536 | } |
535 | else if ( d->setDocumentUsed && d->current ) { | 537 | else if ( d->setDocumentUsed && d->current ) { |
536 | return d->current; | 538 | return d->current; |
537 | } else { | 539 | } else { |
538 | return d->files->selected(); | 540 | return d->files->selected(); |
539 | } | 541 | } |
540 | } | 542 | } |
541 | break; | 543 | break; |
542 | case 1://audio | 544 | case 1://audio |
543 | { | 545 | { |
544 | qDebug("audioView"); | 546 | qDebug("audioView"); |
545 | QListIterator<DocLnk> dit( files.children() ); | 547 | QListIterator<DocLnk> dit( files.children() ); |
546 | for ( ; dit.current(); ++dit ) { | 548 | for ( ; dit.current(); ++dit ) { |
547 | if( dit.current()->name() == audioView->currentItem()->text(0) && !insanityBool) { | 549 | if( dit.current()->name() == audioView->currentItem()->text(0) && !insanityBool) { |
548 | qDebug("here"); | 550 | qDebug("here"); |
549 | insanityBool=TRUE; | 551 | insanityBool=TRUE; |
550 | return dit; | 552 | return dit; |
551 | } | 553 | } |
552 | } | 554 | } |
553 | } | 555 | } |
554 | break; | 556 | break; |
555 | case 2: // video | 557 | case 2: // video |
556 | { | 558 | { |
557 | qDebug("videoView"); | 559 | qDebug("videoView"); |
558 | QListIterator<DocLnk> Vdit( vFiles.children() ); | 560 | QListIterator<DocLnk> Vdit( vFiles.children() ); |
559 | for ( ; Vdit.current(); ++Vdit ) { | 561 | for ( ; Vdit.current(); ++Vdit ) { |
560 | if( Vdit.current()->name() == videoView->currentItem()->text(0) && !insanityBool) { | 562 | if( Vdit.current()->name() == videoView->currentItem()->text(0) && !insanityBool) { |
561 | insanityBool=TRUE; | 563 | insanityBool=TRUE; |
562 | return Vdit; | 564 | return Vdit; |
563 | } | 565 | } |
564 | } | 566 | } |
565 | } | 567 | } |
566 | break; | 568 | break; |
567 | }; | 569 | }; |
568 | return 0; | 570 | return 0; |
569 | } | 571 | } |
570 | 572 | ||
571 | bool PlayListWidget::prev() { | 573 | bool PlayListWidget::prev() { |
572 | if ( mediaPlayerState->playlist() ) { | 574 | if ( mediaPlayerState->playlist() ) { |
573 | if ( mediaPlayerState->shuffled() ) { | 575 | if ( mediaPlayerState->shuffled() ) { |
574 | const DocLnk *cur = current(); | 576 | const DocLnk *cur = current(); |
575 | int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0)); | 577 | int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0)); |
576 | for ( int i = 0; i < j; i++ ) { | 578 | for ( int i = 0; i < j; i++ ) { |
577 | if ( !d->selectedFiles->next() ) | 579 | if ( !d->selectedFiles->next() ) |
578 | d->selectedFiles->first(); | 580 | d->selectedFiles->first(); |
579 | } | 581 | } |
580 | if ( cur == current() ) | 582 | if ( cur == current() ) |
581 | if ( !d->selectedFiles->next() ) | 583 | if ( !d->selectedFiles->next() ) |
582 | d->selectedFiles->first(); | 584 | d->selectedFiles->first(); |
583 | return TRUE; | 585 | return TRUE; |
584 | } else { | 586 | } else { |
585 | if ( !d->selectedFiles->prev() ) { | 587 | if ( !d->selectedFiles->prev() ) { |
586 | if ( mediaPlayerState->looping() ) { | 588 | if ( mediaPlayerState->looping() ) { |
587 | return d->selectedFiles->last(); | 589 | return d->selectedFiles->last(); |
588 | } else { | 590 | } else { |
589 | return FALSE; | 591 | return FALSE; |
590 | } | 592 | } |
591 | } | 593 | } |
592 | return TRUE; | 594 | return TRUE; |
593 | } | 595 | } |
594 | } else { | 596 | } else { |
595 | return mediaPlayerState->looping(); | 597 | return mediaPlayerState->looping(); |
@@ -863,470 +865,459 @@ void PlayListWidget::btnPlay(bool b) { | |||
863 | break; | 865 | break; |
864 | case 1: | 866 | case 1: |
865 | { | 867 | { |
866 | addToSelection( audioView->currentItem() ); | 868 | addToSelection( audioView->currentItem() ); |
867 | mediaPlayerState->setPlaying(b); | 869 | mediaPlayerState->setPlaying(b); |
868 | d->selectedFiles->removeSelected( ); | 870 | d->selectedFiles->removeSelected( ); |
869 | tabWidget->setCurrentPage(1); | 871 | tabWidget->setCurrentPage(1); |
870 | d->selectedFiles->unSelect(); | 872 | d->selectedFiles->unSelect(); |
871 | insanityBool=FALSE; | 873 | insanityBool=FALSE; |
872 | }// audioView->clearSelection(); | 874 | }// audioView->clearSelection(); |
873 | break; | 875 | break; |
874 | case 2: | 876 | case 2: |
875 | { | 877 | { |
876 | addToSelection( videoView->currentItem() ); | 878 | addToSelection( videoView->currentItem() ); |
877 | mediaPlayerState->setPlaying(b); | 879 | mediaPlayerState->setPlaying(b); |
878 | qApp->processEvents(); | 880 | qApp->processEvents(); |
879 | d->selectedFiles->removeSelected( ); | 881 | d->selectedFiles->removeSelected( ); |
880 | tabWidget->setCurrentPage(2); | 882 | tabWidget->setCurrentPage(2); |
881 | d->selectedFiles->unSelect(); | 883 | d->selectedFiles->unSelect(); |
882 | insanityBool=FALSE; | 884 | insanityBool=FALSE; |
883 | }// videoView->clearSelection(); | 885 | }// videoView->clearSelection(); |
884 | break; | 886 | break; |
885 | }; | 887 | }; |
886 | 888 | ||
887 | } | 889 | } |
888 | 890 | ||
889 | void PlayListWidget::deletePlaylist() { | 891 | void PlayListWidget::deletePlaylist() { |
890 | switch( QMessageBox::information( this, (tr("Remove Playlist?")), | 892 | switch( QMessageBox::information( this, (tr("Remove Playlist?")), |
891 | (tr("You really want to delete\nthis playlist?")), | 893 | (tr("You really want to delete\nthis playlist?")), |
892 | (tr("Yes")), (tr("No")), 0 )){ | 894 | (tr("Yes")), (tr("No")), 0 )){ |
893 | case 0: // Yes clicked, | 895 | case 0: // Yes clicked, |
894 | QFile().remove(playLists->selected()->file()); | 896 | QFile().remove(playLists->selected()->file()); |
895 | QFile().remove(playLists->selected()->linkFile()); | 897 | QFile().remove(playLists->selected()->linkFile()); |
896 | playLists->reread(); | 898 | playLists->reread(); |
897 | break; | 899 | break; |
898 | case 1: // Cancel | 900 | case 1: // Cancel |
899 | break; | 901 | break; |
900 | }; | 902 | }; |
901 | } | 903 | } |
902 | 904 | ||
903 | void PlayListWidget::viewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) | 905 | void PlayListWidget::viewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) |
904 | { | 906 | { |
905 | switch (mouse) { | 907 | switch (mouse) { |
906 | case 1: | 908 | case 1: |
907 | break; | 909 | break; |
908 | case 2:{ | 910 | case 2:{ |
909 | 911 | ||
910 | QPopupMenu m; | 912 | QPopupMenu m; |
911 | m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); | 913 | m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); |
912 | m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); | 914 | m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); |
913 | m.insertSeparator(); | 915 | m.insertSeparator(); |
914 | if( QFile(QPEApplication::qpeDir()+"lib/libopie.so").exists() ) | 916 | if( QFile(QPEApplication::qpeDir()+"lib/libopie.so").exists() ) |
915 | m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); | 917 | m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); |
916 | 918 | ||
917 | m.exec( QCursor::pos() ); | 919 | m.exec( QCursor::pos() ); |
918 | } | 920 | } |
919 | break; | 921 | break; |
920 | }; | 922 | }; |
921 | } | 923 | } |
922 | 924 | ||
923 | void PlayListWidget::playSelected() | 925 | void PlayListWidget::playSelected() |
924 | { | 926 | { |
925 | btnPlay( TRUE); | 927 | btnPlay( TRUE); |
926 | // d->selectedFiles->unSelect(); | 928 | // d->selectedFiles->unSelect(); |
927 | } | 929 | } |
928 | 930 | ||
929 | void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) | 931 | void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) |
930 | { | 932 | { |
931 | switch (mouse) { | 933 | switch (mouse) { |
932 | case 1: | 934 | case 1: |
933 | 935 | ||
934 | break; | 936 | break; |
935 | case 2:{ | 937 | case 2:{ |
936 | QPopupMenu m; | 938 | QPopupMenu m; |
937 | m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); | 939 | m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); |
938 | m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); | 940 | m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); |
939 | // m.insertSeparator(); | 941 | // m.insertSeparator(); |
940 | // m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); | 942 | // m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); |
941 | m.exec( QCursor::pos() ); | 943 | m.exec( QCursor::pos() ); |
942 | } | 944 | } |
943 | break; | 945 | break; |
944 | }; | 946 | }; |
945 | 947 | ||
946 | } | 948 | } |
947 | 949 | ||
948 | void PlayListWidget::listDelete() { | 950 | void PlayListWidget::listDelete() { |
949 | Config cfg( "OpiePlayer" ); | 951 | Config cfg( "OpiePlayer" ); |
950 | cfg.setGroup("PlayList"); | 952 | cfg.setGroup("PlayList"); |
951 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); | 953 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); |
952 | QString file; | 954 | QString file; |
953 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | 955 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); |
954 | switch ( tabWidget->currentPageIndex()) { | 956 | switch ( tabWidget->currentPageIndex()) { |
955 | case 0: | 957 | case 0: |
956 | break; | 958 | break; |
957 | case 1: | 959 | case 1: |
958 | { | 960 | { |
959 | file = audioView->selectedItem()->text(0); | 961 | file = audioView->currentItem()->text(0); |
960 | // Global::findDocuments(&files, "audio/*"); | 962 | QListIterator<DocLnk> Pdit( files.children() ); |
961 | // AppLnkSet appFiles; | 963 | for ( ; Pdit.current(); ++Pdit ) { |
962 | QListIterator<DocLnk> dit( files.children() ); | 964 | if( Pdit.current()->name() == file) { |
963 | for ( ; dit.current(); ++dit ) { | 965 | LnkProperties prop( Pdit.current() ); |
964 | if( dit.current()->name() == file) { | ||
965 | // qDebug(file); | ||
966 | LnkProperties prop( dit.current() ); | ||
967 | // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); | ||
968 | prop.showMaximized(); | 966 | prop.showMaximized(); |
969 | prop.exec(); | 967 | prop.exec(); |
970 | } | 968 | } |
971 | } | 969 | } |
972 | populateAudioView(); | 970 | populateAudioView(); |
973 | } | 971 | } |
974 | break; | 972 | break; |
975 | case 2: | 973 | case 2: |
976 | { | 974 | { |
977 | // file = videoView->selectedItem()->text(0); | 975 | // file = videoView->selectedItem()->text(0); |
978 | // for ( int i = 0; i < noOfFiles; i++ ) { | 976 | // for ( int i = 0; i < noOfFiles; i++ ) { |
979 | // QString entryName; | 977 | // QString entryName; |
980 | // entryName.sprintf( "File%i", i + 1 ); | 978 | // entryName.sprintf( "File%i", i + 1 ); |
981 | // QString linkFile = cfg.readEntry( entryName ); | 979 | // QString linkFile = cfg.readEntry( entryName ); |
982 | // AppLnk lnk( AppLnk(linkFile)); | 980 | // AppLnk lnk( AppLnk(linkFile)); |
983 | // if( lnk.name() == file ) { | 981 | // if( lnk.name() == file ) { |
984 | // LnkProperties prop( &lnk); | 982 | // LnkProperties prop( &lnk); |
985 | // // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); | 983 | // // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); |
986 | // prop.showMaximized(); | 984 | // prop.showMaximized(); |
987 | // prop.exec(); | 985 | // prop.exec(); |
988 | // } | 986 | // } |
989 | // } | 987 | // } |
990 | } | 988 | } |
991 | break; | 989 | break; |
992 | }; | 990 | }; |
993 | } | 991 | } |
994 | 992 | ||
995 | void PlayListWidget::scanForAudio() { | 993 | void PlayListWidget::scanForAudio() { |
996 | qDebug("scan for audio"); | 994 | qDebug("scan for audio"); |
997 | files.detachChildren(); | 995 | files.detachChildren(); |
998 | QListIterator<DocLnk> sdit( files.children() ); | 996 | QListIterator<DocLnk> sdit( files.children() ); |
999 | for ( ; sdit.current(); ++sdit ) { | 997 | for ( ; sdit.current(); ++sdit ) { |
1000 | delete sdit.current(); | 998 | delete sdit.current(); |
1001 | } | 999 | } |
1002 | Global::findDocuments(&files, "audio/*"); | 1000 | Global::findDocuments(&files, "audio/*"); |
1003 | audioScan = TRUE; | 1001 | audioScan = TRUE; |
1004 | } | 1002 | } |
1005 | void PlayListWidget::scanForVideo() { | 1003 | void PlayListWidget::scanForVideo() { |
1006 | qDebug("scan for video"); | 1004 | qDebug("scan for video"); |
1007 | vFiles.detachChildren(); | 1005 | vFiles.detachChildren(); |
1008 | QListIterator<DocLnk> sdit( vFiles.children() ); | 1006 | QListIterator<DocLnk> sdit( vFiles.children() ); |
1009 | for ( ; sdit.current(); ++sdit ) { | 1007 | for ( ; sdit.current(); ++sdit ) { |
1010 | delete sdit.current(); | 1008 | delete sdit.current(); |
1011 | } | 1009 | } |
1012 | Global::findDocuments(&vFiles, "video/*"); | 1010 | Global::findDocuments(&vFiles, "video/*"); |
1013 | videoScan = TRUE; | 1011 | videoScan = TRUE; |
1014 | } | 1012 | } |
1015 | 1013 | ||
1016 | void PlayListWidget::populateAudioView() { | 1014 | void PlayListWidget::populateAudioView() { |
1017 | 1015 | ||
1018 | audioView->clear(); | 1016 | audioView->clear(); |
1019 | StorageInfo storageInfo; | 1017 | StorageInfo storageInfo; |
1020 | const QList<FileSystem> &fs = storageInfo.fileSystems(); | 1018 | const QList<FileSystem> &fs = storageInfo.fileSystems(); |
1021 | if(!audioScan) scanForAudio(); | 1019 | if(!audioScan) scanForAudio(); |
1022 | 1020 | ||
1023 | QListIterator<DocLnk> dit( files.children() ); | 1021 | QListIterator<DocLnk> dit( files.children() ); |
1024 | QListIterator<FileSystem> it ( fs ); | 1022 | QListIterator<FileSystem> it ( fs ); |
1025 | 1023 | ||
1026 | QString storage; | 1024 | QString storage; |
1027 | for ( ; dit.current(); ++dit ) { | 1025 | for ( ; dit.current(); ++dit ) { |
1028 | for( ; it.current(); ++it ){ | 1026 | for( ; it.current(); ++it ){ |
1029 | const QString name = (*it)->name(); | 1027 | const QString name = (*it)->name(); |
1030 | const QString path = (*it)->path(); | 1028 | const QString path = (*it)->path(); |
1031 | if(dit.current()->file().find(path) != -1 ) storage=name; | 1029 | if(dit.current()->file().find(path) != -1 ) storage=name; |
1032 | } | 1030 | } |
1033 | 1031 | ||
1034 | QListViewItem * newItem; | 1032 | QListViewItem * newItem; |
1035 | if ( QFile( dit.current()->file()).exists() ) { | 1033 | if ( QFile( dit.current()->file()).exists() ) { |
1036 | // qDebug(dit.current()->name()); | 1034 | // qDebug(dit.current()->name()); |
1037 | newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), | 1035 | newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), |
1038 | QString::number( QFile( dit.current()->file()).size() ), storage); | 1036 | QString::number( QFile( dit.current()->file()).size() ), storage); |
1039 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/musicfile" )); | 1037 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/musicfile" )); |
1040 | } | 1038 | } |
1041 | } | 1039 | } |
1042 | 1040 | ||
1043 | } | 1041 | } |
1044 | 1042 | ||
1045 | void PlayListWidget::populateVideoView() { | 1043 | void PlayListWidget::populateVideoView() { |
1046 | videoView->clear(); | 1044 | videoView->clear(); |
1047 | StorageInfo storageInfo; | 1045 | StorageInfo storageInfo; |
1048 | const QList<FileSystem> &fs = storageInfo.fileSystems(); | 1046 | const QList<FileSystem> &fs = storageInfo.fileSystems(); |
1049 | 1047 | ||
1050 | if(!videoScan ) scanForVideo(); | 1048 | if(!videoScan ) scanForVideo(); |
1051 | 1049 | ||
1052 | QListIterator<DocLnk> Vdit( vFiles.children() ); | 1050 | QListIterator<DocLnk> Vdit( vFiles.children() ); |
1053 | QListIterator<FileSystem> it ( fs ); | 1051 | QListIterator<FileSystem> it ( fs ); |
1054 | videoView->clear(); | 1052 | videoView->clear(); |
1055 | QString storage; | 1053 | QString storage; |
1056 | for ( ; Vdit.current(); ++Vdit ) { | 1054 | for ( ; Vdit.current(); ++Vdit ) { |
1057 | for( ; it.current(); ++it ){ | 1055 | for( ; it.current(); ++it ){ |
1058 | const QString name = (*it)->name(); | 1056 | const QString name = (*it)->name(); |
1059 | const QString path = (*it)->path(); | 1057 | const QString path = (*it)->path(); |
1060 | if( Vdit.current()->file().find(path) != -1 ) storage=name; | 1058 | if( Vdit.current()->file().find(path) != -1 ) storage=name; |
1061 | } | 1059 | } |
1062 | 1060 | ||
1063 | QListViewItem * newItem; | 1061 | QListViewItem * newItem; |
1064 | if ( QFile( Vdit.current()->file()).exists() ) { | 1062 | if ( QFile( Vdit.current()->file()).exists() ) { |
1065 | newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), | 1063 | newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), |
1066 | QString::number( QFile( Vdit.current()->file()).size() ), storage); | 1064 | QString::number( QFile( Vdit.current()->file()).size() ), storage); |
1067 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); | 1065 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); |
1068 | } | 1066 | } |
1069 | } | 1067 | } |
1070 | } | 1068 | } |
1071 | 1069 | ||
1072 | void PlayListWidget::openFile() { | 1070 | void PlayListWidget::openFile() { |
1073 | QString filename, name; | 1071 | QString filename, name; |
1074 | InputDialog *fileDlg; | 1072 | InputDialog *fileDlg; |
1075 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); | 1073 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); |
1076 | fileDlg->exec(); | 1074 | fileDlg->exec(); |
1077 | if( fileDlg->result() == 1 ) { | 1075 | if( fileDlg->result() == 1 ) { |
1078 | filename = fileDlg->LineEdit1->text(); | 1076 | filename = fileDlg->LineEdit1->text(); |
1079 | // http://205.188.234.129:8030 | 1077 | // http://205.188.234.129:8030 |
1080 | // http://66.28.68.70:8000 | 1078 | // http://66.28.68.70:8000 |
1081 | // filename.replace(QRegExp("%20")," "); | 1079 | // filename.replace(QRegExp("%20")," "); |
1082 | if(filename.find(" ",0,TRUE) != -1 || filename.find("%20",0,TRUE) != -1) { | ||
1083 | QMessageBox::message("Note","Spaces in urls are not allowed."); | ||
1084 | return; | ||
1085 | } else { | ||
1086 | qDebug("Selected filename is "+filename); | 1080 | qDebug("Selected filename is "+filename); |
1087 | if(filename.right(3) == "m3u") | 1081 | if(filename.right(3) == "m3u") |
1088 | readm3u( filename); | 1082 | readm3u( filename); |
1089 | else if(filename.right(3) == "pls") | 1083 | else if(filename.right(3) == "pls") |
1090 | readPls( filename); | 1084 | readPls( filename); |
1091 | else { | 1085 | else { |
1092 | DocLnk lnk; | 1086 | DocLnk lnk; |
1093 | 1087 | ||
1094 | lnk.setName(filename); //sets file name | 1088 | lnk.setName(filename); //sets file name |
1095 | if(filename.right(1) != "/" && filename.right(3) != "mp3" && filename.right(3) != "MP3") | 1089 | if(filename.right(1) != "/" && filename.right(3) != "mp3" && filename.right(3) != "MP3") |
1096 | filename += "/"; | 1090 | filename += "/"; |
1097 | lnk.setFile(filename); //sets File property | 1091 | lnk.setFile(filename); //sets File property |
1098 | 1092 | ||
1099 | lnk.setType("audio/x-mpegurl"); | 1093 | lnk.setType("audio/x-mpegurl"); |
1100 | lnk.setExec("opieplayer"); | 1094 | lnk.setExec("opieplayer"); |
1101 | lnk.setIcon("opieplayer/MPEGPlayer"); | 1095 | lnk.setIcon("opieplayer/MPEGPlayer"); |
1102 | 1096 | ||
1103 | if(!lnk.writeLink()) | 1097 | if(!lnk.writeLink()) |
1104 | qDebug("Writing doclink did not work"); | 1098 | qDebug("Writing doclink did not work"); |
1105 | d->selectedFiles->addToSelection( lnk); | 1099 | d->selectedFiles->addToSelection( lnk); |
1106 | // if(fileDlg2) | 1100 | // if(fileDlg2) |
1107 | // delete fileDlg2; | 1101 | // delete fileDlg2; |
1108 | } | 1102 | } |
1109 | } | ||
1110 | } | 1103 | } |
1111 | if(fileDlg) | 1104 | if(fileDlg) |
1112 | delete fileDlg; | 1105 | delete fileDlg; |
1113 | } | 1106 | } |
1114 | 1107 | ||
1115 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e) | 1108 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e) |
1116 | { | 1109 | { |
1117 | switch ( e->key() ) { | 1110 | switch ( e->key() ) { |
1118 | ////////////////////////////// Zaurus keys | 1111 | ////////////////////////////// Zaurus keys |
1119 | case Key_F9: //activity | 1112 | case Key_F9: //activity |
1120 | // if(audioUI->isHidden()) | 1113 | // if(audioUI->isHidden()) |
1121 | // audioUI->showMaximized(); | 1114 | // audioUI->showMaximized(); |
1122 | break; | 1115 | break; |
1123 | case Key_F10: //contacts | 1116 | case Key_F10: //contacts |
1124 | // if( videoUI->isHidden()) | 1117 | // if( videoUI->isHidden()) |
1125 | // videoUI->showMaximized(); | 1118 | // videoUI->showMaximized(); |
1126 | break; | 1119 | break; |
1127 | case Key_F11: //menu | 1120 | case Key_F11: //menu |
1128 | break; | 1121 | break; |
1129 | case Key_F12: //home | 1122 | case Key_F12: //home |
1130 | // doBlank(); | 1123 | // doBlank(); |
1131 | break; | 1124 | break; |
1132 | case Key_F13: //mail | 1125 | case Key_F13: //mail |
1133 | // doUnblank(); | 1126 | // doUnblank(); |
1134 | break; | 1127 | break; |
1135 | case Key_Q: //add to playlist | 1128 | case Key_Q: //add to playlist |
1136 | qDebug("Add"); | 1129 | qDebug("Add"); |
1137 | addSelected(); | 1130 | addSelected(); |
1138 | break; | 1131 | break; |
1139 | case Key_R: //remove from playlist | 1132 | case Key_R: //remove from playlist |
1140 | removeSelected(); | 1133 | removeSelected(); |
1141 | break; | 1134 | break; |
1142 | // case Key_P: //play | 1135 | // case Key_P: //play |
1143 | // qDebug("Play"); | 1136 | // qDebug("Play"); |
1144 | // playSelected(); | 1137 | // playSelected(); |
1145 | // break; | 1138 | // break; |
1146 | case Key_Space: | 1139 | case Key_Space: |
1147 | qDebug("Play"); | 1140 | qDebug("Play"); |
1148 | // playSelected(); puh | 1141 | // playSelected(); puh |
1149 | break; | 1142 | break; |
1150 | case Key_1: | 1143 | case Key_1: |
1151 | tabWidget->setCurrentPage(0); | 1144 | tabWidget->setCurrentPage(0); |
1152 | break; | 1145 | break; |
1153 | case Key_2: | 1146 | case Key_2: |
1154 | tabWidget->setCurrentPage(1); | 1147 | tabWidget->setCurrentPage(1); |
1155 | break; | 1148 | break; |
1156 | case Key_3: | 1149 | case Key_3: |
1157 | tabWidget->setCurrentPage(2); | 1150 | tabWidget->setCurrentPage(2); |
1158 | break; | 1151 | break; |
1159 | case Key_4: | 1152 | case Key_4: |
1160 | tabWidget->setCurrentPage(3); | 1153 | tabWidget->setCurrentPage(3); |
1161 | break; | 1154 | break; |
1162 | case Key_Down: | 1155 | case Key_Down: |
1163 | if ( !d->selectedFiles->next() ) | 1156 | if ( !d->selectedFiles->next() ) |
1164 | d->selectedFiles->first(); | 1157 | d->selectedFiles->first(); |
1165 | 1158 | ||
1166 | break; | 1159 | break; |
1167 | case Key_Up: | 1160 | case Key_Up: |
1168 | if ( !d->selectedFiles->prev() ) | 1161 | if ( !d->selectedFiles->prev() ) |
1169 | // d->selectedFiles->last(); | 1162 | // d->selectedFiles->last(); |
1170 | 1163 | ||
1171 | break; | 1164 | break; |
1172 | 1165 | ||
1173 | } | 1166 | } |
1174 | } | 1167 | } |
1175 | 1168 | ||
1176 | void PlayListWidget::keyPressEvent( QKeyEvent *e) | 1169 | void PlayListWidget::keyPressEvent( QKeyEvent *e) |
1177 | { | 1170 | { |
1178 | // qDebug("Key press"); | 1171 | // qDebug("Key press"); |
1179 | // switch ( e->key() ) { | 1172 | // switch ( e->key() ) { |
1180 | // ////////////////////////////// Zaurus keys | 1173 | // ////////////////////////////// Zaurus keys |
1181 | // case Key_A: //add to playlist | 1174 | // case Key_A: //add to playlist |
1182 | // qDebug("Add"); | 1175 | // qDebug("Add"); |
1183 | // addSelected(); | 1176 | // addSelected(); |
1184 | // break; | 1177 | // break; |
1185 | // case Key_R: //remove from playlist | 1178 | // case Key_R: //remove from playlist |
1186 | // removeSelected(); | 1179 | // removeSelected(); |
1187 | // break; | 1180 | // break; |
1188 | // case Key_P: //play | 1181 | // case Key_P: //play |
1189 | // qDebug("Play"); | 1182 | // qDebug("Play"); |
1190 | // playSelected(); | 1183 | // playSelected(); |
1191 | // break; | 1184 | // break; |
1192 | // case Key_Space: | 1185 | // case Key_Space: |
1193 | // qDebug("Play"); | 1186 | // qDebug("Play"); |
1194 | // playSelected(); | 1187 | // playSelected(); |
1195 | // break; | 1188 | // break; |
1196 | // } | 1189 | // } |
1197 | } | 1190 | } |
1198 | 1191 | ||
1199 | void PlayListWidget::doBlank() { | 1192 | void PlayListWidget::doBlank() { |
1200 | qDebug("do blanking"); | 1193 | qDebug("do blanking"); |
1201 | fd=open("/dev/fb0",O_RDWR); | 1194 | fd=open("/dev/fb0",O_RDWR); |
1202 | if (fd != -1) { | 1195 | if (fd != -1) { |
1203 | ioctl(fd,FBIOBLANK,1); | 1196 | ioctl(fd,FBIOBLANK,1); |
1204 | // close(fd); | 1197 | // close(fd); |
1205 | } | 1198 | } |
1206 | } | 1199 | } |
1207 | 1200 | ||
1208 | void PlayListWidget::doUnblank() { | 1201 | void PlayListWidget::doUnblank() { |
1209 | // this crashes opieplayer with a segfault | 1202 | // this crashes opieplayer with a segfault |
1210 | // int fd; | 1203 | // int fd; |
1211 | // fd=open("/dev/fb0",O_RDWR); | 1204 | // fd=open("/dev/fb0",O_RDWR); |
1212 | qDebug("do unblanking"); | 1205 | qDebug("do unblanking"); |
1213 | if (fd != -1) { | 1206 | if (fd != -1) { |
1214 | ioctl(fd,FBIOBLANK,0); | 1207 | ioctl(fd,FBIOBLANK,0); |
1215 | close(fd); | 1208 | close(fd); |
1216 | } | 1209 | } |
1217 | QCopEnvelope h("QPE/System", "setBacklight(int)"); | 1210 | QCopEnvelope h("QPE/System", "setBacklight(int)"); |
1218 | h <<-3;// v[1]; // -3 Force on | 1211 | h <<-3;// v[1]; // -3 Force on |
1219 | } | 1212 | } |
1220 | 1213 | ||
1221 | void PlayListWidget::readm3u(const QString &filename) { | 1214 | void PlayListWidget::readm3u(const QString &filename) { |
1222 | 1215 | ||
1223 | qDebug("m3u filename is "+filename); | 1216 | qDebug("m3u filename is "+filename); |
1224 | QFile f(filename); | 1217 | QFile f(filename); |
1225 | 1218 | ||
1226 | if(f.open(IO_ReadOnly)) { | 1219 | if(f.open(IO_ReadOnly)) { |
1227 | QTextStream t(&f); | 1220 | QTextStream t(&f); |
1228 | QString s;//, first, second; | 1221 | QString s;//, first, second; |
1229 | int i=0; | 1222 | int i=0; |
1230 | while ( !t.atEnd()) { | 1223 | while ( !t.atEnd()) { |
1231 | // Lview->insertLine(t.readLine(),-1); | 1224 | // Lview->insertLine(t.readLine(),-1); |
1232 | s=t.readLine(); | 1225 | s=t.readLine(); |
1233 | if(s.find(" ",0,TRUE) != -1 || s.find("%20",0,TRUE) != -1) { | 1226 | |
1234 | QMessageBox::message("Note","Spaces in urls are not allowed."); | 1227 | if(s.find("#",0,TRUE) == -1) { |
1235 | } | ||
1236 | else if(s.find("#",0,TRUE) == -1) { | ||
1237 | if(s.find(" ",0,TRUE) == -1) { // not sure if this is neede since cf uses vfat | 1228 | if(s.find(" ",0,TRUE) == -1) { // not sure if this is neede since cf uses vfat |
1238 | if(s.left(2) == "E:" || s.left(2) == "P:") { | 1229 | if(s.left(2) == "E:" || s.left(2) == "P:") { |
1239 | s=s.right(s.length()-2); | 1230 | s=s.right(s.length()-2); |
1240 | DocLnk lnk( s ); | 1231 | DocLnk lnk( s ); |
1241 | QFileInfo f(s); | 1232 | QFileInfo f(s); |
1242 | QString name = f.baseName(); | 1233 | QString name = f.baseName(); |
1243 | name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); | 1234 | name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); |
1244 | lnk.setName( name); | 1235 | lnk.setName( name); |
1245 | s=s.replace( QRegExp("\\"),"/"); | 1236 | s=s.replace( QRegExp("\\"),"/"); |
1246 | lnk.setFile( s); | 1237 | lnk.setFile( s); |
1247 | lnk.writeLink(); | 1238 | lnk.writeLink(); |
1248 | // lnk.setIcon(opieplayer/MPEGPlayer); | 1239 | // lnk.setIcon(opieplayer/MPEGPlayer); |
1249 | qDebug("add "+name); | 1240 | qDebug("add "+name); |
1250 | d->selectedFiles->addToSelection( lnk); | 1241 | d->selectedFiles->addToSelection( lnk); |
1251 | } else { // is url | 1242 | } else { // is url |
1252 | 1243 | ||
1253 | s.replace(QRegExp("%20")," "); | 1244 | s.replace(QRegExp("%20")," "); |
1254 | DocLnk lnk( s); | 1245 | DocLnk lnk( s); |
1255 | QString name; | 1246 | QString name; |
1256 | if(name.left(4)=="http") | 1247 | if(name.left(4)=="http") |
1257 | name = s.right( s.length() - 7); | 1248 | name = s.right( s.length() - 7); |
1258 | else | 1249 | else |
1259 | name=s; | 1250 | name=s; |
1260 | // name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); | 1251 | // name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); |
1261 | lnk.setName(name); | 1252 | lnk.setName(name); |
1262 | if(s.at(s.length()-4) == '.') | 1253 | if(s.at(s.length()-4) == '.') |
1263 | lnk.setFile( s); | 1254 | lnk.setFile( s); |
1264 | else | 1255 | else |
1265 | lnk.setFile( s+"/"); | 1256 | lnk.setFile( s+"/"); |
1266 | // lnk.setFile( filename); | 1257 | // lnk.setFile( filename); |
1267 | // lnk.setComment( s+"/"); | 1258 | // lnk.setComment( s+"/"); |
1268 | lnk.setType("audio/x-mpegurl"); | 1259 | lnk.setType("audio/x-mpegurl"); |
1269 | lnk.writeLink(); | 1260 | lnk.writeLink(); |
1270 | // lnk.setIcon( "opieplayer/MPEGPlayer"); | 1261 | // lnk.setIcon( "opieplayer/MPEGPlayer"); |
1271 | // qDebug("add "+s); | 1262 | // qDebug("add "+s); |
1272 | d->selectedFiles->addToSelection( lnk); | 1263 | d->selectedFiles->addToSelection( lnk); |
1273 | } | 1264 | } |
1274 | i++; | 1265 | i++; |
1275 | } | 1266 | } |
1276 | } | 1267 | } |
1277 | } | 1268 | } |
1278 | } | 1269 | } |
1279 | f.close(); | 1270 | f.close(); |
1280 | } | 1271 | } |
1281 | 1272 | ||
1282 | void PlayListWidget::writem3u() { | 1273 | void PlayListWidget::writem3u() { |
1283 | 1274 | ||
1284 | InputDialog *fileDlg; | 1275 | InputDialog *fileDlg; |
1285 | fileDlg = new InputDialog(this,tr("Save m3u Playlist "),TRUE, 0); | 1276 | fileDlg = new InputDialog(this,tr("Save m3u Playlist "),TRUE, 0); |
1286 | fileDlg->exec(); | 1277 | fileDlg->exec(); |
1287 | QString filename,list; | 1278 | QString filename,list; |
1288 | if( fileDlg->result() == 1 ) { | 1279 | if( fileDlg->result() == 1 ) { |
1289 | filename = fileDlg->LineEdit1->text(); | 1280 | filename = fileDlg->LineEdit1->text(); |
1290 | qDebug(filename); | 1281 | qDebug(filename); |
1291 | int noOfFiles = 0; | 1282 | int noOfFiles = 0; |
1292 | d->selectedFiles->first(); | 1283 | d->selectedFiles->first(); |
1293 | do { | 1284 | do { |
1294 | // we dont check for existance because of url's | 1285 | // we dont check for existance because of url's |
1295 | // qDebug(d->selectedFiles->current()->file()); | 1286 | // qDebug(d->selectedFiles->current()->file()); |
1296 | list += d->selectedFiles->current()->file()+"\n"; | 1287 | list += d->selectedFiles->current()->file()+"\n"; |
1297 | noOfFiles++; | 1288 | noOfFiles++; |
1298 | } | 1289 | } |
1299 | while ( d->selectedFiles->next() ); | 1290 | while ( d->selectedFiles->next() ); |
1300 | qDebug(list); | 1291 | qDebug(list); |
1301 | if(filename.left(1) != "/") | 1292 | if(filename.left(1) != "/") |
1302 | filename=QPEApplication::documentDir()+"/"+filename; | 1293 | filename=QPEApplication::documentDir()+"/"+filename; |
1303 | if(filename.right(3) != "m3u") | 1294 | if(filename.right(3) != "m3u") |
1304 | filename=filename+".m3u"; | 1295 | filename=filename+".m3u"; |
1305 | 1296 | ||
1306 | QFile f(filename); | 1297 | QFile f(filename); |
1307 | f.open(IO_WriteOnly); | 1298 | f.open(IO_WriteOnly); |
1308 | f.writeBlock(list, list.length()); | 1299 | f.writeBlock(list, list.length()); |
1309 | f.close(); | 1300 | f.close(); |
1310 | } | 1301 | } |
1311 | if(fileDlg) delete fileDlg; | 1302 | if(fileDlg) delete fileDlg; |
1312 | } | 1303 | } |
1313 | 1304 | ||
1314 | void PlayListWidget::readPls(const QString &filename) { | 1305 | void PlayListWidget::readPls(const QString &filename) { |
1315 | 1306 | ||
1316 | qDebug("pls filename is "+filename); | 1307 | qDebug("pls filename is "+filename); |
1317 | QFile f(filename); | 1308 | QFile f(filename); |
1318 | 1309 | ||
1319 | if(f.open(IO_ReadOnly)) { | 1310 | if(f.open(IO_ReadOnly)) { |
1320 | QTextStream t(&f); | 1311 | QTextStream t(&f); |
1321 | QString s;//, first, second; | 1312 | QString s;//, first, second; |
1322 | int i=0; | 1313 | int i=0; |
1323 | while ( !t.atEnd()) { | 1314 | while ( !t.atEnd()) { |
1324 | s=t.readLine(); | 1315 | s=t.readLine(); |
1325 | if(s.left(4) == "File") { | 1316 | if(s.left(4) == "File") { |
1326 | s=s.right(s.length() - 6); | 1317 | s=s.right(s.length() - 6); |
1327 | s.replace(QRegExp("%20")," "); | 1318 | s.replace(QRegExp("%20")," "); |
1328 | qDebug("adding "+s+" to playlist"); | 1319 | qDebug("adding "+s+" to playlist"); |
1329 | // numberofentries=2 | 1320 | // numberofentries=2 |
1330 | // File1=http | 1321 | // File1=http |
1331 | // Title | 1322 | // Title |
1332 | // Length | 1323 | // Length |