From faa39db900ac68efda9f1632878407757e52a187 Mon Sep 17 00:00:00 2001 From: Christian Persch Date: Fri, 29 Oct 2004 19:03:46 +0000 Subject: Don't open all bookmarks in new tabs. Fixes bug #156843. 2004-10-29 Christian Persch * src/bookmarks/ephy-topic-action.c: (can_open_in_tabs), (open_in_tabs_activate_cb), (add_open_in_tabs_menu), (build_bookmarks_menu), (show_context_menu): Don't open all bookmarks in new tabs. Fixes bug #156843. --- src/bookmarks/ephy-topic-action.c | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-) (limited to 'src') diff --git a/src/bookmarks/ephy-topic-action.c b/src/bookmarks/ephy-topic-action.c index 601bd11f8..39fa29c2a 100644 --- a/src/bookmarks/ephy-topic-action.c +++ b/src/bookmarks/ephy-topic-action.c @@ -246,13 +246,15 @@ sort_bookmarks (gconstpointer a, gconstpointer b) #define MAX_LENGTH 32 static gboolean -can_open_in_tabs (EphyTopicAction *action) +can_open_in_tabs (EphyNode *node) { GPtrArray *children; + int priority; - children = ephy_node_get_children (action->priv->topic_node); + priority = ephy_node_get_property_int (node, EPHY_NODE_KEYWORD_PROP_PRIORITY); + children = ephy_node_get_children (node); - return (children->len > 1); + return (priority != EPHY_NODE_ALL_PRIORITY) && (children->len > 1); } static void @@ -337,14 +339,20 @@ append_bookmarks_menu (EphyTopicAction *action, GtkWidget *menu, EphyNode *node, } } +#define TOPIC_NODE_DATA_KEY "TopicNode" + static void -open_in_tabs_activate_cb (GtkWidget *menu, EphyTopicAction *action) +open_in_tabs_activate_cb (GtkWidget *item, EphyTopicAction *action) { + EphyNode *node; GList *uri_list = NULL; GPtrArray *children; int i; - children = ephy_node_get_children (action->priv->topic_node); + node = g_object_get_data (G_OBJECT (item), TOPIC_NODE_DATA_KEY); + g_return_if_fail (node != NULL); + + children = ephy_node_get_children (node); for (i = 0; i < children->len; i++) { const char *address; @@ -437,7 +445,9 @@ move_right_activate_cb (GtkWidget *menu, GtkWidget *proxy) } static GtkWidget * -add_open_in_tabs_menu (EphyTopicAction *action, GtkWidget *menu) +add_open_in_tabs_menu (EphyTopicAction *action, + GtkWidget *menu, + EphyNode *node) { GtkWidget *item; @@ -445,6 +455,8 @@ add_open_in_tabs_menu (EphyTopicAction *action, GtkWidget *menu) gtk_widget_show (item); gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); + g_object_set_data (G_OBJECT (item), TOPIC_NODE_DATA_KEY, node); + g_signal_connect (item, "activate", G_CALLBACK (open_in_tabs_activate_cb), action); @@ -460,7 +472,7 @@ build_bookmarks_menu (EphyTopicAction *action, EphyNode *node) append_bookmarks_menu (action, menu, node, TRUE); - if (can_open_in_tabs (action)) + if (can_open_in_tabs (node)) { GtkWidget *item; @@ -468,7 +480,7 @@ build_bookmarks_menu (EphyTopicAction *action, EphyNode *node) gtk_widget_show (item); gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); - add_open_in_tabs_menu (action, menu); + add_open_in_tabs_menu (action, menu, node); } return menu; @@ -724,8 +736,8 @@ show_context_menu (EphyTopicAction *action, GtkWidget *proxy, menu = gtk_menu_new (); - item = add_open_in_tabs_menu (action, menu); - gtk_widget_set_sensitive (item, can_open_in_tabs (action)); + item = add_open_in_tabs_menu (action, menu, action->priv->topic_node); + gtk_widget_set_sensitive (item, can_open_in_tabs (action->priv->topic_node)); item = gtk_separator_menu_item_new (); gtk_widget_show (item); -- cgit v1.2.3