X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fdemux%2Fplaylist%2Fpls.c;h=6c308319cc01a2decfc0bcb2af000e49afb91460;hb=80bd0c5d39ba8ac1c52f747da6d2b18a4e20ff7f;hp=d499db0badab8b366cc4716b1fbbc81635e2e952;hpb=6ee1e193fd896ab9a4729fde14f009d9ce629815;p=vlc diff --git a/modules/demux/playlist/pls.c b/modules/demux/playlist/pls.c index d499db0bad..6c308319cc 100644 --- a/modules/demux/playlist/pls.c +++ b/modules/demux/playlist/pls.c @@ -1,31 +1,35 @@ /***************************************************************************** * pls.c : PLS playlist format import ***************************************************************************** - * Copyright (C) 2004 the VideoLAN team + * Copyright (C) 2004 VLC authors and VideoLAN * $Id$ * * Authors: Clément Stenac * Authors: Sigmund Augdal Helberg * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ /***************************************************************************** * Preamble *****************************************************************************/ -#include +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include #include #include "playlist.h" @@ -39,26 +43,25 @@ struct demux_sys_t * Local prototypes *****************************************************************************/ static int Demux( demux_t *p_demux); -static int Control( demux_t *p_demux, int i_query, va_list args ); /***************************************************************************** * Import_PLS: main import function *****************************************************************************/ -int E_(Import_PLS)( vlc_object_t *p_this ) +int Import_PLS( vlc_object_t *p_this ) { demux_t *p_demux = (demux_t *)p_this; - uint8_t *p_peek; + const uint8_t *p_peek; CHECK_PEEK( p_peek, 10 ); if( POKE( p_peek, "[playlist]", 10 ) || POKE( p_peek, "[Reference]", 10 ) || - demux2_IsPathExtension( p_demux, ".pls" ) || demux2_IsForced( p_demux, "pls" ) ) + demux_IsPathExtension( p_demux, ".pls" ) || demux_IsForced( p_demux, "pls" ) ) { ; } else return VLC_EGENERIC; STANDARD_DEMUX_INIT_MSG( "found valid PLS playlist file"); - p_demux->p_sys->psz_prefix = E_(FindPrefix)( p_demux ); + p_demux->p_sys->psz_prefix = FindPrefix( p_demux ); return VLC_SUCCESS; } @@ -66,19 +69,15 @@ int E_(Import_PLS)( vlc_object_t *p_this ) /***************************************************************************** * Deactivate: frees unused data *****************************************************************************/ -void E_(Close_PLS)( vlc_object_t *p_this ) +void Close_PLS( vlc_object_t *p_this ) { demux_t *p_demux = (demux_t *)p_this; - if( p_demux->p_sys->psz_prefix ) - { - free( p_demux->p_sys->psz_prefix ); - } + free( p_demux->p_sys->psz_prefix ); free( p_demux->p_sys ); } static int Demux( demux_t *p_demux ) { - mtime_t i_duration = -1; char *psz_name = NULL; char *psz_line; char *psz_mrl = NULL; @@ -86,11 +85,11 @@ static int Demux( demux_t *p_demux ) char *psz_key; char *psz_value; int i_item = -1; - int i_new_item = 0; - int i_key_length; input_item_t *p_input; - INIT_PLAYLIST_STUFF; + input_item_t *p_current_input = GetCurrentItem(p_demux); + + input_item_node_t *p_subitems = input_item_node_Create( p_current_input ); while( ( psz_line = stream_ReadLine( p_demux->s ) ) ) { @@ -109,7 +108,6 @@ static int Demux( demux_t *p_demux ) } else { - msg_Warn( p_demux, "invalid line in pls file" ); free( psz_line ); continue; } @@ -125,90 +123,59 @@ static int Demux( demux_t *p_demux ) free( psz_line); continue; } + /* find the number part of of file1, title1 or length1 etc */ - i_key_length = strlen( psz_key ); - if( i_key_length >= 4 ) /* Ref1 type case */ - { - i_new_item = atoi( psz_key + 3 ); - if( i_new_item == 0 && i_key_length >= 5 ) /* file1 type case */ - { - i_new_item = atoi( psz_key + 4 ); - if( i_new_item == 0 && i_key_length >= 6 ) /* title1 type case */ - { - i_new_item = atoi( psz_key + 5 ); - if( i_new_item == 0 && i_key_length >= 7 ) /* length1 type case */ - { - i_new_item = atoi( psz_key + 6 ); - } - } - } - } - if( i_new_item == 0 ) + int i_new_item; + if( sscanf( psz_key, "%*[^0-9]%d", &i_new_item ) != 1 ) { msg_Warn( p_demux, "couldn't find number of items" ); free( psz_line ); continue; } + if( i_item == -1 ) - { i_item = i_new_item; - } - /* we found a new item, insert the previous */ - if( i_item != i_new_item ) + else if( i_item != i_new_item ) { + /* we found a new item, insert the previous */ if( psz_mrl ) { - p_input = input_ItemNewExt( p_playlist, psz_mrl, psz_name, - 0, NULL, -1 ); - input_ItemCopyOptions( p_current_input, p_input ); - input_ItemAddSubItem( p_current_input, p_input ); + p_input = input_item_New( psz_mrl, psz_name ); + input_item_CopyOptions( p_current_input, p_input ); + input_item_node_AppendItem( p_subitems, p_input ); + vlc_gc_decref( p_input ); + free( psz_mrl_orig ); + psz_mrl_orig = psz_mrl = NULL; } else { msg_Warn( p_demux, "no file= part found for item %d", i_item ); } - if( psz_name ) - { - free( psz_name ); - psz_name = NULL; - } - i_duration = -1; + free( psz_name ); + psz_name = NULL; i_item = i_new_item; - i_new_item = 0; } + if( !strncasecmp( psz_key, "file", sizeof("file") -1 ) || !strncasecmp( psz_key, "Ref", sizeof("Ref") -1 ) ) { - if( psz_mrl_orig ) - free( psz_mrl_orig ); + free( psz_mrl_orig ); psz_mrl_orig = - psz_mrl = E_(ProcessMRL)( psz_value, p_demux->p_sys->psz_prefix ); + psz_mrl = ProcessMRL( psz_value, p_demux->p_sys->psz_prefix ); if( !strncasecmp( psz_key, "Ref", sizeof("Ref") -1 ) ) { if( !strncasecmp( psz_mrl, "http://", sizeof("http://") -1 ) ) - { - psz_mrl++; - psz_mrl[0] = 'm'; - psz_mrl[1] = 'm'; - psz_mrl[2] = 's'; - } + memcpy( psz_mrl, "mmsh", 4 ); } } else if( !strncasecmp( psz_key, "title", sizeof("title") -1 ) ) { - if( psz_name ) - free( psz_name ); + free( psz_name ); psz_name = strdup( psz_value ); } else if( !strncasecmp( psz_key, "length", sizeof("length") -1 ) ) - { - i_duration = atoi( psz_value ); - if( i_duration != -1 ) - { - i_duration *= 1000000; - } - } + /* duration in seconds */; else { msg_Warn( p_demux, "unknown key found in pls file: %s", psz_key ); @@ -218,27 +185,21 @@ static int Demux( demux_t *p_demux ) /* Add last object */ if( psz_mrl ) { - p_input = input_ItemNewExt( p_playlist, psz_mrl, psz_name,0, NULL, -1 ); - input_ItemCopyOptions( p_current_input, p_input ); - input_ItemAddSubItem( p_current_input, p_input ); + p_input = input_item_New( psz_mrl, psz_name ); + input_item_CopyOptions( p_current_input, p_input ); + input_item_node_AppendItem( p_subitems, p_input ); + vlc_gc_decref( p_input ); free( psz_mrl_orig ); - psz_mrl = NULL; } else { msg_Warn( p_demux, "no file= part found for item %d", i_item ); } - if( psz_name ) - { - free( psz_name ); - psz_name = NULL; - } + free( psz_name ); + psz_name = NULL; - HANDLE_PLAY_AND_RELEASE; - return -1; /* Needed for correct operation of go back */ -} + input_item_node_PostAndDelete( p_subitems ); -static int Control( demux_t *p_demux, int i_query, va_list args ) -{ - return VLC_EGENERIC; + vlc_gc_decref(p_current_input); + return 0; /* Needed for correct operation of go back */ }