diff options
author | Matthias Clasen <mclasen@redhat.com> | 2014-10-09 15:30:52 -0400 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2014-10-09 18:12:25 -0400 |
commit | 41b53ca603c157ba101a89b0828c79e7ec42bebf (patch) | |
tree | 37fe5784914a9920ccd3efbbb5d8d5850a6259b6 /gtk/gtkmenubutton.c | |
parent | 1331740dd65bc1c05d93c9461115dcaac5ee6fa7 (diff) | |
download | gtk+-41b53ca603c157ba101a89b0828c79e7ec42bebf.tar.gz |
GtkMenuButton: Submit to action
As an actionable (inherited from GtkButton), a GtkMenuButton
should not set its own sensitivity when it has an action-name
set, but just follow the enabled state of the associated
action.
https://bugzilla.gnome.org/show_bug.cgi?id=738083
Diffstat (limited to 'gtk/gtkmenubutton.c')
-rw-r--r-- | gtk/gtkmenubutton.c | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/gtk/gtkmenubutton.c b/gtk/gtkmenubutton.c index 656392f97d..875b2d783e 100644 --- a/gtk/gtkmenubutton.c +++ b/gtk/gtkmenubutton.c @@ -108,6 +108,7 @@ #include "gtkmenubutton.h" #include "gtkmenubuttonprivate.h" +#include "gtkbuttonprivate.h" #include "gtktypebuiltins.h" #include "gtkwindow.h" #include "gtkmain.h" @@ -695,6 +696,18 @@ menu_detacher (GtkWidget *widget, priv->menu = NULL; } +static void +update_sensitivity (GtkMenuButton *menu_button) +{ + GtkMenuButtonPrivate *priv = menu_button->priv; + + if (GTK_BUTTON (menu_button)->priv->action_helper) + return; + + gtk_widget_set_sensitive (GTK_WIDGET (menu_button), + priv->menu != NULL || priv->popover != NULL); +} + /* This function is used in GtkMenuToolButton, the call back will * be called when GtkMenuToolButton would have emitted the “show-menu” * signal. @@ -742,7 +755,7 @@ _gtk_menu_button_set_popup_with_func (GtkMenuButton *menu_button gtk_style_context_add_class (gtk_widget_get_style_context (GTK_WIDGET (menu_button)), "menu-button"); } - gtk_widget_set_sensitive (GTK_WIDGET (menu_button), priv->menu != NULL); + update_sensitivity (menu_button); g_object_notify (G_OBJECT (menu_button), "popup"); g_object_notify (G_OBJECT (menu_button), "menu-model"); @@ -777,8 +790,7 @@ gtk_menu_button_set_popup (GtkMenuButton *menu_button, if (menu && priv->popover) gtk_menu_button_set_popover (menu_button, NULL); - gtk_widget_set_sensitive (GTK_WIDGET (menu_button), - priv->menu != NULL || priv->popover != NULL); + update_sensitivity (menu_button); g_object_thaw_notify (G_OBJECT (menu_button)); } @@ -1171,8 +1183,7 @@ gtk_menu_button_set_popover (GtkMenuButton *menu_button, if (popover && priv->menu) gtk_menu_button_set_popup (menu_button, NULL); - gtk_widget_set_sensitive (GTK_WIDGET (menu_button), - priv->menu != NULL || priv->popover != NULL); + update_sensitivity (menu_button); g_object_notify (G_OBJECT (menu_button), "popover"); g_object_notify (G_OBJECT (menu_button), "menu-model"); |