X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=common%2Finput.h;h=390f41106bee8baa9829d34dd35b71bf80c3fa54;hb=8e77275edade55d89b0723a60ab4ef1e2ec288de;hp=9bc28c90aac3c253895bef564e245fae06da2704;hpb=ee0f881e9f135db6ed9337b99f611b3cae955f8c;p=libpicofe.git diff --git a/common/input.h b/common/input.h index 9bc28c9..390f411 100644 --- a/common/input.h +++ b/common/input.h @@ -58,13 +58,23 @@ enum { IN_INFO_DOES_COMBOS, }; +enum { + IN_BINDTYPE_NONE = -1, + IN_BINDTYPE_EMU = 0, + IN_BINDTYPE_PLAYER12, + IN_BINDTYPE_COUNT +}; + +#define IN_BIND_OFFS(key, btype) \ + ((key) * IN_BINDTYPE_COUNT + (btype)) + typedef struct { const char *prefix; void (*probe)(void); void (*free)(void *drv_data); int (*get_bind_count)(void); void (*get_def_binds)(int *binds); - int (*clean_binds)(void *drv_data, int *binds); + int (*clean_binds)(void *drv_data, int *binds, int *def_finds); void (*set_blocking)(void *data, int y); int (*update_keycode)(void *drv_data, int *is_down); int (*menu_translate)(int keycode); @@ -74,13 +84,14 @@ typedef struct { /* to be called by drivers */ -void in_register(const char *nname, int drv_id, int fd_hnd, void *drv_data, int combos); -void in_combos_find(int *binds, int last_key, int *combo_keys, int *combo_acts); -int in_combos_do(int keys, int *binds, int last_key, int combo_keys, int combo_acts); +void in_register(const char *nname, int drv_id, int drv_fd_hnd, void *drv_data, + int key_count, int combos); +void in_combos_find(const int *binds, int last_key, int *combo_keys, int *combo_acts); +int in_combos_do(int keys, const int *binds, int last_key, int combo_keys, int combo_acts); void in_init(void); void in_probe(void); -int in_update(void); +int in_update(int *result); void in_set_blocking(int is_blocking); int in_update_keycode(int *dev_id, int *is_down, int timeout_ms); int in_menu_wait_any(int timeout_ms); @@ -88,9 +99,9 @@ int in_menu_wait(int interesting, int autorep_delay_ms); int in_get_dev_info(int dev_id, int what); void in_config_start(void); int in_config_parse_dev(const char *dev_name); -int in_config_bind_key(int dev_id, const char *key, int mask); +int in_config_bind_key(int dev_id, const char *key, int binds, int bind_type); void in_config_end(void); -int in_bind_key(int dev_id, int keycode, int mask, int force_unbind); +int in_bind_key(int dev_id, int keycode, int bind_type, int mask, int force_unbind); void in_debug_dump(void); const int *in_get_dev_binds(int dev_id);