Re: [PATCH 07/22] window: set sensitivity based on display capability

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

 



Hi

On Fri, Aug 31, 2018 at 8:43 AM, Victor Toso <victortoso@xxxxxxxxxx> wrote:
> Hi,
>
> On Tue, Jul 31, 2018 at 03:41:10PM +0200, marcandre.lureau@xxxxxxxxxx wrote:
>> From: Marc-André Lureau <marcandre.lureau@xxxxxxxxxx>
>
> I take this is a preparatory patch for VTE, could you please add
> some rationale in the commit log on why this was needed?

Indeed, a following patch is adding a new display that won't have the
send_key() or screenshot() callbacks. Activating those menu/actions
would lead to crash. I chose to keep the UI consistent for all
display, but disable the menu sensitivy.

I'll update the commit message.

>> Signed-off-by: Marc-André Lureau <marcandre.lureau@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..eadc333 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) \
>> +    (VIRT_VIEWER_DISPLAY_GET_CLASS(display)->get_pixbuf != NULL)
>> +
>> +#define VIRT_VIEWER_DISPLAY_CAN_SEND_KEYS(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 b9b8ce9..ec9bae6 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 && self->priv->display != NULL &&
>> +                             VIRT_VIEWER_DISPLAY_CAN_SCREENSHOT(self->priv->display));
>
> Why not moving the display != NULL check into the macro?

ok

>
>>      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 && self->priv->display != NULL &&
>> +            VIRT_VIEWER_DISPLAY_CAN_SEND_KEYS(self->priv->display);
>
> Ditto.
>
>>
>> -    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);
>> +    }
>>  }
>
> Cheers,
> Victor

_______________________________________________
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