Commit 343c86e8 authored by Ilkka Ollakka's avatar Ilkka Ollakka

Don't wait location-node for creating input, and allow multiple

location nodes on track.

Use last location-node for uri (maybe first would be better instead ?).

check that input_item_NewExt doesn't return NULL

should fix ticket #2353
parent 1b3c30b3
...@@ -394,7 +394,6 @@ static bool parse_tracklist_node COMPLEX_INTERFACE ...@@ -394,7 +394,6 @@ static bool parse_tracklist_node COMPLEX_INTERFACE
*/ */
static bool parse_track_node COMPLEX_INTERFACE static bool parse_track_node COMPLEX_INTERFACE
{ {
input_item_t *p_new_input = NULL;
int i_node; int i_node;
char *psz_name = NULL; char *psz_name = NULL;
char *psz_value = NULL; char *psz_value = NULL;
...@@ -417,6 +416,14 @@ static bool parse_track_node COMPLEX_INTERFACE ...@@ -417,6 +416,14 @@ static bool parse_track_node COMPLEX_INTERFACE
{NULL, UNKNOWN_CONTENT, {NULL} } {NULL, UNKNOWN_CONTENT, {NULL} }
}; };
input_item_t *p_new_input = input_item_NewExt( p_demux, NULL, NULL, 0, NULL, -1 );
if( !p_new_input )
{
/* malloc has failed for input_item_NewExt, so bailout early */
return false;
}
/* reset i_track_id */ /* reset i_track_id */
p_demux->p_sys->i_track_id = -1; p_demux->p_sys->i_track_id = -1;
...@@ -503,11 +510,13 @@ static bool parse_track_node COMPLEX_INTERFACE ...@@ -503,11 +510,13 @@ static bool parse_track_node COMPLEX_INTERFACE
if( p_demux->p_sys->i_track_id < 0 ) if( p_demux->p_sys->i_track_id < 0 )
{ {
if( p_new_input ) char *psz_uri = input_item_GetURI( p_new_input );
if( psz_uri && *psz_uri)
{ {
input_item_AddSubItem( p_input_item, p_new_input ); input_item_AddSubItem( p_input_item, p_new_input );
vlc_gc_decref( p_new_input );
} }
vlc_gc_decref( p_new_input );
free( psz_uri );
return true; return true;
} }
...@@ -543,14 +552,6 @@ static bool parse_track_node COMPLEX_INTERFACE ...@@ -543,14 +552,6 @@ static bool parse_track_node COMPLEX_INTERFACE
if( !strcmp( p_handler->name, "location" ) ) if( !strcmp( p_handler->name, "location" ) )
{ {
char *psz_uri = NULL; char *psz_uri = NULL;
/* there MUST NOT be an item */
if( p_new_input )
{
msg_Err( p_demux, "item <%s> already created",
psz_name );
FREE_ATT();
return false;
}
psz_uri = decode_URI_duplicate( psz_value ); psz_uri = decode_URI_duplicate( psz_value );
if( psz_uri ) if( psz_uri )
...@@ -581,6 +582,12 @@ static bool parse_track_node COMPLEX_INTERFACE ...@@ -581,6 +582,12 @@ static bool parse_track_node COMPLEX_INTERFACE
FREE_ATT(); FREE_ATT();
return false; return false;
} }
input_item_SetURI( p_new_input, psz_uri );
free( psz_uri );
input_item_CopyOptions( p_input_item, p_new_input );
psz_uri = NULL;
FREE_ATT();
p_handler = NULL;
} }
else else
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment