diff options
Diffstat (limited to 'src/toolbar.c')
-rwxr-xr-x | src/toolbar.c | 94 |
1 files changed, 56 insertions, 38 deletions
diff --git a/src/toolbar.c b/src/toolbar.c index ff5f9cba1..29ae4665f 100755 --- a/src/toolbar.c +++ b/src/toolbar.c @@ -100,17 +100,72 @@ toolbar_get_type (void) } static void +go_location_cb (EggAction *action, char *location, EphyWindow *window) +{ + EphyEmbed *embed; + + embed = ephy_window_get_active_embed (window); + g_return_if_fail (embed != NULL); + + ephy_embed_load_url (embed, location); +} + +static EggAction * +toolbar_get_action (EphyEditableToolbar *etoolbar, + const char *type, + const char *name) +{ + Toolbar *t = TOOLBAR (etoolbar); + EggAction *action = NULL; + EphyBookmarks *bookmarks; + gulong id = 0; + + if (type && (strcmp (type, EPHY_DND_URL_TYPE) == 0)) + { + char action_name[255]; + + bookmarks = ephy_shell_get_bookmarks (ephy_shell); + id = ephy_bookmarks_get_bookmark_id (bookmarks, name); + + snprintf (action_name, 255, "GoBookmarkId%ld", id); + action = ephy_bookmark_action_new (name, id); + } + else if (g_str_has_prefix (name, "GoBookmarkId")) + { + ephy_str_to_int (name + strlen ("GoBookmarkId"), &id); + } + + if (action) + { + g_signal_connect (action, "go_location", + G_CALLBACK (go_location_cb), t->priv->window); + egg_action_group_add_action (t->priv->action_group, action); + g_object_unref (action); + } + else + { + action = EPHY_EDITABLE_TOOLBAR_CLASS + (parent_class)->get_action (etoolbar, type, name); + } + + return action; +} + +static void toolbar_class_init (ToolbarClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); + EphyEditableToolbarClass *eet_class; parent_class = g_type_class_peek_parent (klass); + eet_class = EPHY_EDITABLE_TOOLBAR_CLASS (klass); object_class->finalize = toolbar_finalize; - object_class->set_property = toolbar_set_property; object_class->get_property = toolbar_get_property; + eet_class->get_action = toolbar_get_action; + g_object_class_install_property (object_class, PROP_EPHY_WINDOW, g_param_spec_object ("EphyWindow", @@ -153,17 +208,6 @@ toolbar_get_property (GObject *object, } static void -go_location_cb (EggAction *action, char *location, EphyWindow *window) -{ - EphyEmbed *embed; - - embed = ephy_window_get_active_embed (window); - g_return_if_fail (embed != NULL); - - ephy_embed_load_url (embed, location); -} - -static void toolbar_setup_actions (Toolbar *t) { EggAction *action; @@ -246,28 +290,6 @@ toolbar_set_window (Toolbar *t, EphyWindow *window) } static void -editable_toolbar_request_action (Toolbar *t, - const char *name, - EphyEditableToolbar *etoolbar) -{ - guint id; - - if (g_str_has_prefix (name, "GoBookmark") && - ephy_str_to_int (name + strlen ("GoBookmark"), &id)) - { - EggAction *action; - - LOG ("Create an action for bookmark %d", id) - - action = ephy_bookmark_action_new (name, id); - g_signal_connect (action, "go_location", - G_CALLBACK (go_location_cb), t->priv->window); - egg_action_group_add_action (t->priv->action_group, action); - g_object_unref (action); - } -} - -static void toolbar_init (Toolbar *t) { t->priv = g_new0 (ToolbarPrivate, 1); @@ -275,10 +297,6 @@ toolbar_init (Toolbar *t) t->priv->window = NULL; t->priv->ui_merge = NULL; t->priv->visibility = TRUE; - - g_signal_connect (t, "request_action", - G_CALLBACK (editable_toolbar_request_action), - EPHY_EDITABLE_TOOLBAR (t)); } static void |