]> Pileus Git - ~andy/gtk/commitdiff
Fix a case of 'stuck grab'
authorMatthias Clasen <mclasen@redhat.com>
Wed, 16 May 2012 21:18:51 +0000 (17:18 -0400)
committerMatthias Clasen <mclasen@redhat.com>
Wed, 16 May 2012 21:34:36 +0000 (17:34 -0400)
This was showing up when using a combo box in list mode. After popping
up the list, the keyboard grab appeared stuck. What was stuck here is
only the client-side grab, since we forgot to clean up our grabs
when receiving an UnmapNotify.

This bug was introduced in 1c970036648bffd5d58499bb7c8e2439b84d4397.

gdk/x11/gdkdisplay-x11.c

index fe3784a3e35ed30b985bffa3929c5db7d565fe3b..3ef8fa056741fe34a6ce9e0b16edb994485122fa 100644 (file)
@@ -659,16 +659,15 @@ gdk_x11_display_translate_event (GdkEventTranslator *translator,
            * means we hid the window ourselves, so we will have already flipped
            * the iconified bit off.
            */
-          if (window)
-            {
-              if (GDK_WINDOW_IS_MAPPED (window))
-                gdk_synthesize_window_state (window,
-                                             0,
-                                             GDK_WINDOW_STATE_ICONIFIED);
-              _gdk_x11_window_grab_check_unmap (window, xevent->xany.serial);
-            }
+          if (window && GDK_WINDOW_IS_MAPPED (window))
+            gdk_synthesize_window_state (window,
+                                         0,
+                                         GDK_WINDOW_STATE_ICONIFIED);
         }
 
+      if (window)
+        _gdk_x11_window_grab_check_unmap (window, xevent->xany.serial);
+
       break;
 
     case MapNotify: