allow the use of keycodes directly in key bindings

This commit is contained in:
Dana Jansens 2003-09-17 02:37:52 +00:00
parent b288fdee41
commit dbd3e9b6b2

View file

@ -89,13 +89,24 @@ gboolean translate_key(char *str, guint *state, guint *keycode)
*state |= m;
}
/* figure out the keycode */
sym = XStringToKeysym(l);
if (sym == NoSymbol) {
g_warning("Invalid key name '%s' in key binding.", l);
goto translation_fail;
if (!g_ascii_strncasecmp("0x", l, 2)) {
gchar *end;
/* take it directly */
*keycode = strtol(l, &end, 16);
if (*l == '\0' || *end != '\0') {
g_warning("Invalid key code '%s' in key binding.", l);
goto translation_fail;
}
} else {
/* figure out the keycode */
sym = XStringToKeysym(l);
if (sym == NoSymbol) {
g_warning("Invalid key name '%s' in key binding.", l);
goto translation_fail;
}
*keycode = XKeysymToKeycode(ob_display, sym);
}
*keycode = XKeysymToKeycode(ob_display, sym);
if (!*keycode) {
g_warning("Key '%s' does not exist on the display.", l);
goto translation_fail;