Commit c17456b4 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

core: allow multiple hotkeys for the same action

Hotkeys are separated by tabs. I would have allowed white spaces, but
they are found in some media key names :-(
parent 94a2b9d0
...@@ -370,6 +370,7 @@ static int vlc_key_to_action (vlc_object_t *libvlc, const char *varname, ...@@ -370,6 +370,7 @@ static int vlc_key_to_action (vlc_object_t *libvlc, const char *varname,
*/ */
struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc) struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc)
{ {
vlc_object_t *obj = VLC_OBJECT(libvlc);
struct hotkey *keys; struct hotkey *keys;
struct vlc_actions *as = malloc (sizeof (*as) + (ACTIONS_COUNT + 1) * sizeof (*keys)); struct vlc_actions *as = malloc (sizeof (*as) + (ACTIONS_COUNT + 1) * sizeof (*keys));
...@@ -397,26 +398,36 @@ struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc) ...@@ -397,26 +398,36 @@ struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc)
keys->i_action = actions[i].value; keys->i_action = actions[i].value;
keys++; keys++;
char *str = var_InheritString (libvlc, actions[i].name); char *str = var_InheritString (obj, actions[i].name);
uint32_t code = str ? vlc_str2keycode (str) : KEY_UNSET; if (str == NULL)
if (code == KEY_UNSET)
continue;
struct mapping *entry = malloc (sizeof (*entry));
if (entry == NULL)
continue; continue;
entry->key = code;
entry->action = actions[i].value;
struct mapping **pent = tsearch (entry, &as->map, keycmp); for (char *buf, *key = strtok_r (str, "\t", &buf);
if (unlikely(pent == NULL)) key != NULL;
continue; key = strtok_r (NULL, "\t", &buf))
if (*pent != entry)
{ {
free (entry); uint32_t code = vlc_str2keycode (key);
msg_Warn (libvlc, "Key code \"%s\" bound to multiple actions",
str); if (code == KEY_UNSET)
{
msg_Warn (obj, "Key \"%s\" unrecognized", key);
continue;
}
struct mapping *entry = malloc (sizeof (*entry));
if (entry == NULL)
continue;
entry->key = code;
entry->action = actions[i].value;
struct mapping **pent = tsearch (entry, &as->map, keycmp);
if (unlikely(pent == NULL))
continue;
if (*pent != entry)
{
free (entry);
msg_Warn (obj, "Key \"%s\" bound to multiple actions", key);
}
} }
free (str); free (str);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment