X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ftranslate.c;h=97066519f4b9f0cf73e53826e77a59e398cf5777;hb=c8983c42a7c27321d18825f2a130c15e29046f7b;hp=9b4c1406e9af9ebb966e4ee798ce25153fb1faf9;hpb=c90da6da781932c2d178bfb7e39ec1d5003543b7;p=chaz%2Fopenbox diff --git a/openbox/translate.c b/openbox/translate.c index 9b4c1406..97066519 100644 --- a/openbox/translate.c +++ b/openbox/translate.c @@ -1,15 +1,36 @@ -#include "kernel/openbox.h" +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- + + translate.c for the Openbox window manager + Copyright (c) 2006 Mikael Magnusson + Copyright (c) 2003-2007 Dana Jansens + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + See the COPYING file for a copy of the GNU General Public License. +*/ + +#include "openbox.h" #include "mouse.h" +#include "gettext.h" #include #include #include -static guint translate_modifier(char *str) +static guint translate_modifier(gchar *str) { if (!g_ascii_strcasecmp("Mod1", str) || !g_ascii_strcasecmp("A", str)) return Mod1Mask; else if (!g_ascii_strcasecmp("Mod2", str)) return Mod2Mask; - else if (!g_ascii_strcasecmp("Mod3", str)) return Mod3Mask; + else if (!g_ascii_strcasecmp("Mod3", str) || + !g_ascii_strcasecmp("M", str)) return Mod3Mask; else if (!g_ascii_strcasecmp("Mod4", str) || !g_ascii_strcasecmp("W", str)) return Mod4Mask; else if (!g_ascii_strcasecmp("Mod5", str)) return Mod5Mask; @@ -17,15 +38,15 @@ static guint translate_modifier(char *str) !g_ascii_strcasecmp("C", str)) return ControlMask; else if (!g_ascii_strcasecmp("Shift", str) || !g_ascii_strcasecmp("S", str)) return ShiftMask; - g_warning("Invalid modifier '%s' in binding.", str); + g_message(_("Invalid modifier key '%s' in key/pointer binding"), str); return 0; } -gboolean translate_button(char *str, guint *state, guint *button) +gboolean translate_button(const gchar *str, guint *state, guint *button) { - char **parsed; - char *l; - int i; + gchar **parsed; + gchar *l; + gint i; gboolean ret = FALSE; parsed = g_strsplit(str, "-", -1); @@ -33,16 +54,16 @@ gboolean translate_button(char *str, guint *state, guint *button) /* first, find the button (last token) */ l = NULL; for (i = 0; parsed[i] != NULL; ++i) - l = parsed[i]; + l = parsed[i]; if (l == NULL) - goto translation_fail; + goto translation_fail; /* figure out the mod mask */ *state = 0; for (i = 0; parsed[i] != l; ++i) { - guint m = translate_modifier(parsed[i]); - if (!m) goto translation_fail; - *state |= m; + guint m = translate_modifier(parsed[i]); + if (!m) goto translation_fail; + *state |= m; } /* figure out the button */ @@ -53,8 +74,8 @@ gboolean translate_button(char *str, guint *state, guint *button) else if (!g_ascii_strcasecmp("Down", l)) *button = 5; else if (!g_ascii_strncasecmp("Button", l, 6)) *button = atoi(l+6); if (!*button) { - g_warning("Invalid button '%s' in pointer binding.", l); - goto translation_fail; + g_message(_("Invalid button '%s' in pointer binding"), l); + goto translation_fail; } ret = TRUE; @@ -64,11 +85,11 @@ translation_fail: return ret; } -gboolean translate_key(char *str, guint *state, guint *keycode) +gboolean translate_key(const gchar *str, guint *state, guint *keycode) { - char **parsed; - char *l; - int i; + gchar **parsed; + gchar *l; + gint i; gboolean ret = FALSE; KeySym sym; @@ -77,28 +98,39 @@ gboolean translate_key(char *str, guint *state, guint *keycode) /* first, find the key (last token) */ l = NULL; for (i = 0; parsed[i] != NULL; ++i) - l = parsed[i]; + l = parsed[i]; if (l == NULL) - goto translation_fail; + goto translation_fail; /* figure out the mod mask */ *state = 0; for (i = 0; parsed[i] != l; ++i) { - guint m = translate_modifier(parsed[i]); - if (!m) goto translation_fail; - *state |= m; + guint m = translate_modifier(parsed[i]); + if (!m) goto translation_fail; + *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_message(_("Invalid key code '%s' in key binding"), l); + goto translation_fail; + } + } else { + /* figure out the keycode */ + sym = XStringToKeysym(l); + if (sym == NoSymbol) { + g_message(_("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; + g_message(_("Requested key '%s' does not exist on the display"), l); + goto translation_fail; } ret = TRUE; @@ -107,3 +139,13 @@ translation_fail: g_strfreev(parsed); return ret; } + +const gchar *translate_keycode(guint keycode) +{ + KeySym sym; + const gchar *ret = NULL; + + if ((sym = XKeycodeToKeysym(ob_display, keycode, 0)) != NoSymbol) + ret = XKeysymToString(sym); + return g_locale_to_utf8(ret, -1, NULL, NULL, NULL); +}