X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fvlc_input.h;h=be2821265c6988220ae8b667f8ea47db0d95ae16;hb=552b5247eea6d1c0c93407c49ce64a39af751e43;hp=70bf2b42caee0662f072da1caeb2215b3653b6d8;hpb=9d85c35d50b34f3b7d54f12555ab268c73cb95bc;p=vlc diff --git a/include/vlc_input.h b/include/vlc_input.h index 70bf2b42ca..be2821265c 100644 --- a/include/vlc_input.h +++ b/include/vlc_input.h @@ -22,10 +22,6 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ -#if !defined( __LIBVLC__ ) - #error You are not libvlc or one of its plugins. You cannot include this file -#endif - /* __ is need because conflict with */ #ifndef _VLC__INPUT_H #define _VLC__INPUT_H 1 @@ -62,7 +58,7 @@ struct input_item_t char *psz_name; /**< text describing this item */ char *psz_uri; /**< mrl of this item */ - bool b_fixed_name; /**< Can the interface change the name ?*/ + bool b_fixed_name; /**< Can the interface change the name ?*/ int i_options; /**< Number of input options */ char **ppsz_options; /**< Array of input options */ @@ -407,7 +403,7 @@ typedef struct { char *psz_name; - bool b_menu; /* Is it a menu or a normal entry */ + bool b_menu; /* Is it a menu or a normal entry */ int64_t i_length; /* Length(microsecond) if known, else 0 */ int64_t i_size; /* Size (bytes) if known, else 0 */ @@ -471,6 +467,7 @@ static inline input_title_t *vlc_input_title_Duplicate( input_title_t *t ) return dup; } + /***************************************************************************** * Attachments *****************************************************************************/ @@ -483,6 +480,7 @@ struct input_attachment_t int i_data; void *p_data; }; + static inline input_attachment_t *vlc_input_attachment_New( const char *psz_name, const char *psz_mime, const char *psz_description, @@ -521,20 +519,26 @@ static inline void vlc_input_attachment_Delete( input_attachment_t *a ) free( a->p_data ); free( a ); } + /***************************************************************************** * input defines/constants. *****************************************************************************/ /* "state" value */ +/* NOTE: you need to update ppsz_input_state in the RC interface + * if you modify this list. */ enum input_state_e { - INIT_S, + INIT_S = 0, OPENING_S, BUFFERING_S, PLAYING_S, PAUSE_S, + STOP_S, + FORWARD_S, + BACKWARD_S, END_S, - ERROR_S + ERROR_S, }; /* "rate" default, min/max @@ -577,7 +581,7 @@ struct input_thread_t int64_t i_time; /* Current time */ /* Internal caching common to all inputs */ - int i_pts_delay; + mtime_t i_pts_delay; /* All other data is input_thread is PRIVATE. You can't access it * outside of src/input */ @@ -666,4 +670,6 @@ VLC_EXPORT( void, input_DecoderDecode,( decoder_t *, block_t * ) ); VLC_EXPORT( bool, input_AddSubtitles, ( input_thread_t *, char *, bool ) ); +VLC_EXPORT( vlc_event_manager_t *, input_get_event_manager, ( input_thread_t * ) ); + #endif