unified menu wip and some reorganization for it
[libpicofe.git] / common / input.h
CommitLineData
da767bd5 1#define IN_MAX_DEVS 10
2
34581c95 3enum {
da767bd5 4 IN_DRVID_UNKNOWN = 0,
7f022a8d 5 IN_DRVID_GP2X,
13b692eb 6 IN_DRVID_EVDEV,
da767bd5 7 IN_DRVID_COUNT
34581c95 8};
2258f158 9
da767bd5 10typedef struct {
11 const char *prefix;
12 void (*probe)(void);
13 void (*free)(void *drv_data);
14 int (*get_bind_count)(void);
15 void (*get_def_binds)(int *binds);
16 int (*clean_binds)(void *drv_data, int *binds);
17 void (*set_blocking)(void *data, int y);
7f022a8d 18 int (*update_keycode)(void *drv_data, int *is_down);
da767bd5 19 int (*menu_translate)(int keycode);
20 int (*get_key_code)(const char *key_name);
21 const char * (*get_key_name)(int keycode);
22} in_drv_t;
23
24
2258f158 25/* to be called by drivers */
7f022a8d 26void in_register(const char *nname, int drv_id, int fd_hnd, void *drv_data);
2258f158 27
28void in_init(void);
29void in_probe(void);
30int in_update(void);
595491c4 31void in_set_blocking(int is_blocking);
906bdc9f 32int in_update_keycode(int *dev_id, int *is_down, int timeout_ms);
fce20e73 33int in_menu_wait_any(int timeout_ms);
34int in_menu_wait(int interesting);
da767bd5 35int in_get_dev_bind_count(int dev_id);
36void in_config_start(void);
37int in_config_parse_dev(const char *dev_name);
38int in_config_bind_key(int dev_id, const char *key, int mask);
39void in_config_end(void);
906bdc9f 40int in_bind_key(int dev_id, int keycode, int mask, int force_unbind);
da767bd5 41void in_debug_dump(void);
42
43const int *in_get_dev_binds(int dev_id);
44const int *in_get_dev_def_binds(int dev_id);
fce20e73 45const char *in_get_dev_name(int dev_id, int must_be_active);
595491c4 46const char *in_get_key_name(int dev_id, int keycode);