input slave) Untested.
media_instance.c no longer depends on input_internal.h
Clean up a bit es_out pause handling.
Fixed DEMUX_GET_FPS description (double not float)
*/
DEMUX_SET_NEXT_DEMUX_TIME, /* arg1= int64_t * can fail */
/* FPS for correct subtitles handling */
- DEMUX_GET_FPS, /* arg1= float * res=can fail */
+ DEMUX_GET_FPS, /* arg1= double * res=can fail */
/* Meta data */
DEMUX_GET_META, /* arg1= vlc_meta_t ** res=can fail */
/* Input properties */
INPUT_GET_BYTE_POSITION, /* arg1= int64_t * res= */
INPUT_SET_BYTE_SIZE, /* arg1= int64_t * res= */
+ INPUT_GET_VIDEO_FPS, /* arg1= double * res=can fail */
/* bookmarks */
INPUT_GET_BOOKMARKS, /* arg1= seekpoint_t *** arg2= int * res=can fail */
#include <vlc/libvlc.h>
#include <vlc_demux.h>
#include <vlc_input.h>
-#include "input/input_internal.h"
#include "libvlc_internal.h"
+#include "libvlc.h"
/*
* Release the associated input thread
libvlc_media_instance_t *p_mi,
libvlc_exception_t *p_e)
{
+ input_thread_t *p_input_thread = libvlc_get_input_thread ( p_mi, p_e );
double f_fps = 0.0;
- input_thread_t *p_input_thread;
-
- p_input_thread = libvlc_get_input_thread ( p_mi, p_e );
- if( !p_input_thread )
- return 0.0;
- if( (NULL == p_input_thread->p->input.p_demux)
- || demux2_Control( p_input_thread->p->input.p_demux, DEMUX_GET_FPS, &f_fps )
- || f_fps < 0.1 )
- {
- vlc_object_release( p_input_thread );
- return 0.0;
- }
- else
+ if( p_input_thread )
{
+ if( input_Control( p_input_thread, INPUT_GET_VIDEO_FPS, &f_fps ) )
+ f_fps = 0.0;
vlc_object_release( p_input_thread );
- return( f_fps );
}
+ return f_fps;
}
vlc_bool_t libvlc_media_instance_will_play(
stream_Size( p_input->p->input.p_stream );
return VLC_SUCCESS;
+ case INPUT_GET_VIDEO_FPS:
+ {
+ int i;
+ pf = (double*)va_arg( args, double * );
+ vlc_mutex_lock( &p_input->p->input.p_item->lock );
+ *pf = p_input->p->input.f_fps;
+ for( i = 0; i < p_input->p->i_slave && *pf <= 0.001; i++ )
+ *pf = p_input->p->slave[i]->f_fps;
+ vlc_mutex_unlock( &p_input->p->input.p_item->lock );
+ return VLC_SUCCESS;
+ }
+
case INPUT_ADD_SLAVE:
psz = (char*)va_arg( args, char * );
if( psz && *psz )
input_DecoderDiscontinuity( es->p_dec, b_flush );
}
}
-void input_EsOutSetRate( es_out_t *out )
+void input_EsOutChangeRate( es_out_t *out )
{
es_out_sys_t *p_sys = out->p_sys;
int i;
+ input_EsOutDiscontinuity( out, VLC_FALSE, VLC_FALSE );
+
for( i = 0; i < p_sys->i_pgrm; i++ )
input_ClockSetRate( p_sys->p_input, &p_sys->pgrm[i]->clock );
}
else if( i_cat == SPU_ES )
p_sys->i_spu_delay = i_delay;
}
+void input_EsOutChangeState( es_out_t *out )
+{
+ es_out_sys_t *p_sys = out->p_sys;
+ input_thread_t *p_input = p_sys->p_input;
+
+ if( p_input->i_state == PAUSE_S )
+ {
+ /* Send discontinuity to decoders (it will allow them to flush
+ * * if implemented */
+ input_EsOutDiscontinuity( out, VLC_FALSE, VLC_FALSE );
+ }
+ else
+ {
+ /* Out of pause, reset pcr */
+ es_out_Control( out, ES_OUT_RESET_PCR );
+ }
+}
vlc_bool_t input_EsOutDecodersEmpty( es_out_t *out )
{
val.i_int = PLAYING_S;
var_Change( p_input, "state", VLC_VAR_SETVALUE, &val, NULL );
- /* Reset clock */
- es_out_Control( p_input->p->p_es_out, ES_OUT_RESET_PCR );
+ /* */
+ if( !i_ret )
+ input_EsOutChangeState( p_input->p->p_es_out );
}
else if( val.i_int == PAUSE_S && p_input->i_state == PLAYING_S &&
p_input->p->b_can_pause )
p_input->i_state = val.i_int;
var_Change( p_input, "state", VLC_VAR_SETVALUE, &val, NULL );
- /* Send discontinuity to decoders (it will allow them to flush
- * if implemented */
- input_EsOutDiscontinuity( p_input->p->p_es_out, VLC_FALSE, VLC_FALSE );
+ /* */
+ if( !i_ret )
+ input_EsOutChangeState( p_input->p->p_es_out );
}
else if( val.i_int == PAUSE_S && !p_input->p->b_can_pause )
{
val.i_int = i_rate;
var_Change( p_input, "rate", VLC_VAR_SETVALUE, &val, NULL );
- input_EsOutDiscontinuity( p_input->p->p_es_out,
- VLC_FALSE, VLC_FALSE );
-
p_input->p->i_rate = i_rate;
- input_EsOutSetRate( p_input->p->p_es_out );
+ input_EsOutChangeRate( p_input->p->p_es_out );
b_force_update = VLC_TRUE;
}
TAB_INIT( in->i_title, in->title );
in->b_can_pace_control = VLC_TRUE;
in->b_eof = VLC_FALSE;
+ in->f_fps = 0.0;
in->i_cr_average = 0;
return in;
char *psz_tmp;
char *psz;
vlc_value_t val;
+ double f_fps;
strcpy( psz_dup, psz_mrl );
in->b_title_demux = VLC_TRUE;
}
}
- /* get attachment
- * FIXME improve for b_preparsing: move it after GET_META and check psz_arturl */
- if( 1 || !p_input->b_preparsing )
+ }
+
+ /* get attachment
+ * FIXME improve for b_preparsing: move it after GET_META and check psz_arturl */
+ if( 1 || !p_input->b_preparsing )
+ {
+ int i_attachment;
+ input_attachment_t **attachment;
+ if( !demux2_Control( in->p_demux, DEMUX_GET_ATTACHMENTS,
+ &attachment, &i_attachment ) )
{
- int i_attachment;
- input_attachment_t **attachment;
- if( !demux2_Control( in->p_demux, DEMUX_GET_ATTACHMENTS,
- &attachment, &i_attachment ) )
- {
- int i;
- vlc_mutex_lock( &p_input->p->input.p_item->lock );
- p_input->p->attachment = realloc( p_input->p->attachment,
- sizeof(input_attachment_t**) * ( p_input->p->i_attachment + i_attachment ) );
- for( i = 0; i < i_attachment; i++ )
- p_input->p->attachment[p_input->p->i_attachment++] = attachment[i];
- if( attachment )
- free( attachment );
- vlc_mutex_unlock( &p_input->p->input.p_item->lock );
- }
+ int i;
+ vlc_mutex_lock( &p_input->p->input.p_item->lock );
+ p_input->p->attachment = realloc( p_input->p->attachment,
+ sizeof(input_attachment_t**) * ( p_input->p->i_attachment + i_attachment ) );
+ for( i = 0; i < i_attachment; i++ )
+ p_input->p->attachment[p_input->p->i_attachment++] = attachment[i];
+ if( attachment )
+ free( attachment );
+ vlc_mutex_unlock( &p_input->p->input.p_item->lock );
}
}
+ if( !demux2_Control( in->p_demux, DEMUX_GET_FPS, &f_fps ) )
+ {
+ vlc_mutex_lock( &p_input->p->input.p_item->lock );
+ in->f_fps = f_fps;
+ vlc_mutex_unlock( &p_input->p->input.p_item->lock );
+ }
if( var_GetInteger( p_input, "clock-synchro" ) != -1 )
in->b_can_pace_control = !var_GetInteger( p_input, "clock-synchro" );
vlc_bool_t b_can_pace_control;
vlc_bool_t b_can_pause;
vlc_bool_t b_eof; /* eof of demuxer */
+ double f_fps;
/* Clock average variation */
int i_cr_average;
es_out_id_t *input_EsOutGetFromID( es_out_t *, int i_id );
void input_EsOutDiscontinuity( es_out_t *, vlc_bool_t b_flush, vlc_bool_t b_audio );
void input_EsOutSetDelay( es_out_t *, int i_cat, int64_t );
-void input_EsOutSetRate( es_out_t * );
+void input_EsOutChangeRate( es_out_t * );
+void input_EsOutChangeState( es_out_t * );
vlc_bool_t input_EsOutDecodersEmpty( es_out_t * );
/* clock.c */