[config] Store keysym or keycode (FS#64)
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
73dee91a28
commit
6623668b6f
24
config.c
24
config.c
|
@ -165,18 +165,22 @@ set_key_info(Key *key, cfg_t *cfg)
|
||||||
warn("unknown command %s\n", cfg_getstr(cfg, "command"));
|
warn("unknown command %s\n", cfg_getstr(cfg, "command"));
|
||||||
}
|
}
|
||||||
|
|
||||||
static KeySym
|
static void
|
||||||
key_to_keysym(char *str)
|
config_key_store(Key *key, char *str)
|
||||||
{
|
{
|
||||||
KeyCode kc;
|
KeyCode kc;
|
||||||
int ikc;
|
int ikc;
|
||||||
|
|
||||||
if(a_strncmp(str, "#", 1))
|
if(!a_strlen(str))
|
||||||
return XStringToKeysym(str);
|
return;
|
||||||
|
else if(a_strncmp(str, "#", 1))
|
||||||
ikc = atoi(str + 1);
|
key->keysym = XStringToKeysym(str);
|
||||||
memcpy(&kc, &ikc, sizeof(KeyCode));
|
else
|
||||||
return XKeycodeToKeysym(globalconf.display, kc, 0);
|
{
|
||||||
|
ikc = atoi(str + 1);
|
||||||
|
memcpy(&kc, &ikc, sizeof(KeyCode));
|
||||||
|
key->keycode = kc;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static Key *
|
static Key *
|
||||||
|
@ -191,7 +195,7 @@ section_keys(cfg_t *cfg_keys)
|
||||||
key = p_new(Key, 1);
|
key = p_new(Key, 1);
|
||||||
cfgkeytmp = cfg_getnsec(cfg_keys, "key", i);
|
cfgkeytmp = cfg_getnsec(cfg_keys, "key", i);
|
||||||
set_key_info(key, cfgkeytmp);
|
set_key_info(key, cfgkeytmp);
|
||||||
key->keysym = key_to_keysym(cfg_getstr(cfgkeytmp, "key"));
|
config_key_store(key, cfg_getstr(cfgkeytmp, "key"));
|
||||||
key->arg = a_strdup(cfg_getstr(cfgkeytmp, "arg"));
|
key->arg = a_strdup(cfg_getstr(cfgkeytmp, "arg"));
|
||||||
key_list_push(&head, key);
|
key_list_push(&head, key);
|
||||||
}
|
}
|
||||||
|
@ -210,7 +214,7 @@ section_keys(cfg_t *cfg_keys)
|
||||||
{
|
{
|
||||||
key = p_new(Key, 1);
|
key = p_new(Key, 1);
|
||||||
set_key_info(key, cfgkeytmp);
|
set_key_info(key, cfgkeytmp);
|
||||||
key->keysym = key_to_keysym(cfg_getnstr(cfgkeytmp, "keylist", j));
|
config_key_store(key, cfg_getnstr(cfgkeytmp, "keylist", j));
|
||||||
key->arg = a_strdup(cfg_getnstr(cfgkeytmp, "arglist", j));
|
key->arg = a_strdup(cfg_getnstr(cfgkeytmp, "arglist", j));
|
||||||
key_list_push(&head, key);
|
key_list_push(&head, key);
|
||||||
}
|
}
|
||||||
|
|
2
event.c
2
event.c
|
@ -353,7 +353,7 @@ event_handle_keypress(XEvent *e)
|
||||||
keysym = XKeycodeToKeysym(globalconf.display, (KeyCode) ev->keycode, 0);
|
keysym = XKeycodeToKeysym(globalconf.display, (KeyCode) ev->keycode, 0);
|
||||||
|
|
||||||
for(k = globalconf.keys; k; k = k->next)
|
for(k = globalconf.keys; k; k = k->next)
|
||||||
if(keysym == k->keysym &&
|
if((ev->keycode == k->keycode || keysym == k->keysym) &&
|
||||||
k->func && CLEANMASK(k->mod) == CLEANMASK(ev->state))
|
k->func && CLEANMASK(k->mod) == CLEANMASK(ev->state))
|
||||||
k->func(screen, k->arg);
|
k->func(screen, k->arg);
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,6 +81,7 @@ struct Key
|
||||||
{
|
{
|
||||||
unsigned long mod;
|
unsigned long mod;
|
||||||
KeySym keysym;
|
KeySym keysym;
|
||||||
|
KeyCode keycode;
|
||||||
Uicb *func;
|
Uicb *func;
|
||||||
char *arg;
|
char *arg;
|
||||||
/** Next and previous keys */
|
/** Next and previous keys */
|
||||||
|
|
2
window.c
2
window.c
|
@ -162,7 +162,7 @@ window_root_grabkeys(int phys_screen)
|
||||||
XUngrabKey(globalconf.display, AnyKey, AnyModifier, RootWindow(globalconf.display, phys_screen));
|
XUngrabKey(globalconf.display, AnyKey, AnyModifier, RootWindow(globalconf.display, phys_screen));
|
||||||
|
|
||||||
for(k = globalconf.keys; k; k = k->next)
|
for(k = globalconf.keys; k; k = k->next)
|
||||||
if(k->keysym && (kc = XKeysymToKeycode(globalconf.display, k->keysym)))
|
if((kc = k->keycode) || (k->keysym && (kc = XKeysymToKeycode(globalconf.display, k->keysym))))
|
||||||
{
|
{
|
||||||
XGrabKey(globalconf.display, kc, k->mod,
|
XGrabKey(globalconf.display, kc, k->mod,
|
||||||
RootWindow(globalconf.display, phys_screen), True, GrabModeAsync, GrabModeAsync);
|
RootWindow(globalconf.display, phys_screen), True, GrabModeAsync, GrabModeAsync);
|
||||||
|
|
Loading…
Reference in New Issue