diff options
author | Marco Pesenti Gritti <marco@gnome.org> | 2004-07-02 17:03:42 +0800 |
---|---|---|
committer | Marco Pesenti Gritti <marco@src.gnome.org> | 2004-07-02 17:03:42 +0800 |
commit | 6dadef323fb59daefac69200014b1d5f238a911a (patch) | |
tree | f44b28f70a91dee49b95ebbc8d5c7a86a7ea9f3c /src/ephy-favorites-menu.c | |
parent | 5788200966658bf840916954af8718426d33c177 (diff) | |
download | gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.tar gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.tar.gz gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.tar.bz2 gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.tar.lz gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.tar.xz gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.tar.zst gsoc2013-epiphany-6dadef323fb59daefac69200014b1d5f238a911a.zip |
Move in the bookmarks dir.
2004-07-02 Marco Pesenti Gritti <marco@gnome.org>
* src/bookmarks/ephy-favorites-menu.c:
* src/bookmarks/ephy-favorites-menu.h:
Move in the bookmarks dir.
* lib/ephy-gui.c: (ephy_gui_select_row_by_key),
(ephy_gui_is_middle_click):
* lib/ephy-gui.h:
Add a function to check if menus was activated
by a middle or a ctrl+click (which is equivalent in epiphany)
* lib/ephy-marshal.list:
* src/Makefile.am:
* src/bookmarks/Makefile.am:
* src/bookmarks/ephy-bookmark-action.c: (activate_cb),
(ephy_bookmark_action_class_init):
* src/bookmarks/ephy-bookmark-action.h:
* src/bookmarks/ephy-bookmarks-menu.c: (open_bookmark_cb),
(create_menu):
* src/bookmarks/ephy-bookmarksbar.c: (bookmark_open_in_tab_cb),
(bookmark_open_cb), (ephy_bookmarksbar_action_request):
* src/bookmarks/ephy-topic-action.c: (menu_activate_cb),
(ephy_topic_action_class_init):
* src/bookmarks/ephy-topic-action.h:
Add signals to open bookmarks in new window/tab. I'll need
them for context menus.
Use them for middle/ctrl click.
Diffstat (limited to 'src/ephy-favorites-menu.c')
-rw-r--r-- | src/ephy-favorites-menu.c | 297 |
1 files changed, 0 insertions, 297 deletions
diff --git a/src/ephy-favorites-menu.c b/src/ephy-favorites-menu.c deleted file mode 100644 index fee325c47..000000000 --- a/src/ephy-favorites-menu.c +++ /dev/null @@ -1,297 +0,0 @@ -/* - * Copyright (C) 2002 Ricardo Fernández Pascual - * Copyright (C) 2003 Marco Pesenti Gritti - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - * - * $Id$ - */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "ephy-favorites-menu.h" -#include "ephy-bookmark-action.h" -#include "ephy-shell.h" -#include "ephy-debug.h" - -#include <gtk/gtkuimanager.h> -#include <glib/gprintf.h> - -#define EPHY_FAVORITES_MENU_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_FAVORITES_MENU, EphyFavoritesMenuPrivate)) - -struct _EphyFavoritesMenuPrivate -{ - EphyWindow *window; - EphyBookmarks *bookmarks; - GtkActionGroup *action_group; - guint ui_id; - guint update_tag; -}; - -static void ephy_favorites_menu_class_init (EphyFavoritesMenuClass *klass); -static void ephy_favorites_menu_init (EphyFavoritesMenu *menu); -static void ephy_favorites_menu_finalize (GObject *o); - -enum -{ - PROP_0, - PROP_WINDOW -}; - -static gpointer parent_class; - -GType -ephy_favorites_menu_get_type (void) -{ - static GType ephy_favorites_menu_type = 0; - - if (ephy_favorites_menu_type == 0) - { - static const GTypeInfo our_info = - { - sizeof (EphyFavoritesMenuClass), - NULL, /* base_init */ - NULL, /* base_finalize */ - (GClassInitFunc) ephy_favorites_menu_class_init, - NULL, - NULL, /* class_data */ - sizeof (EphyFavoritesMenu), - 0, /* n_preallocs */ - (GInstanceInitFunc) ephy_favorites_menu_init - }; - - ephy_favorites_menu_type = g_type_register_static (G_TYPE_OBJECT, - "EphyFavoritesMenu", - &our_info, 0); - } - return ephy_favorites_menu_type; -} - -static void -ephy_favorites_menu_clean (EphyFavoritesMenu *menu) -{ - EphyFavoritesMenuPrivate *p = menu->priv; - GtkUIManager *merge = GTK_UI_MANAGER (p->window->ui_merge); - - if (p->ui_id > 0) - { - gtk_ui_manager_remove_ui (merge, p->ui_id); - gtk_ui_manager_ensure_update (merge); - p->ui_id = 0; - } - - if (p->action_group != NULL) - { - gtk_ui_manager_remove_action_group (merge, p->action_group); - g_object_unref (p->action_group); - } -} - -static void -go_location_cb (GtkAction *action, char *location, EphyWindow *window) -{ - ephy_window_load_url (window, location); -} - -static void -ephy_favorites_menu_rebuild (EphyFavoritesMenu *menu) -{ - EphyFavoritesMenuPrivate *p = menu->priv; - gint i; - EphyNode *fav; - GPtrArray *children; - GtkUIManager *merge = GTK_UI_MANAGER (p->window->ui_merge); - - LOG ("Rebuilding favorites menu") - - START_PROFILER ("Rebuild favorites menu") - - ephy_favorites_menu_clean (menu); - - fav = ephy_bookmarks_get_favorites (p->bookmarks); - children = ephy_node_get_children (fav); - - p->action_group = gtk_action_group_new ("FavoritesActions"); - gtk_ui_manager_insert_action_group (merge, p->action_group, 0); - p->ui_id = gtk_ui_manager_new_merge_id (merge); - - for (i = 0; i < children->len; i++) - { - char verb[20]; - char name[20]; - char accel_path[48]; - EphyNode *node; - GtkAction *action; - - g_snprintf (verb, sizeof (verb),"GoFav%d", i); - g_snprintf (name, sizeof (name), "GoFav%dMenu", i); - g_snprintf (accel_path, sizeof (accel_path), - "<Actions>/FavoritesActions/%s", verb); - - node = g_ptr_array_index (children, i); - - action = ephy_bookmark_action_new (verb, - ephy_node_get_id (node)); - gtk_action_set_accel_path (action, accel_path); - gtk_action_group_add_action (p->action_group, action); - g_object_unref (action); - g_signal_connect (action, "go_location", - G_CALLBACK (go_location_cb), p->window); - - gtk_ui_manager_add_ui (merge, p->ui_id, - "/menubar/GoMenu", - name, verb, - GTK_UI_MANAGER_MENUITEM, FALSE); - } - - STOP_PROFILER ("Rebuild favorites menu") -} - -static void -ephy_favorites_menu_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec) -{ - EphyFavoritesMenu *menu = EPHY_FAVORITES_MENU (object); - - switch (prop_id) - { - case PROP_WINDOW: - menu->priv->window = g_value_get_object (value); - ephy_favorites_menu_rebuild (menu); - break; - } -} - -static void -ephy_favorites_menu_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec) -{ - EphyFavoritesMenu *menu = EPHY_FAVORITES_MENU (object); - - switch (prop_id) - { - case PROP_WINDOW: - g_value_set_object (value, menu->priv->window); - break; - } -} - - -static void -ephy_favorites_menu_class_init (EphyFavoritesMenuClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - - parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = ephy_favorites_menu_finalize; - object_class->set_property = ephy_favorites_menu_set_property; - object_class->get_property = ephy_favorites_menu_get_property; - - g_object_class_install_property (object_class, - PROP_WINDOW, - g_param_spec_object ("window", - "Window", - "Parent window", - EPHY_TYPE_WINDOW, - G_PARAM_READWRITE | - G_PARAM_CONSTRUCT_ONLY)); - - g_type_class_add_private (object_class, sizeof(EphyFavoritesMenuPrivate)); -} - -static gboolean -do_updates (EphyFavoritesMenu *menu) -{ - ephy_favorites_menu_rebuild (menu); - - menu->priv->update_tag = 0; - - /* don't run again */ - return FALSE; -} - -static void -fav_removed_cb (EphyNode *node, - EphyNode *child, - guint old_index, - EphyFavoritesMenu *menu) -{ - if (menu->priv->update_tag == 0) - { - menu->priv->update_tag = g_idle_add((GSourceFunc)do_updates, menu); - } -} - -static void -fav_added_cb (EphyNode *node, - EphyNode *child, - EphyFavoritesMenu *menu) -{ - if (menu->priv->update_tag == 0) - { - menu->priv->update_tag = g_idle_add((GSourceFunc)do_updates, menu); - } -} - -static void -ephy_favorites_menu_init (EphyFavoritesMenu *menu) -{ - EphyFavoritesMenuPrivate *p = EPHY_FAVORITES_MENU_GET_PRIVATE (menu); - EphyNode *fav; - menu->priv = p; - - menu->priv->bookmarks = ephy_shell_get_bookmarks (ephy_shell); - menu->priv->ui_id = 0; - menu->priv->update_tag = 0; - menu->priv->action_group = NULL; - - fav = ephy_bookmarks_get_favorites (menu->priv->bookmarks); - ephy_node_signal_connect_object (fav, - EPHY_NODE_CHILD_REMOVED, - (EphyNodeCallback) fav_removed_cb, - G_OBJECT (menu)); - ephy_node_signal_connect_object (fav, - EPHY_NODE_CHILD_ADDED, - (EphyNodeCallback) fav_added_cb, - G_OBJECT (menu)); -} - -static void -ephy_favorites_menu_finalize (GObject *o) -{ - EphyFavoritesMenu *menu = EPHY_FAVORITES_MENU (o); - - if (menu->priv->action_group != NULL) - { - g_object_unref (menu->priv->action_group); - } - - G_OBJECT_CLASS (parent_class)->finalize (o); -} - -EphyFavoritesMenu * -ephy_favorites_menu_new (EphyWindow *window) -{ - return g_object_new (EPHY_TYPE_FAVORITES_MENU, - "window", window, - NULL); -} |