From 0998235c2d4f021558142f91ec327ceeec20b5ac Mon Sep 17 00:00:00 2001 From: root Date: Tue, 7 Sep 2004 12:34:05 +0000 Subject: [PATCH] *** empty log message *** --- src/rxvttoolkit.C | 59 +++++++++++++++++++++++++++++++++++------------ src/rxvttoolkit.h | 1 + 2 files changed, 45 insertions(+), 15 deletions(-) diff --git a/src/rxvttoolkit.C b/src/rxvttoolkit.C index 10bb9f9d..396711a8 100644 --- a/src/rxvttoolkit.C +++ b/src/rxvttoolkit.C @@ -1,5 +1,5 @@ /*--------------------------------*-C-*---------------------------------* - * File: rxvtcolor.C + * File: rxvttoolkit.C *----------------------------------------------------------------------* * * All portions of code are copyright by their respective author/s. @@ -103,8 +103,9 @@ im_destroy_cb (XIM unused1, XPointer client_data, XPointer unused3) rxvt_xim *xim = (rxvt_xim *)client_data; rxvt_display *display = xim->display; - display->xims.erase (find (display->xims.begin (), display->xims.end (), xim)); + xim->xim = 0; + display->xims.erase (find (display->xims.begin (), display->xims.end (), xim)); display->im_change_cb (); } @@ -215,6 +216,31 @@ void rxvt_display::im_change_cb () for (im_watcher **i = imw.begin (); i != imw.end (); ++i) (*i)->call (); } + +void rxvt_display::im_change_check () +{ + // make sure we only call im_change_cb when a new input method + // registers, as xlib crashes due to a race otherwise. + Atom actual_type, *atoms; + int actual_format; + unsigned long nitems, bytes_after; + + if (XGetWindowProperty (display, root, xa_xim_servers, 0L, 1000000L, + False, XA_ATOM, &actual_type, &actual_format, + &nitems, &bytes_after, (unsigned char **)&atoms) + != Success ) + return; + + if (actual_type == XA_ATOM && actual_format == 32) + for (int i = 0; i < nitems; i++) + if (XGetSelectionOwner (display, atoms[i])) + { + im_change_cb (); + break; + } + + XFree (atoms); +} #endif void rxvt_display::x_cb (io_watcher &w, short revents) @@ -224,22 +250,25 @@ void rxvt_display::x_cb (io_watcher &w, short revents) XEvent xev; XNextEvent (display, &xev); - //printf ("T %d w %lx\n", xev.type, xev.xany.window);//D - #ifdef USE_XIM - if (xev.type == PropertyNotify - && xev.xany.window == root - && xev.xproperty.atom == xa_xim_servers) - im_change_cb (); -#endif - - for (int i = xw.size (); i--; ) + if (!XFilterEvent (&xev, None)) { - if (!xw[i]) - xw.erase_unordered (i); - else if (xw[i]->window == xev.xany.window) - xw[i]->call (xev); + + if (xev.type == PropertyNotify + && xev.xany.window == root + && xev.xproperty.atom == xa_xim_servers) + im_change_check (); +#endif + for (int i = xw.size (); i--; ) + { + if (!xw[i]) + xw.erase_unordered (i); + else if (xw[i]->window == xev.xany.window) + xw[i]->call (xev); + } +#ifdef USE_XIM } +#endif } while (XPending (display)); diff --git a/src/rxvttoolkit.h b/src/rxvttoolkit.h index 7a240cb5..7937bd32 100644 --- a/src/rxvttoolkit.h +++ b/src/rxvttoolkit.h @@ -67,6 +67,7 @@ struct rxvt_display : refcounted { vector imw; void im_change_cb (); + void im_change_check (); #endif //public -- 2.34.1