2 * This file is part of MPlayer.
4 * MPlayer is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * MPlayer is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License along
15 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
19 #ifndef MPLAYER_INPUT_H
20 #define MPLAYER_INPUT_H
30 MP_CMD_GRAB_FRAMES
, // deprecated: was a no-op command for years
31 MP_CMD_PLAY_TREE_STEP
,
32 MP_CMD_PLAY_TREE_UP_STEP
,
33 MP_CMD_PLAY_ALT_SRC_STEP
,
37 MP_CMD_MIXER_USEMASTER
,
43 MP_CMD_TV_STEP_CHANNEL
,
45 MP_CMD_TV_STEP_CHANNEL_LIST
,
54 MP_CMD_VF_CHANGE_RECTANGLE
,
56 MP_CMD_SUB_VISIBILITY
,
57 MP_CMD_VOBSUB_LANG
, // deprecated: combined with SUB_SELECT
60 MP_CMD_GET_TIME_LENGTH
,
61 MP_CMD_GET_PERCENT_POS
,
63 MP_CMD_TV_SET_CHANNEL
,
66 MP_CMD_TV_LAST_CHANNEL
,
70 MP_CMD_TV_SET_BRIGHTNESS
,
71 MP_CMD_TV_SET_CONTRAST
,
73 MP_CMD_TV_SET_SATURATION
,
74 MP_CMD_GET_VO_FULLSCREEN
,
75 MP_CMD_GET_SUB_VISIBILITY
,
76 MP_CMD_SUB_FORCED_ONLY
,
92 MP_CMD_KEYDOWN_EVENTS
,
96 MP_CMD_OSD_SHOW_PROPERTY_TEXT
,
97 MP_CMD_OSD_SHOW_PROGRESSION
,
101 MP_CMD_GET_VIDEO_CODEC
,
102 MP_CMD_GET_VIDEO_BITRATE
,
103 MP_CMD_GET_VIDEO_RESOLUTION
,
104 MP_CMD_GET_AUDIO_CODEC
,
105 MP_CMD_GET_AUDIO_BITRATE
,
106 MP_CMD_GET_AUDIO_SAMPLES
,
107 MP_CMD_GET_META_TITLE
,
108 MP_CMD_GET_META_ARTIST
,
109 MP_CMD_GET_META_ALBUM
,
110 MP_CMD_GET_META_YEAR
,
111 MP_CMD_GET_META_COMMENT
,
112 MP_CMD_GET_META_TRACK
,
113 MP_CMD_GET_META_GENRE
,
114 MP_CMD_RADIO_STEP_CHANNEL
,
115 MP_CMD_RADIO_SET_CHANNEL
,
116 MP_CMD_RADIO_SET_FREQ
,
117 MP_CMD_SET_MOUSE_POS
,
118 MP_CMD_STEP_PROPERTY
,
119 MP_CMD_RADIO_STEP_FREQ
,
124 MP_CMD_TV_TELETEXT_ADD_DEC
,
125 MP_CMD_TV_TELETEXT_GO_LINK
,
126 MP_CMD_TV_START_SCAN
,
132 MP_CMD_ASS_USE_MARGINS
,
137 MP_CMD_DVDNAV_UP
= 1000,
142 MP_CMD_DVDNAV_SELECT
,
143 MP_CMD_DVDNAV_PREVMENU
,
144 MP_CMD_DVDNAV_MOUSECLICK
,
147 MP_CMD_GUI_EVENTS
= 5000,
149 MP_CMD_GUI_LOADSUBTITLE
,
154 MP_CMD_GUI_PREFERENCES
,
155 MP_CMD_GUI_FULLSCREEN
,
156 MP_CMD_GUI_SKINBROWSER
,
159 MP_CMD_DVB_SET_CHANNEL
= 5101,
166 /// Audio Filter commands
175 #define MP_CMD_ARG_INT 0
176 #define MP_CMD_ARG_FLOAT 1
177 #define MP_CMD_ARG_STRING 2
178 #define MP_CMD_ARG_VOID 3
180 #ifndef MP_CMD_MAX_ARGS
181 #define MP_CMD_MAX_ARGS 10
184 // Error codes for the drivers
186 // An error occurred but we can continue
187 #define MP_INPUT_ERROR -1
188 // A fatal error occurred, this driver should be removed
189 #define MP_INPUT_DEAD -2
190 // No input was available
191 #define MP_INPUT_NOTHING -3
192 //! Input will be available if you try again
193 #define MP_INPUT_RETRY -4
195 // For the key's drivers, if possible you can send key up and key down
196 // events. Key up is the default, to send a key down you must use the
197 // OR operator between the key code and MP_KEY_DOWN.
198 #define MP_KEY_DOWN (1<<29)
199 // Use this when the key shouldn't be auto-repeated (like mouse buttons)
200 #define MP_NO_REPEAT_KEY (1<<28)
202 #ifndef MP_MAX_KEY_DOWN
203 #define MP_MAX_KEY_DOWN 32
206 typedef union mp_cmd_arg_value
{
211 } mp_cmd_arg_value_t
;
213 typedef struct mp_cmd_arg
{
215 mp_cmd_arg_value_t v
;
218 typedef struct mp_cmd
{
222 mp_cmd_arg_t args
[MP_CMD_MAX_ARGS
];
227 typedef struct mp_cmd_bind
{
228 int input
[MP_MAX_KEY_DOWN
+1];
232 typedef struct mp_key_name
{
237 // These typedefs are for the drivers. They are the functions used to retrieve
238 // the next key code or command.
240 // These functions should return the key code or one of the error codes
241 typedef int (*mp_key_func_t
)(int fd
);
242 // These functions should act like read but they must use our error code (if needed ;-)
243 typedef int (*mp_cmd_func_t
)(int fd
,char* dest
,int size
);
244 // These are used to close the driver
245 typedef void (*mp_close_func_t
)(int fd
);
247 // Set this to grab all incoming key codes
248 extern int (*mp_input_key_cb
)(int code
);
249 // Should return 1 if the command was processed
250 typedef int (*mp_input_cmd_filter
)(mp_cmd_t
* cmd
, int paused
, void* ctx
);
252 // This function adds a new key driver.
253 // The first arg is a file descriptor (use a negative value if you don't use any fd)
254 // The second arg tells if we use select on the fd to know if something is available.
255 // The third arg is optional. If null a default function wich reads an int from the
257 // The last arg can be NULL if nothing is needed to close the driver. The close
258 // function can be used
260 mp_input_add_cmd_fd(int fd
, int select
, mp_cmd_func_t read_func
, mp_close_func_t close_func
);
262 // This removes a cmd driver, you usually don't need to use it.
264 mp_input_rm_cmd_fd(int fd
);
266 // The args are the same as for the key's drivers. If you don't use any valid fd you MUST
269 mp_input_add_key_fd(int fd
, int select
, mp_key_func_t read_func
, mp_close_func_t close_func
);
271 // As for the cmd one you usually don't need this function.
273 mp_input_rm_key_fd(int fd
);
275 int mp_input_add_event_fd(int fd
, void (*read_func
)(void));
277 void mp_input_rm_event_fd(int fd
);
279 /// Get input key from its name.
280 int mp_input_get_key_from_name(const char *name
);
282 // This function can be used to put a command in the system again. It's used by libmpdemux
283 // when it performs a blocking operation to resend the command it received to the main
286 mp_input_queue_cmd(mp_cmd_t
* cmd
);
288 // This function retrieves the next available command waiting no more than time msec.
289 // If pause is true, the next input will always return a pause command.
291 mp_input_get_cmd(int time
, int paused
, int peek_only
);
294 mp_input_parse_cmd(char* str
);
297 * Parse and queue commands separated by '\n'.
298 * @return count of commands new queued.
300 int mp_input_parse_and_queue_cmds(const char *str
);
302 /// These filters allow you to process the command before MPlayer.
303 /// If a filter returns a true value mp_input_get_cmd will return NULL.
305 mp_input_add_cmd_filter(mp_input_cmd_filter
, void* ctx
);
307 // After getting a command from mp_input_get_cmd you need to free it using this
310 mp_cmd_free(mp_cmd_t
* cmd
);
312 // This creates a copy of a command (used by the auto repeat stuff).
314 mp_cmd_clone(mp_cmd_t
* cmd
);
316 // Set current input section
318 mp_input_set_section(char *name
);
320 // Get current input section
322 mp_input_get_section(void);
324 // When you create a new driver you should add it in these 2 functions.
326 mp_input_init(int use_gui
);
329 mp_input_uninit(void);
331 void mp_input_register_options(m_config_t
* cfg
);
333 // Interruptible usleep: (used by libmpdemux)
335 mp_input_check_interrupt(int time
);
337 extern int async_quit_request
;
339 #endif /* MPLAYER_INPUT_H */