X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fvlc_stream.h;h=96a2f0e5f7f0da092216976f15a408ae725856ef;hb=1e7fcc5da42aaa9728343d73934d7020bc87bf2b;hp=4e4864cb9412c127401f08d6657b088a05db26ea;hpb=02dc7efea86a69bfe03ba96a0bbba85a0a615e29;p=vlc diff --git a/include/vlc_stream.h b/include/vlc_stream.h index 4e4864cb94..96a2f0e5f7 100644 --- a/include/vlc_stream.h +++ b/include/vlc_stream.h @@ -53,17 +53,21 @@ struct stream_t { VLC_COMMON_MEMBERS - /* Module properties */ + /* Module properties for stream filter */ module_t *p_module; - /* For stream filter they will hold an array of stream sources */ - int i_source; - stream_t **pp_source; + /* Real or virtual path (it can only be changed during stream_t opening) */ + char *psz_path; + + /* Stream source for stream filter */ + stream_t *p_source; /* */ int (*pf_read) ( stream_t *, void *p_read, unsigned int i_read ); int (*pf_peek) ( stream_t *, const uint8_t **pp_peek, unsigned int i_peek ); int (*pf_control)( stream_t *, int i_query, va_list ); + + /* */ void (*pf_destroy)( stream_t *); /* Private data for module */ @@ -71,6 +75,9 @@ struct stream_t /* Text reader state */ stream_text_t *p_text; + + /* Weak link to parent input */ + input_thread_t *p_input; }; /** @@ -88,17 +95,19 @@ enum stream_query_e STREAM_GET_SIZE, /**< arg1= int64_t * res=cannot fail (0 if no sense)*/ - STREAM_GET_MTU, /**< arg1= int * res=cannot fail (0 if no sense)*/ - /* Special for direct access control from demuxer. * XXX: avoid using it by all means */ STREAM_CONTROL_ACCESS, /* arg1= int i_access_query, args res: can fail if access unreachable or access control answer */ + /* You should update size of source if any and then update size + * FIXME find a way to avoid it */ + STREAM_UPDATE_SIZE, + + /* */ STREAM_GET_CONTENT_TYPE, /**< arg1= char ** res=can fail */ - /* SET_RECORD: - * XXX only data read through stream_Read/Block will be recorded */ + /* XXX only data read through stream_Read/Block will be recorded */ STREAM_SET_RECORD_STATE, /**< arg1=bool, arg2=const char *psz_ext (if arg1 is true) res=can fail */ }; @@ -130,13 +139,6 @@ static inline int64_t stream_Size( stream_t *s ) return i_pos; } -static inline int stream_MTU( stream_t *s ) -{ - int i_mtu; - stream_Control( s, STREAM_GET_MTU, &i_mtu ); - return i_mtu; -} - static inline int stream_Seek( stream_t *s, int64_t i_pos ) { return stream_Control( s, STREAM_SET_POSITION, i_pos ); @@ -158,8 +160,8 @@ static inline char *stream_ContentType( stream_t *s ) * Create a special stream and a demuxer, this allows chaining demuxers * You must delete it using stream_Delete. */ -#define stream_DemuxNew( a, b, c ) __stream_DemuxNew( VLC_OBJECT(a), b, c) -VLC_EXPORT( stream_t *,__stream_DemuxNew, ( vlc_object_t *p_obj, const char *psz_demux, es_out_t *out ) ); +VLC_EXPORT( stream_t *, stream_DemuxNew, ( demux_t *p_demux, const char *psz_demux, es_out_t *out ) ); + /** * Send data to a stream_t handle created by stream_DemuxNew. */