#include <vlc_common.h>
+enum es_out_mode_e
+{
+ ES_OUT_MODE_NONE, /* don't select anything */
+ ES_OUT_MODE_ALL, /* eg for stream output */
+ ES_OUT_MODE_AUTO, /* best audio/video or for input follow audio-track, sub-track */
+ ES_OUT_MODE_PARTIAL,/* select programs given after --programs */
+ ES_OUT_MODE_END /* mark the es_out as dead */
+};
+
enum es_out_query_private_e
{
+ /* set/get mode */
+ ES_OUT_SET_MODE = ES_OUT_PRIVATE_START, /* arg1= int */
+
/* Get date to wait before demuxing more data */
- ES_OUT_GET_WAKE_UP = ES_OUT_PRIVATE_START, /* arg1=mtime_t* res=cannot fail */
+ ES_OUT_GET_WAKE_UP, /* arg1=mtime_t* res=cannot fail */
/* Wrapper for some ES command to work with id */
ES_OUT_SET_ES_BY_ID,
ES_OUT_RESTART_ES_BY_ID,
ES_OUT_SET_ES_DEFAULT_BY_ID,
+ ES_OUT_GET_ES_OBJECTS_BY_ID, /* arg1=int id, vlc_object_t **dec, vout_thread_t **, aout_instance_t ** res=can fail*/
/* Get buffering state */
ES_OUT_GET_BUFFERING, /* arg1=bool* res=cannot fail */
- /* Check if es_out has still data to play */
- ES_OUT_GET_EMPTY, /* arg1=bool* res=cannot fail */
-
/* Set delay for a ES category */
- ES_OUT_SET_DELAY, /* arg1=es_category_e, res=can fail */
+ ES_OUT_SET_DELAY, /* arg1=es_category_e, res=cannot fail */
/* Set record state */
ES_OUT_SET_RECORD_STATE, /* arg1=bool res=can fail */
/* Set next frame */
ES_OUT_SET_FRAME_NEXT, /* res=can fail */
- /* Lock/Unlock es_out
- * XXX es_out is safe without them, but they ensure coherency between
- * calls if needed (if es_out is called outside of the main thread) */
- ES_OUT_LOCK, /* res=cannot fail */
- ES_OUT_UNLOCK, /* res=cannot fail */
+ /* Set position/time/length */
+ ES_OUT_SET_TIMES, /* arg1=double f_position arg2=mtime_t i_time arg3=mtime_t i_length res=cannot fail */
+
+ /* Set jitter */
+ ES_OUT_SET_JITTER, /* arg1=mtime_t i_pts_delay arg2= mtime_t i_pts_jitter, arg2=int i_cr_average res=cannot fail */
+
+ /* Get forced group */
+ ES_OUT_GET_GROUP_FORCED, /* arg1=int * res=cannot fail */
};
+static inline void es_out_SetMode( es_out_t *p_out, int i_mode )
+{
+ int i_ret = es_out_Control( p_out, ES_OUT_SET_MODE, i_mode );
+ assert( !i_ret );
+}
static inline mtime_t es_out_GetWakeup( es_out_t *p_out )
{
mtime_t i_wu;
assert( !i_ret );
return b;
}
-static inline int es_out_SetDelay( es_out_t *p_out, int i_cat, mtime_t i_delay )
+static inline void es_out_SetDelay( es_out_t *p_out, int i_cat, mtime_t i_delay )
{
- return es_out_Control( p_out, ES_OUT_SET_DELAY, i_cat, i_delay );
+ int i_ret = es_out_Control( p_out, ES_OUT_SET_DELAY, i_cat, i_delay );
+ assert( !i_ret );
}
static inline int es_out_SetRecordState( es_out_t *p_out, bool b_record )
{
{
return es_out_Control( p_out, ES_OUT_SET_FRAME_NEXT );
}
-static inline void es_out_Lock( es_out_t *p_out )
+static inline void es_out_SetTimes( es_out_t *p_out, double f_position, mtime_t i_time, mtime_t i_length )
+{
+ int i_ret = es_out_Control( p_out, ES_OUT_SET_TIMES, f_position, i_time, i_length );
+ assert( !i_ret );
+}
+static inline void es_out_SetJitter( es_out_t *p_out,
+ mtime_t i_pts_delay, mtime_t i_pts_jitter, int i_cr_average )
{
- int i_ret = es_out_Control( p_out, ES_OUT_LOCK );
+ int i_ret = es_out_Control( p_out, ES_OUT_SET_JITTER,
+ i_pts_delay, i_pts_jitter, i_cr_average );
assert( !i_ret );
}
-static inline void es_out_Unlock( es_out_t *p_out )
+static inline int es_out_GetEsObjects( es_out_t *p_out, int i_id,
+ vlc_object_t **pp_decoder, vout_thread_t **pp_vout, aout_instance_t **pp_aout )
+{
+ return es_out_Control( p_out, ES_OUT_GET_ES_OBJECTS_BY_ID, i_id, pp_decoder, pp_vout, pp_aout );
+}
+static inline int es_out_GetGroupForced( es_out_t *p_out )
{
- int i_ret = es_out_Control( p_out, ES_OUT_UNLOCK );
+ int i_group;
+ int i_ret = es_out_Control( p_out, ES_OUT_GET_GROUP_FORCED, &i_group );
assert( !i_ret );
+ return i_group;
}
es_out_t *input_EsOutNew( input_thread_t *, int i_rate );