aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-tabs-menu.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-tabs-menu.c')
-rw-r--r--src/ephy-tabs-menu.c110
1 files changed, 63 insertions, 47 deletions
diff --git a/src/ephy-tabs-menu.c b/src/ephy-tabs-menu.c
index f8b697eb0..67737997a 100644
--- a/src/ephy-tabs-menu.c
+++ b/src/ephy-tabs-menu.c
@@ -44,12 +44,6 @@ struct _EphyTabsMenuPrivate
guint ui_id;
};
-typedef struct
-{
- EphyWindow *window;
- EphyTab *tab;
-} TabsData;
-
/**
* Private functions, only availble from this file
*/
@@ -77,10 +71,34 @@ static gpointer g_object_class;
/**
* EphyTabsMenu object
*/
-MAKE_GET_TYPE (ephy_tabs_menu,
- "EphyTabsMenu", EphyTabsMenu,
- ephy_tabs_menu_class_init, ephy_tabs_menu_init,
- G_TYPE_OBJECT);
+
+GType
+ephy_tabs_menu_get_type (void)
+{
+ static GType ephy_tabs_menu_type = 0;
+
+ if (ephy_tabs_menu_type == 0)
+ {
+ static const GTypeInfo our_info =
+ {
+ sizeof (EphyTabsMenuClass),
+ NULL, /* base_init */
+ NULL, /* base_finalize */
+ (GClassInitFunc) ephy_tabs_menu_class_init,
+ NULL,
+ NULL, /* class_data */
+ sizeof (EphyTab),
+ 0, /* n_preallocs */
+ (GInstanceInitFunc) ephy_tabs_menu_init
+ };
+
+ ephy_tabs_menu_type = g_type_register_static (G_TYPE_OBJECT,
+ "EphyTabsMenu",
+ &our_info, 0);
+ }
+
+ return ephy_tabs_menu_type;
+}
static void
ephy_tabs_menu_class_init (EphyTabsMenuClass *klass)
@@ -193,10 +211,14 @@ ephy_tabs_menu_new (EphyWindow *window)
}
static void
-ephy_tabs_menu_verb_cb (EggMenuMerge *merge,
- TabsData *data)
+ephy_tabs_menu_verb_cb (EggAction *action, EphyTab *tab)
{
- ephy_window_jump_to_tab (data->window, data->tab);
+ EphyWindow *window;
+
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ window = ephy_tab_get_window (tab);
+ ephy_window_jump_to_tab (window, tab);
}
@@ -252,57 +274,54 @@ static void
ephy_tabs_menu_rebuild (EphyTabsMenu *wrhm)
{
EphyTabsMenuPrivate *p = wrhm->priv;
- GString *xml;
- gint i;
- GList *tabs;
EggMenuMerge *merge = EGG_MENU_MERGE (p->window->ui_merge);
+ GString *xml;
+ guint i = 0;
+ guint len;
+ GList *tabs, *l;
+ GError *error = NULL;
LOG ("Rebuilding open tabs menu")
+ START_PROFILER ("Rebuilding tabs menu")
+
ephy_tabs_menu_clean (wrhm);
tabs = ephy_window_get_tabs (p->window);
+ len = g_list_length (tabs);
+ if (len == 0) return;
+
+ /* it's faster to preallocate */
+ xml = g_string_sized_new (52 * len + 105);
- xml = g_string_new (NULL);
g_string_append (xml, "<Root><menu><submenu name=\"TabsMenu\">"
"<placeholder name=\"TabsOpen\">");
p->action_group = egg_action_group_new ("TabsActions");
egg_menu_merge_insert_action_group (merge, p->action_group, 0);
- for (i = 0; i < g_list_length (tabs); i++)
+ for (l = tabs; l != NULL; l = l->next)
{
- char *verb = g_strdup_printf ("TabsOpen%d", i);
- char *title_s;
- const char *title;
- xmlChar *label_x;
- EphyTab *child;
- TabsData *data;
+ gchar *verb = g_strdup_printf ("TabsOpen%d", i);
+ gchar *title_s;
+ const gchar *title;
+ EphyTab *tab;
EggAction *action;
- child = g_list_nth_data (tabs, i);
+ tab = (EphyTab *) l->data;
- title = ephy_tab_get_title(child);
+ title = ephy_tab_get_title (tab);
title_s = ephy_string_shorten (title, MAX_LABEL_LENGTH);
- label_x = xmlEncodeSpecialChars (NULL, title_s);
-
- data = g_new0 (TabsData, 1);
- data->window = wrhm->priv->window;
- data->tab = child;
action = g_object_new (EGG_TYPE_ACTION,
"name", verb,
- "label", label_x,
- "tooltip", "Hello",
+ "label", title_s,
+ "tooltip", title,
"stock_id", NULL,
NULL);
- g_signal_connect_closure
- (action, "activate",
- g_cclosure_new (G_CALLBACK (ephy_tabs_menu_verb_cb),
- data,
- (GClosureNotify)g_free),
- FALSE);
+ g_signal_connect (action, "activate",
+ G_CALLBACK (ephy_tabs_menu_verb_cb), tab);
ephy_tabs_menu_set_action_accelerator (p->action_group, action, i);
@@ -316,22 +335,19 @@ ephy_tabs_menu_rebuild (EphyTabsMenu *wrhm)
g_string_append (xml, verb);
g_string_append (xml, "\"/>\n");
- xmlFree (label_x);
g_free (title_s);
g_free (verb);
+
+ ++i;
}
g_string_append (xml, "</placeholder></submenu></menu></Root>");
- if (g_list_length (tabs) > 0)
- {
- GError *error = NULL;
- LOG ("Merging ui\n%s",xml->str);
- p->ui_id = egg_menu_merge_add_ui_from_string
- (merge, xml->str, -1, &error);
- }
+ p->ui_id = egg_menu_merge_add_ui_from_string (merge, xml->str, -1, &error);
g_string_free (xml, TRUE);
+
+ STOP_PROFILER ("Rebuilding tabs menu")
}
void ephy_tabs_menu_update (EphyTabsMenu *wrhm)