diff options
Diffstat (limited to 'e-util')
-rw-r--r-- | e-util/e-menu-tool-button.c | 59 | ||||
-rw-r--r-- | e-util/e-menu-tool-button.h | 12 |
2 files changed, 38 insertions, 33 deletions
diff --git a/e-util/e-menu-tool-button.c b/e-util/e-menu-tool-button.c index 16340dc483..61327f7ae1 100644 --- a/e-util/e-menu-tool-button.c +++ b/e-util/e-menu-tool-button.c @@ -80,26 +80,33 @@ menu_tool_button_get_prefer_menu_item (GtkMenuToolButton *menu_tool_button) E_MENU_TOOL_BUTTON (menu_tool_button)); if (prefer_item != NULL && *prefer_item != '\0') { GtkAction *action; - GList *iter; + GList *link; - for (iter = children; iter != NULL; iter = iter->next) { - item = GTK_MENU_ITEM (iter->data); + for (link = children; link != NULL; link = g_list_next (link)) { + GtkWidget *child; + const gchar *name; - if (!item) + child = GTK_WIDGET (link->data); + + if (!GTK_IS_MENU_ITEM (child)) continue; action = gtk_activatable_get_related_action ( - GTK_ACTIVATABLE (item)); - if (action && g_strcmp0 (gtk_action_get_name (action), prefer_item) == 0) - break; - else if (!action && g_strcmp0 (gtk_widget_get_name (GTK_WIDGET (item)), prefer_item) == 0) - break; + GTK_ACTIVATABLE (child)); - item = NULL; + if (action != NULL) + name = gtk_action_get_name (action); + else + name = gtk_widget_get_name (child); + + if (g_strcmp0 (name, prefer_item) == 0) { + item = GTK_MENU_ITEM (child); + break; + } } } - if (!item) + if (item == NULL) item = GTK_MENU_ITEM (children->data); g_list_free (children); @@ -189,19 +196,16 @@ menu_tool_button_get_property (GObject *object, } static void -menu_tool_button_dispose (GObject *object) +menu_tool_button_finalize (GObject *object) { EMenuToolButtonPrivate *priv; priv = E_MENU_TOOL_BUTTON_GET_PRIVATE (object); - if (priv->prefer_item) { - g_free (priv->prefer_item); - priv->prefer_item = NULL; - } + g_free (priv->prefer_item); - /* Chain up to parent's dispose() method. */ - G_OBJECT_CLASS (e_menu_tool_button_parent_class)->dispose (object); + /* Chain up to parent's finalize() method. */ + G_OBJECT_CLASS (e_menu_tool_button_parent_class)->finalize (object); } static void @@ -215,7 +219,7 @@ e_menu_tool_button_class_init (EMenuToolButtonClass *class) object_class = G_OBJECT_CLASS (class); object_class->set_property = menu_tool_button_set_property; object_class->get_property = menu_tool_button_get_property; - object_class->dispose = menu_tool_button_dispose; + object_class->finalize = menu_tool_button_finalize; tool_button_class = GTK_TOOL_BUTTON_CLASS (class); tool_button_class->clicked = menu_tool_button_clicked; @@ -249,11 +253,18 @@ e_menu_tool_button_new (const gchar *label) return g_object_new (E_TYPE_MENU_TOOL_BUTTON, "label", label, NULL); } +const gchar * +e_menu_tool_button_get_prefer_item (EMenuToolButton *button) +{ + g_return_val_if_fail (E_IS_MENU_TOOL_BUTTON (button), NULL); + + return button->priv->prefer_item; +} + void e_menu_tool_button_set_prefer_item (EMenuToolButton *button, const gchar *prefer_item) { - g_return_if_fail (button != NULL); g_return_if_fail (E_IS_MENU_TOOL_BUTTON (button)); if (g_strcmp0 (button->priv->prefer_item, prefer_item) == 0) @@ -265,11 +276,3 @@ e_menu_tool_button_set_prefer_item (EMenuToolButton *button, g_object_notify (G_OBJECT (button), "prefer-item"); } -const gchar * -e_menu_tool_button_get_prefer_item (EMenuToolButton *button) -{ - g_return_val_if_fail (button != NULL, NULL); - g_return_val_if_fail (E_IS_MENU_TOOL_BUTTON (button), NULL); - - return button->priv->prefer_item; -} diff --git a/e-util/e-menu-tool-button.h b/e-util/e-menu-tool-button.h index c16ba09b64..e99d3e9bdf 100644 --- a/e-util/e-menu-tool-button.h +++ b/e-util/e-menu-tool-button.h @@ -66,11 +66,13 @@ struct _EMenuToolButtonClass { GtkMenuToolButtonClass parent_class; }; -GType e_menu_tool_button_get_type (void) G_GNUC_CONST; -GtkToolItem * e_menu_tool_button_new (const gchar *label); -void e_menu_tool_button_set_prefer_item (EMenuToolButton *button, - const gchar *prefer_item); -const gchar * e_menu_tool_button_get_prefer_item (EMenuToolButton *button); +GType e_menu_tool_button_get_type (void) G_GNUC_CONST; +GtkToolItem * e_menu_tool_button_new (const gchar *label); +const gchar * e_menu_tool_button_get_prefer_item + (EMenuToolButton *button); +void e_menu_tool_button_set_prefer_item + (EMenuToolButton *button, + const gchar *prefer_item); G_END_DECLS |