summaryrefslogtreecommitdiff
path: root/gtk/gtkmenubutton.c
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2014-10-09 15:30:52 -0400
committerMatthias Clasen <mclasen@redhat.com>2014-10-09 18:12:25 -0400
commit41b53ca603c157ba101a89b0828c79e7ec42bebf (patch)
tree37fe5784914a9920ccd3efbbb5d8d5850a6259b6 /gtk/gtkmenubutton.c
parent1331740dd65bc1c05d93c9461115dcaac5ee6fa7 (diff)
downloadgtk+-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.c21
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");