X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fvlc_es_out.h;h=cf1abcec08467eb495ad62474e055c1500f358b6;hb=21dfee9de8ebccda05a8c8d41182df41e505db20;hp=043e5579d86e61b3c9be1eae090cd894f4b0cc0c;hpb=ab35d8541425309b1892aeacec7853a21b0c487d;p=vlc diff --git a/include/vlc_es_out.h b/include/vlc_es_out.h index 043e5579d8..cf1abcec08 100644 --- a/include/vlc_es_out.h +++ b/include/vlc_es_out.h @@ -1,24 +1,24 @@ /***************************************************************************** * vlc_es_out.h: es_out (demuxer output) descriptor, queries and methods ***************************************************************************** - * Copyright (C) 1999-2004 the VideoLAN team + * Copyright (C) 1999-2004 VLC authors and VideoLAN * $Id$ * * Authors: Laurent Aimar * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ #ifndef VLC_ES_OUT_H @@ -34,14 +34,6 @@ * @{ */ -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 */ -}; - enum es_out_query_e { /* set ES selected for the es category (audio/video/spu) */ @@ -73,10 +65,10 @@ enum es_out_query_e /* Allow preroll of data (data with dts/pts < i_pts for all ES will be decoded but not displayed */ ES_OUT_SET_NEXT_DISPLAY_TIME, /* arg1=int64_t i_pts(microsecond) */ - /* Set meta data for group (dynamic) */ - ES_OUT_SET_GROUP_META, /* arg1=int i_group arg2=vlc_meta_t */ - /* Set epg for group (dynamic) */ - ES_OUT_SET_GROUP_EPG, /* arg1=int i_group arg2=vlc_epg_t */ + /* Set meta data for group (dynamic) (The vlc_meta_t is not modified nor released) */ + ES_OUT_SET_GROUP_META, /* arg1=int i_group arg2=const vlc_meta_t */ + /* Set epg for group (dynamic) (The vlc_epg_t is not modified nor released) */ + ES_OUT_SET_GROUP_EPG, /* arg1=int i_group arg2=const vlc_epg_t */ /* */ ES_OUT_DEL_GROUP, /* arg1=int i_group */ @@ -90,6 +82,13 @@ enum es_out_query_e * XXX You SHALL call ES_OUT_RESET_PCR before any other es_out_Control/Send calls. */ ES_OUT_GET_EMPTY, /* arg1=bool* res=cannot fail */ + /* Set global meta data (The vlc_meta_t is not modified nor released) */ + ES_OUT_SET_META, /* arg1=const vlc_meta_t * */ + + /* PCR system clock manipulation for external clock synchronization */ + ES_OUT_GET_PCR_SYSTEM, /* arg1=mtime_t *, arg2=mtime_t * res=can fail */ + ES_OUT_MODIFY_PCR_SYSTEM, /* arg1=int is_absolute, arg2=mtime_t, res=can fail */ + /* First value usable for private control */ ES_OUT_PRIVATE_START = 0x10000, }; @@ -102,12 +101,10 @@ struct es_out_t int (*pf_control)( es_out_t *, int i_query, va_list ); void (*pf_destroy)( es_out_t * ); - bool b_sout; - es_out_sys_t *p_sys; }; -LIBVLC_USED +VLC_USED static inline es_out_id_t * es_out_Add( es_out_t *out, const es_format_t *fmt ) { return out->pf_add( out, fmt ); @@ -145,6 +142,20 @@ static inline void es_out_Delete( es_out_t *p_out ) p_out->pf_destroy( p_out ); } +static inline int es_out_ControlSetMeta( es_out_t *out, const vlc_meta_t *p_meta ) +{ + return es_out_Control( out, ES_OUT_SET_META, p_meta ); +} + +static inline int es_out_ControlGetPcrSystem( es_out_t *out, mtime_t *pi_system, mtime_t *pi_delay ) +{ + return es_out_Control( out, ES_OUT_GET_PCR_SYSTEM, pi_system, pi_delay ); +} +static inline int es_out_ControlModifyPcrSystem( es_out_t *out, bool b_absolute, mtime_t i_system ) +{ + return es_out_Control( out, ES_OUT_MODIFY_PCR_SYSTEM, b_absolute, i_system ); +} + /** * @} */