From 9417017f5b9d457966ef44d8f376ceceec4dc30f Mon Sep 17 00:00:00 2001 From: Cosimo Cecchi Date: Thu, 30 Jun 2011 15:51:10 -0400 Subject: [PATCH] toolbar: invalidate order when an item visibility changes --- gtk/gtktoolbar.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/gtk/gtktoolbar.c b/gtk/gtktoolbar.c index b79cef98e9..432e2afd05 100644 --- a/gtk/gtktoolbar.c +++ b/gtk/gtktoolbar.c @@ -3267,6 +3267,16 @@ struct _ToolbarContent guint has_menu : 2; }; +static void +toolbar_item_visiblity_notify_cb (GObject *obj, + GParamSpec *pspec, + gpointer user_data) +{ + GtkToolbar *toolbar = user_data; + + gtk_toolbar_invalidate_order (toolbar); +} + static ToolbarContent * toolbar_content_new_tool_item (GtkToolbar *toolbar, GtkToolItem *item, @@ -3287,6 +3297,9 @@ toolbar_content_new_tool_item (GtkToolbar *toolbar, gtk_widget_set_parent (GTK_WIDGET (item), GTK_WIDGET (toolbar)); gtk_toolbar_invalidate_order (toolbar); + g_signal_connect (content->item, "notify::visible", + G_CALLBACK (toolbar_item_visiblity_notify_cb), toolbar); + if (!is_placeholder) { priv->num_children++; @@ -3309,6 +3322,10 @@ toolbar_content_remove (ToolbarContent *content, gtk_toolbar_invalidate_order (toolbar); gtk_widget_unparent (GTK_WIDGET (content->item)); + g_signal_handlers_disconnect_by_func (content->item, + toolbar_item_visiblity_notify_cb, + toolbar); + priv->content = g_list_remove (priv->content, content); if (!toolbar_content_is_placeholder (content))