all repos — openbox @ 36ddd0c4086652bfb65d3b3034640e349d5c991b

openbox fork - make it a bit more like ryudo

dont use XKeysymToKeycode because valgrind says it is doing bad things, and we have all the data we need anyways
Dana Jansens danakj@orodu.net
commit

36ddd0c4086652bfb65d3b3034640e349d5c991b

parent

b8309807ab8e18686db148fc46323237b9103787

3 files changed, 31 insertions(+), 18 deletions(-)

jump to
M openbox/modkeys.copenbox/modkeys.c

@@ -36,14 +36,14 @@

static void set_modkey_mask(guchar mask, KeySym sym); static XModifierKeymap *modmap; +static KeySym *keymap; +static gint min_keycode, max_keycode, keysyms_per_keycode; /* This is a bitmask of the different masks for each modifier key */ static guchar modkeys_keys[OB_MODKEY_NUM_KEYS]; void modkeys_startup(gboolean reconfigure) { - KeySym *keymap; gint i, j, k; - gint min_keycode, max_keycode, keysyms_per_keycode; /* reset the keys to not be bound to any masks */ for (i = 0; i < OB_MODKEY_NUM_KEYS; ++i)

@@ -77,12 +77,12 @@ }

} } } - XFree(keymap); } void modkeys_shutdown(gboolean reconfigure) { XFreeModifiermap(modmap); + XFree(keymap); } guint modkeys_keycode_to_mask(guint keycode)

@@ -142,3 +142,16 @@ modkeys_keys[OB_MODKEY_KEY_ALT] |= mask;

else if (sym == XK_Meta_L || sym == XK_Meta_R) modkeys_keys[OB_MODKEY_KEY_META] |= mask; } + +KeyCode modkeys_sym_to_code(KeySym sym) +{ + gint i, j; + + /* go through each keycode and look for the keysym */ + for (i = min_keycode; i <= max_keycode; ++i) + for (j = 0; j < keysyms_per_keycode; ++j) + if (sym == keymap[(i-min_keycode) * keysyms_per_keycode + j]) + return i; + return 0; +} +
M openbox/modkeys.hopenbox/modkeys.h

@@ -20,6 +20,7 @@ #ifndef ob__modkeys_h

#define ob__modkeys_h #include <glib.h> +#include <X11/Xlib.h> /*! These keys are bound to the modifier masks in any fashion */ typedef enum {

@@ -50,5 +51,9 @@

/*! Get the modifier masks for a modifier key. This includes both the left and right keys when there are both. */ guint modkeys_key_to_mask(ObModkeysKey key); + +/*! Convert a KeySym to a KeyCode, because the X function is terrible - says + valgrind. */ +KeyCode modkeys_sym_to_code(KeySym sym); #endif
M openbox/openbox.copenbox/openbox.c

@@ -205,31 +205,26 @@ cursors[OB_CURSOR_WEST] = load_cursor("left_side", XC_left_side);

cursors[OB_CURSOR_NORTHWEST] = load_cursor("top_left_corner", XC_top_left_corner); - /* create available keycodes */ - keys[OB_KEY_RETURN] = - XKeysymToKeycode(ob_display, XK_Return); - keys[OB_KEY_ESCAPE] = - XKeysymToKeycode(ob_display, XK_Escape); - keys[OB_KEY_LEFT] = - XKeysymToKeycode(ob_display, XK_Left); - keys[OB_KEY_RIGHT] = - XKeysymToKeycode(ob_display, XK_Right); - keys[OB_KEY_UP] = - XKeysymToKeycode(ob_display, XK_Up); - keys[OB_KEY_DOWN] = - XKeysymToKeycode(ob_display, XK_Down); prop_startup(); /* get atoms values for the display */ extensions_query_all(); /* find which extensions are present */ if (screen_annex(program_name)) { /* it will be ours! */ do { + modkeys_startup(reconfigure); + + /* get the keycodes for keys we use */ + keys[OB_KEY_RETURN] = modkeys_sym_to_code(XK_Return); + keys[OB_KEY_ESCAPE] = modkeys_sym_to_code(XK_Escape); + keys[OB_KEY_LEFT] = modkeys_sym_to_code(XK_Left); + keys[OB_KEY_RIGHT] = modkeys_sym_to_code(XK_Right); + keys[OB_KEY_UP] = modkeys_sym_to_code(XK_Up); + keys[OB_KEY_DOWN] = modkeys_sym_to_code(XK_Down); + { ObParseInst *i; xmlDocPtr doc; xmlNodePtr node; - - modkeys_startup(reconfigure); /* startup the parsing so everything can register sections of the rc */