diff --git a/src/core/display.c b/src/core/display.c index 00480b55f..fd4e93242 100644 --- a/src/core/display.c +++ b/src/core/display.c @@ -2852,15 +2852,11 @@ static Window event_get_modified_window (MetaDisplay *display, XEvent *event) { + if (meta_input_event_get_type (display, event, NULL)) + return meta_input_event_get_window (display, event); + switch (event->type) { - case KeyPress: - case KeyRelease: - case ButtonPress: - case ButtonRelease: - case MotionNotify: - case FocusIn: - case FocusOut: case KeymapNotify: case Expose: case GraphicsExpose: @@ -2873,8 +2869,6 @@ event_get_modified_window (MetaDisplay *display, case SelectionNotify: case ColormapNotify: case ClientMessage: - case EnterNotify: - case LeaveNotify: return event->xany.window; case CreateNotify: @@ -2931,19 +2925,11 @@ static guint32 event_get_time (MetaDisplay *display, XEvent *event) { + if (meta_input_event_get_type (display, event, NULL)) + return meta_input_event_get_time (display, event); + switch (event->type) { - case KeyPress: - case KeyRelease: - return event->xkey.time; - - case ButtonPress: - case ButtonRelease: - return event->xbutton.time; - - case MotionNotify: - return event->xmotion.time; - case PropertyNotify: return event->xproperty.time; @@ -2952,13 +2938,7 @@ event_get_time (MetaDisplay *display, case SelectionNotify: return event->xselection.time; - case EnterNotify: - case LeaveNotify: - return event->xcrossing.time; - - case FocusIn: - case FocusOut: - case KeymapNotify: + case KeymapNotify: case Expose: case GraphicsExpose: case NoExpose: