X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fstream_out%2Fautodel.c;h=dffb687c4130222dab347a0ac8d425e9cdf4f54d;hb=9d4515ac4873076af85af33270d126818c0e8639;hp=9293d979740b629c3f5738cb28b30449ab420669;hpb=27d483e9ef7a451397d7857251c8d67097661f1d;p=vlc diff --git a/modules/stream_out/autodel.c b/modules/stream_out/autodel.c index 9293d97974..dffb687c41 100644 --- a/modules/stream_out/autodel.c +++ b/modules/stream_out/autodel.c @@ -29,7 +29,7 @@ # include "config.h" #endif -#include +#include #include #include #include @@ -42,13 +42,13 @@ static void Close ( vlc_object_t * ); #define SOUT_CFG_PREFIX "sout-autodel-" -vlc_module_begin(); - set_shortname( _("Autodel")); - set_description( _("Automatically add/delete input streams")); - set_capability( "sout stream", 50 ); - add_shortcut( "autodel" ); - set_callbacks( Open, Close ); -vlc_module_end(); +vlc_module_begin () + set_shortname( N_("Autodel")) + set_description( N_("Automatically add/delete input streams")) + set_capability( "sout stream", 50 ) + add_shortcut( "autodel" ) + set_callbacks( Open, Close ) +vlc_module_end () /***************************************************************************** @@ -68,7 +68,6 @@ struct sout_stream_id_t struct sout_stream_sys_t { - sout_stream_t *p_out; sout_stream_id_t **pp_es; int i_es_num; }; @@ -83,8 +82,7 @@ static int Open( vlc_object_t *p_this ) p_sys = malloc( sizeof( sout_stream_sys_t ) ); - p_sys->p_out = sout_StreamNew( p_stream->p_sout, p_stream->psz_next ); - if( !p_sys->p_out ) + if( !p_stream->p_next ) { msg_Err( p_stream, "cannot create chain" ); free( p_sys ); @@ -113,7 +111,6 @@ static void Close( vlc_object_t * p_this ) sout_stream_t *p_stream = (sout_stream_t*)p_this; sout_stream_sys_t *p_sys = (sout_stream_sys_t *)p_stream->p_sys; - sout_StreamDelete( p_sys->p_out ); p_stream->p_sout->i_out_pace_nocontrol--; free( p_sys ); @@ -126,7 +123,7 @@ static sout_stream_id_t * Add( sout_stream_t *p_stream, es_format_t *p_fmt ) p_es->fmt = *p_fmt; p_es->id = NULL; - p_es->i_last = 0; + p_es->i_last = VLC_TS_INVALID; p_es->b_error = false; TAB_APPEND( p_sys->i_es_num, p_sys->pp_es, p_es ); @@ -142,7 +139,7 @@ static int Del( sout_stream_t *p_stream, sout_stream_id_t *p_es ) free( p_es ); if ( id != NULL ) - return p_sys->p_out->pf_del( p_sys->p_out, id ); + return p_stream->p_next->pf_del( p_stream->p_next, id ); else return VLC_SUCCESS; } @@ -155,9 +152,9 @@ static int Send( sout_stream_t *p_stream, sout_stream_id_t *p_es, int i; p_es->i_last = p_buffer->i_dts; - if ( p_es->id == NULL && p_es->b_error != true ) + if ( !p_es->id && !p_es->b_error ) { - p_es->id = p_sys->p_out->pf_add( p_sys->p_out, &p_es->fmt ); + p_es->id = p_stream->p_next->pf_add( p_stream->p_next, &p_es->fmt ); if ( p_es->id == NULL ) { p_es->b_error = true; @@ -166,8 +163,8 @@ static int Send( sout_stream_t *p_stream, sout_stream_id_t *p_es, } } - if ( p_es->b_error != true ) - p_sys->p_out->pf_send( p_sys->p_out, p_es->id, p_buffer ); + if ( !p_es->b_error ) + p_stream->p_next->pf_send( p_stream->p_next, p_es->id, p_buffer ); else block_ChainRelease( p_buffer ); @@ -178,7 +175,7 @@ static int Send( sout_stream_t *p_stream, sout_stream_id_t *p_es, || p_sys->pp_es[i]->fmt.i_cat == AUDIO_ES) && p_sys->pp_es[i]->i_last < i_current ) { - p_sys->p_out->pf_del( p_sys->p_out, p_sys->pp_es[i]->id ); + p_stream->p_next->pf_del( p_stream->p_next, p_sys->pp_es[i]->id ); p_sys->pp_es[i]->id = NULL; } }