aboutsummaryrefslogtreecommitdiff
path: root/frontend/linux
diff options
context:
space:
mode:
authornotaz2012-07-22 19:40:11 +0300
committernotaz2012-07-22 19:40:11 +0300
commit61f97bb0518cde50b243fba8ce2e8a907a0fc2e9 (patch)
tree0bd9bcfb9ca68197922ee5d12f250fb43638cd17 /frontend/linux
parent5905989e5215a4e29e6be27216ea46f288ed16a5 (diff)
downloadpcsx_rearmed-61f97bb0518cde50b243fba8ce2e8a907a0fc2e9.tar.gz
pcsx_rearmed-61f97bb0518cde50b243fba8ce2e8a907a0fc2e9.tar.bz2
pcsx_rearmed-61f97bb0518cde50b243fba8ce2e8a907a0fc2e9.zip
frontend: support seeking the filelist with letter keys
Diffstat (limited to 'frontend/linux')
-rw-r--r--frontend/linux/in_evdev.c24
1 files changed, 19 insertions, 5 deletions
diff --git a/frontend/linux/in_evdev.c b/frontend/linux/in_evdev.c
index c615061..b447da1 100644
--- a/frontend/linux/in_evdev.c
+++ b/frontend/linux/in_evdev.c
@@ -559,9 +559,10 @@ static const struct {
#define KEY_PBTN_MAP_SIZE (sizeof(key_pbtn_map) / sizeof(key_pbtn_map[0]))
-static int in_evdev_menu_translate(void *drv_data, int keycode)
+static int in_evdev_menu_translate(void *drv_data, int keycode, char *charcode)
{
in_evdev_t *dev = drv_data;
+ int ret = 0;
int i;
if (keycode < 0)
@@ -578,12 +579,25 @@ static int in_evdev_menu_translate(void *drv_data, int keycode)
}
else
{
- for (i = 0; i < KEY_PBTN_MAP_SIZE; i++)
- if (key_pbtn_map[i].key == keycode)
- return key_pbtn_map[i].pbtn;
+ for (i = 0; i < KEY_PBTN_MAP_SIZE; i++) {
+ if (key_pbtn_map[i].key == keycode) {
+ ret = key_pbtn_map[i].pbtn;
+ break;
+ }
+ }
+
+ if (charcode != NULL && (unsigned int)keycode < KEY_CNT &&
+ in_evdev_keys[keycode] != NULL && in_evdev_keys[keycode][1] == 0)
+ {
+ char c = in_evdev_keys[keycode][0];
+ if ('A' <= c && c <= 'Z')
+ c = 'a' + c - 'A';
+ ret |= PBTN_CHAR;
+ *charcode = c;
+ }
}
- return 0;
+ return ret;
}
/* remove binds of missing keys, count remaining ones */