From: Dana Jansens Date: Fri, 12 Feb 2010 13:11:27 +0000 (-0500) Subject: destroy XIC's that belong to an XIM before closing the XIM, else Xlib will seggie! X-Git-Url: https://git.dogcows.com/gitweb?a=commitdiff_plain;h=7c2eb3a781b4434d243b3d135e3dc1ce288cf464;p=chaz%2Fopenbox destroy XIC's that belong to an XIM before closing the XIM, else Xlib will seggie! --- diff --git a/obt/keyboard.c b/obt/keyboard.c index 57208aa2..f7a0f3bb 100644 --- a/obt/keyboard.c +++ b/obt/keyboard.c @@ -116,10 +116,19 @@ void obt_keyboard_reload(void) void obt_keyboard_shutdown(void) { + GSList *it; + XFreeModifiermap(modmap); modmap = NULL; XFree(keymap); keymap = NULL; + for (it = xic_all; it; it = g_slist_next(it)) { + ObtIC* ic = it->data; + if (ic->xic) { + XDestroyIC(ic->xic); + ic->xic = NULL; + } + } if (xim) XCloseIM(xim); xim = NULL; xim_style = 0; @@ -375,11 +384,6 @@ KeySym obt_keyboard_keypress_to_keysym(XEvent *ev) void obt_keyboard_context_renew(ObtIC *ic) { - if (ic->xic) { - XDestroyIC(ic->xic); - ic->xic = NULL; - } - if (xim) { ic->xic = XCreateIC(xim, XNInputStyle, xim_style,