Re: [PATCH v2 02/16] window: set sensitivity based on display capability

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On Wed, Sep 26, 2018 at 07:26:25PM +0400, marcandre.lureau@xxxxxxxxxx wrote:
> From: Marc-André Lureau <marcandre.lureau@xxxxxxxxxx>
> 
> A following patch is adding a new display (VTE) that won't have the
> send_key() or screenshot() callbacks. Activating those menu/actions
> would lead to nothing or a crash. I chose to keep the UI consistent
> for all display, but disable the menu sensitivity.
> 
> Signed-off-by: Marc-André Lureau <marcandre.lureau@xxxxxxxxxx>
Acked-by: Victor Toso <victortoso@xxxxxxxxxx>
> ---
>  src/virt-viewer-display.h |  6 ++++++
>  src/virt-viewer-window.c  | 14 ++++++++++----
>  2 files changed, 16 insertions(+), 4 deletions(-)
> 
> diff --git a/src/virt-viewer-display.h b/src/virt-viewer-display.h
> index 7016a85..2de17db 100644
> --- a/src/virt-viewer-display.h
> +++ b/src/virt-viewer-display.h
> @@ -86,6 +86,12 @@ struct _VirtViewerDisplayClass {
>      void (*disable)(VirtViewerDisplay *display);
>  };
>  
> +#define VIRT_VIEWER_DISPLAY_CAN_SCREENSHOT(display) \
> +    (display && (VIRT_VIEWER_DISPLAY_GET_CLASS(display)->get_pixbuf != NULL))
> +
> +#define VIRT_VIEWER_DISPLAY_CAN_SEND_KEYS(display) \
> +    (display && (VIRT_VIEWER_DISPLAY_GET_CLASS(display)->send_keys != NULL))
> +
>  GType virt_viewer_display_get_type(void);
>  
>  GtkWidget *virt_viewer_display_new(void);
> diff --git a/src/virt-viewer-window.c b/src/virt-viewer-window.c
> index 74afb32..e50ac54 100644
> --- a/src/virt-viewer-window.c
> +++ b/src/virt-viewer-window.c
> @@ -1339,15 +1339,21 @@ virt_viewer_window_set_menus_sensitive(VirtViewerWindow *self, gboolean sensitiv
>      gtk_widget_set_sensitive(menu, sensitive);
>  
>      menu = GTK_WIDGET(gtk_builder_get_object(priv->builder, "menu-file-screenshot"));
> -    gtk_widget_set_sensitive(menu, sensitive);
> +    gtk_widget_set_sensitive(menu, sensitive &&
> +                             VIRT_VIEWER_DISPLAY_CAN_SCREENSHOT(self->priv->display));
>  
>      menu = GTK_WIDGET(gtk_builder_get_object(priv->builder, "menu-view-zoom"));
>      gtk_widget_set_sensitive(menu, sensitive);
>  
> -    menu = GTK_WIDGET(gtk_builder_get_object(priv->builder, "menu-send"));
> -    gtk_widget_set_sensitive(menu, sensitive);
> +    {
> +        gboolean can_send = sensitive &&
> +            VIRT_VIEWER_DISPLAY_CAN_SEND_KEYS(self->priv->display);
>  
> -    gtk_widget_set_sensitive(self->priv->toolbar_send_key, sensitive);
> +        menu = GTK_WIDGET(gtk_builder_get_object(priv->builder, "menu-send"));
> +        gtk_widget_set_sensitive(menu, can_send);
> +
> +        gtk_widget_set_sensitive(self->priv->toolbar_send_key, can_send);
> +    }
>  }
>  
>  static void
> -- 
> 2.19.0.271.gfe8321ec05
> 

Attachment: signature.asc
Description: PGP signature

_______________________________________________
virt-tools-list mailing list
virt-tools-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/virt-tools-list

[Index of Archives]     [Linux Virtualization]     [KVM Development]     [CentOS Virtualization]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite Forum]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]     [Video 4 Linux]

  Powered by Linux