[Spice-devel] [spice-gtk] mouse: Fix pointer grabbing in server mode

Victor Toso lists at victortoso.com
Mon Aug 8 15:41:23 UTC 2016


Hi,

On Mon, Aug 08, 2016 at 05:23:53PM +0200, Christophe Fergeau wrote:
> Trying to click on spice-gtk window while in server mode should result
> in a pointer grab. This is currently failing, with the cursor wrapping
> to the top left corner of the window instead without being grabbed.
> This is caused by unexpected grab-broken event happening, we call
> gdk_pointer_grab() on the SpiceDisplay GdkWindow, and then we receive a
> grab-broken event coming from the same window, which the code does not
> expect (see gtk+ bug https://bugzilla.gnome.org/show_bug.cgi?id=769635
> ).

Looks good, just tested with windows 7 guest and it works fine.
Acked-by: Victor Toso <victortoso at redhat.com>

> 
> This commit detects such situations, and ignore the spurious grab-broken
> event.
> ---
>  src/spice-widget.c | 7 +++++++
>  1 file changed, 7 insertions(+)
> 
> diff --git a/src/spice-widget.c b/src/spice-widget.c
> index 7c1c756..4b0acd2 100644
> --- a/src/spice-widget.c
> +++ b/src/spice-widget.c
> @@ -462,8 +462,15 @@ static GdkCursor* get_blank_cursor(void)
>  static gboolean grab_broken(SpiceDisplay *self, GdkEventGrabBroken *event,
>                              gpointer user_data G_GNUC_UNUSED)
>  {
> +    GdkWindow *window = gtk_widget_get_window(GTK_WIDGET(self));
>      SPICE_DEBUG("%s (implicit: %d, keyboard: %d)", __FUNCTION__,
>                  event->implicit, event->keyboard);
> +    SPICE_DEBUG("%s (SpiceDisplay::GdkWindow %p, event->grab_window: %p)",
> +                __FUNCTION__, window, event->grab_window);
> +    if (window == event->grab_window) {
> +        /* ignore unwanted grab-broken event */
> +        return false;
> +    }
>  
>      if (event->keyboard) {
>          try_keyboard_ungrab(self);
> -- 
> 2.7.4
> 
> _______________________________________________
> Spice-devel mailing list
> Spice-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/spice-devel


More information about the Spice-devel mailing list