X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fstream_out%2Fautodel.c;h=e9229e5dcfdc0cfa2d303146dd13f30af9b6d0ea;hb=9365e5b08acc788b1ddb55b9b62152572146f8f4;hp=5cf813a223e7cd2537567867fdb49582d375d561;hpb=df61d33b06e2b3cbbe746b2f5a9bea5b370c24ff;p=vlc diff --git a/modules/stream_out/autodel.c b/modules/stream_out/autodel.c index 5cf813a223..e9229e5dcf 100644 --- a/modules/stream_out/autodel.c +++ b/modules/stream_out/autodel.c @@ -29,7 +29,8 @@ # include "config.h" #endif -#include +#include +#include #include #include @@ -41,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 () /***************************************************************************** @@ -67,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; }; @@ -82,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 ); @@ -112,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 ); @@ -125,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 ); @@ -141,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; } @@ -156,7 +154,7 @@ static int Send( sout_stream_t *p_stream, sout_stream_id_t *p_es, p_es->i_last = p_buffer->i_dts; if ( p_es->id == NULL && p_es->b_error != true ) { - 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,7 +164,7 @@ 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 ); + p_stream->p_next->pf_send( p_stream->p_next, p_es->id, p_buffer ); else block_ChainRelease( p_buffer ); @@ -177,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; } }