aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXan Lopez <xan@igalia.com>2011-12-05 07:21:40 +0800
committerXan Lopez <xan@igalia.com>2011-12-05 07:24:50 +0800
commitfdf7054db6d84b554b3ea52ed60d065f211765e0 (patch)
tree4dcc7b7cecea4814369fa82a84de49f0a8a306e6
parentebbb1c48197f53b98575b0cb4f6d9fa1e4535abc (diff)
downloadgsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.tar
gsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.tar.gz
gsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.tar.bz2
gsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.tar.lz
gsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.tar.xz
gsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.tar.zst
gsoc2013-epiphany-fdf7054db6d84b554b3ea52ed60d065f211765e0.zip
ephy-window: remove the tabs menu
It is not present in the new design. The Alt+<num> accelerators are dying with it, but it will be pretty easy to bring them back if needed.
-rw-r--r--data/ui/epiphany-ui.xml14
-rw-r--r--src/Makefile.am2
-rw-r--r--src/ephy-tabs-menu.c486
-rw-r--r--src/ephy-tabs-menu.h61
-rw-r--r--src/ephy-window.c73
5 files changed, 7 insertions, 629 deletions
diff --git a/data/ui/epiphany-ui.xml b/data/ui/epiphany-ui.xml
index ad8577cf9..a962341f3 100644
--- a/data/ui/epiphany-ui.xml
+++ b/data/ui/epiphany-ui.xml
@@ -86,20 +86,6 @@
<menu name="ToolsMenu" action="Tools"/>
- <menu name="TabsMenu" action="Tabs">
- <menuitem name="TabsPreviousMenu" action="TabsPrevious"/>
- <menuitem name="TabsNextMenu" action="TabsNext"/>
- <separator name="TabsSep1"/>
- <placeholder name="TabsMoveGroup">
- <menuitem name="TabsMoveLeftMenu" action="TabsMoveLeft"/>
- <menuitem name="TabsMoveRightMenu" action="TabsMoveRight"/>
- </placeholder>
- <menuitem name="TabsDetach" action="TabsDetach"/>
- <placeholder name="TabsOpen">
- <separator name="TabsSep2"/>
- </placeholder>
- </menu>
-
<menu name="HelpMenu" action="Help">
<menuitem name="HelpContentsMenu" action="HelpContents"/>
<menuitem name="HelpAboutMenu" action="HelpAbout"/>
diff --git a/src/Makefile.am b/src/Makefile.am
index 49463d6fa..97418adb0 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -29,7 +29,6 @@ NOINST_H_FILES = \
ephy-navigation-history-action.h \
ephy-navigation-up-action.h \
ephy-password-info.h \
- ephy-tabs-menu.h \
ephy-toolbars-model.h \
ephy-toolbar.h \
languages.h \
@@ -73,7 +72,6 @@ libephymain_la_SOURCES = \
ephy-password-info.c \
ephy-session.c \
ephy-shell.c \
- ephy-tabs-menu.c \
ephy-toolbars-model.c \
ephy-toolbar.c \
ephy-window.c \
diff --git a/src/ephy-tabs-menu.c b/src/ephy-tabs-menu.c
deleted file mode 100644
index 4e5f8ee54..000000000
--- a/src/ephy-tabs-menu.c
+++ /dev/null
@@ -1,486 +0,0 @@
-/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
-/*
- * Copyright © 2003 David Bordoley
- * Copyright © 2003-2004 Christian Persch
- *
- * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- */
-
-#include "config.h"
-
-#include "ephy-tabs-menu.h"
-#include "ephy-notebook.h"
-#include "ephy-shell.h"
-#include "ephy-debug.h"
-#include "ephy-embed-container.h"
-#include "ephy-embed-utils.h"
-
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-#include <string.h>
-#include <stdlib.h>
-
-#define LABEL_WIDTH_CHARS 32
-#define ACTION_VERB_FORMAT_PREFIX "JmpTab"
-#define ACTION_VERB_FORMAT_PREFIX_LEN (6) /* strlen (ACTION_VERB_FORMAT_PREFIX) */
-#define ACTION_VERB_FORMAT ACTION_VERB_FORMAT_PREFIX "%x"
-#define ACTION_VERB_FORMAT_LENGTH strlen (ACTION_VERB_FORMAT) + 14 + 1
-#define ACTION_VERB_FORMAT_BASE (16) /* %x is hex */
-#define ACCEL_PATH_FORMAT "<Actions>/TabsActions/%s"
-#define ACCEL_PATH_FORMAT_LENGTH strlen (ACCEL_PATH_FORMAT) -2 + ACTION_VERB_FORMAT_LENGTH
-#define DATA_KEY "EphyTabsMenu::Action"
-
-#define EPHY_TABS_MENU_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_TABS_MENU, EphyTabsMenuPrivate))
-
-struct _EphyTabsMenuPrivate
-{
- EphyWindow *window;
- GtkActionGroup *action_group;
- GtkAction *anchor_action;
- guint ui_id;
-};
-
-enum
-{
- PROP_0,
- PROP_WINDOW
-};
-
-static void ephy_tabs_menu_class_init (EphyTabsMenuClass *klass);
-static void ephy_tabs_menu_init (EphyTabsMenu *menu);
-static void ephy_tabs_menu_update (EphyTabsMenu *menu);
-
-/* FIXME: this can be severely optimised */
-static GByteArray *tabs_id_array = NULL;
-static guint n_tabs = 0;
-
-G_DEFINE_TYPE (EphyTabsMenu, ephy_tabs_menu, G_TYPE_OBJECT)
-
-/* We need to assign unique IDs to tabs, otherwise accels get confused in the
- * tabs menu (bug #339548). We could use a serial #, but the ID is used in the
- * action name which is stored in a GQuark and so we should allocate them
- * efficiently.
- */
-static guint
-allocate_tab_id (void)
-{
- int bit;
- guint b, len;
- guint8 *data;
- guint8 byte, mask;
-
- if (n_tabs++ == 0)
- {
- g_assert (tabs_id_array == NULL);
- tabs_id_array = g_byte_array_sized_new (16);
- }
-
- /* Find a free ID */
- len = tabs_id_array->len;
- data = tabs_id_array->data;
- for (b = 0; b < len; ++b)
- {
- if (data[b] != 0xff)
- break;
- }
-
- /* Need to append a new byte */
- if (b == len)
- {
- guint8 bytes[] = { 0 };
- g_byte_array_append (tabs_id_array, bytes, G_N_ELEMENTS (bytes));
- g_assert (tabs_id_array->len > b);
- }
-
- data = tabs_id_array->data + b;
- byte = 0xff ^ *data;
- /* Now find the first free bit */
- bit = g_bit_nth_lsf (byte, -1);
- mask = 1 << bit;
- g_assert (bit >= 0 && bit <= 7);
- g_assert ((*data & mask) == 0);
- /* And mark it as allocated */
- *data |= mask;
-
- return b * 8 + bit;
-}
-
-static void
-free_tab_id (GtkAction *action)
-{
- const char *name;
- guint id;
- guint8 *data;
- guint b, bit;
-
- name = gtk_action_get_name (action);
- id = g_ascii_strtoull (name + ACTION_VERB_FORMAT_PREFIX_LEN, NULL,
- ACTION_VERB_FORMAT_BASE);
- g_assert (id >= 0 && id < tabs_id_array->len * 8);
-
- b = id >> 3;
- bit = id & 0x7;
- data = tabs_id_array->data + b;
- *data &= ~(1 << bit);
-
- g_assert (n_tabs > 0);
- if (--n_tabs == 0)
- {
- g_assert (tabs_id_array != NULL);
- g_byte_array_free (tabs_id_array, TRUE);
- tabs_id_array = NULL;
- }
-}
-
-static void
-tab_action_activate_cb (GtkAction *action,
- EphyTabsMenu *menu)
-{
- EphyTabsMenuPrivate *priv = menu->priv;
- EphyEmbed *embed;
-
- embed = g_object_get_data (G_OBJECT (action), DATA_KEY);
- g_return_if_fail (embed != NULL);
-
- LOG ("tab_action_activate_cb embed=%p", embed);
-
- if (ephy_embed_container_get_active_child (EPHY_EMBED_CONTAINER (priv->window)) != embed)
- {
- ephy_embed_container_set_active_child (EPHY_EMBED_CONTAINER (priv->window), embed);
- }
-}
-
-static void
-sync_tab_title (EphyWebView *view,
- GParamSpec *pspec,
- GtkAction *action)
-{
- const char *title;
-
- title = ephy_web_view_get_title_composite (view);
-
- g_object_set (action, "label", title, NULL);
-}
-
-static void
-sync_tab_icon (EphyWebView *view,
- GParamSpec *pspec,
- GtkWidget *proxy)
-{
- if (GTK_IS_MENU_ITEM (proxy))
- {
- GdkPixbuf *pixbuf;
- GtkWidget *image;
-
- pixbuf = ephy_web_view_get_icon (view);
- image = gtk_image_new_from_pixbuf (pixbuf);
- gtk_widget_show (image);
- gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (proxy), image);
- gtk_image_menu_item_set_always_show_image (GTK_IMAGE_MENU_ITEM (proxy), TRUE);
- }
-}
-
-static void
-notebook_page_added_cb (EphyNotebook *notebook,
- EphyEmbed *embed,
- guint position,
- EphyTabsMenu *menu)
-{
- EphyTabsMenuPrivate *priv = menu->priv;
- GtkAction *action;
- char verb[ACTION_VERB_FORMAT_LENGTH];
-
- LOG ("tab_added_cb embed=%p", embed);
-
- g_snprintf (verb, sizeof (verb), ACTION_VERB_FORMAT, allocate_tab_id ());
-
- action = gtk_action_new (verb, NULL, _("Switch to this tab"), NULL);
-
- sync_tab_title (ephy_embed_get_web_view (embed), NULL, action);
- /* make sure the action is alive when handling the signal, see bug #169833 */
- g_signal_connect_object (ephy_embed_get_web_view (embed), "notify::embed-title",
- G_CALLBACK (sync_tab_title), action, 0);
-
- gtk_action_group_add_action_with_accel (priv->action_group, action, NULL);
-
- g_object_set_data (G_OBJECT (embed), DATA_KEY, action);
- g_object_set_data (G_OBJECT (action), DATA_KEY, embed);
-
- g_signal_connect (action, "activate",
- G_CALLBACK (tab_action_activate_cb), menu);
-
- g_object_unref (action);
-
- ephy_tabs_menu_update (menu);
-}
-
-static void
-notebook_page_removed_cb (EphyNotebook *notebook,
- EphyEmbed *embed,
- guint position,
- EphyTabsMenu *menu)
-{
- EphyTabsMenuPrivate *priv = menu->priv;
- GtkAction *action;
-
- LOG ("tab_removed_cb embed=%p", embed);
-
- action = g_object_get_data (G_OBJECT (embed), DATA_KEY);
- g_return_if_fail (action != NULL);
-
- free_tab_id (action);
-
- g_signal_handlers_disconnect_by_func
- (ephy_embed_get_web_view (embed), G_CALLBACK (sync_tab_title), action);
-
- g_signal_handlers_disconnect_by_func
- (action, G_CALLBACK (tab_action_activate_cb), menu);
-
- g_object_set_data (G_OBJECT (embed), DATA_KEY, NULL);
- gtk_action_group_remove_action (priv->action_group, action);
-
- ephy_tabs_menu_update (menu);
-}
-
-static void
-notebook_page_reordered_cb (EphyNotebook *notebook,
- EphyEmbed *embed,
- guint position,
- EphyTabsMenu *menu)
-{
- LOG ("tabs_reordered_cb");
-
- ephy_tabs_menu_update (menu);
-}
-
-static void
-connect_proxy_cb (GtkActionGroup *action_group,
- GtkAction *action,
- GtkWidget *proxy,
- gpointer dummy)
-{
- if (GTK_IS_MENU_ITEM (proxy))
- {
- GtkLabel *label;
- EphyEmbed *embed;
- EphyWebView *view;
-
- label = GTK_LABEL (gtk_bin_get_child (GTK_BIN (proxy)));
-
- gtk_label_set_use_underline (label, FALSE);
- gtk_label_set_ellipsize (label, PANGO_ELLIPSIZE_END);
- gtk_label_set_max_width_chars (label, LABEL_WIDTH_CHARS);
-
- embed = g_object_get_data (G_OBJECT (action), DATA_KEY);
- view = ephy_embed_get_web_view (embed);
-
- sync_tab_icon (view, NULL, proxy);
- g_signal_connect_object (view, "notify::icon",
- G_CALLBACK (sync_tab_icon), proxy, 0);
- }
-}
-
-static void
-ephy_tabs_menu_set_window (EphyTabsMenu *menu,
- EphyWindow *window)
-{
- EphyTabsMenuPrivate *priv = menu->priv;
- GtkWidget *notebook;
- GtkUIManager *manager;
-
- priv->window = window;
-
- manager = GTK_UI_MANAGER (ephy_window_get_ui_manager (window));
- priv->action_group = gtk_action_group_new ("TabsActions");
- gtk_ui_manager_insert_action_group (manager, priv->action_group, -1);
- g_object_unref (priv->action_group);
-
- priv->anchor_action = g_object_new (GTK_TYPE_RADIO_ACTION,
- "name", "TabsMenuAnchorAction",
- NULL);
- gtk_action_group_add_action (priv->action_group, priv->anchor_action);
- g_object_unref (priv->anchor_action);
-
- g_signal_connect (priv->action_group, "connect-proxy",
- G_CALLBACK (connect_proxy_cb), NULL);
-
- notebook = ephy_window_get_notebook (window);
- g_signal_connect_object (notebook, "page-added",
- G_CALLBACK (notebook_page_added_cb), menu, 0);
- g_signal_connect_object (notebook, "page-removed",
- G_CALLBACK (notebook_page_removed_cb), menu, 0);
- g_signal_connect_object (notebook, "page-reordered",
- G_CALLBACK (notebook_page_reordered_cb), menu, 0);
-}
-
-static void
-ephy_tabs_menu_set_property (GObject *object,
- guint prop_id,
- const GValue *value,
- GParamSpec *pspec)
-{
- EphyTabsMenu *menu = EPHY_TABS_MENU (object);
-
- switch (prop_id)
- {
- case PROP_WINDOW:
- ephy_tabs_menu_set_window (menu, g_value_get_object (value));
- break;
- }
-}
-
-static void
-ephy_tabs_menu_get_property (GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
-{
- /* no readable properties */
- g_return_if_reached ();
-}
-
-static void
-ephy_tabs_menu_class_init (EphyTabsMenuClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- object_class->set_property = ephy_tabs_menu_set_property;
- object_class->get_property = ephy_tabs_menu_get_property;
-
- g_object_class_install_property (object_class,
- PROP_WINDOW,
- g_param_spec_object ("window", NULL, NULL,
- EPHY_TYPE_WINDOW,
- G_PARAM_WRITABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB |
- G_PARAM_CONSTRUCT_ONLY));
-
- g_type_class_add_private (object_class, sizeof (EphyTabsMenuPrivate));
-
- /* We don't want to save accels, so skip them */
- gtk_accel_map_add_filter ("<Actions>/TabsActions/JmpTab*");
-}
-
-static void
-ephy_tabs_menu_init (EphyTabsMenu *menu)
-{
- menu->priv = EPHY_TABS_MENU_GET_PRIVATE (menu);
-}
-
-static void
-ephy_tabs_menu_clean (EphyTabsMenu *menu)
-{
- EphyTabsMenuPrivate *p = menu->priv;
- GtkUIManager *manager = GTK_UI_MANAGER (ephy_window_get_ui_manager (p->window));
-
- if (p->ui_id != 0)
- {
- gtk_ui_manager_remove_ui (manager, p->ui_id);
- gtk_ui_manager_ensure_update (manager);
- p->ui_id = 0;
- }
-}
-
-EphyTabsMenu *
-ephy_tabs_menu_new (EphyWindow *window)
-{
- return EPHY_TABS_MENU (g_object_new (EPHY_TYPE_TABS_MENU,
- "window", window,
- NULL));
-}
-
-static void
-tab_set_action_accelerator (GtkActionGroup *action_group,
- GtkAction *action,
- guint tab_number)
-{
- const char *verb;
- char accel_path[ACCEL_PATH_FORMAT_LENGTH];
- char accel[7];
- gint accel_number;
- guint accel_key;
- GdkModifierType accel_mods;
-
- verb = gtk_action_get_name (action);
-
- /* set the accel path for the menu item */
- g_snprintf (accel_path, sizeof (accel_path),
- ACCEL_PATH_FORMAT, verb);
- gtk_action_set_accel_path (action, accel_path);
-
- /* Only the first ten tabs get accelerators starting from 1 through 0 */
- if (tab_number < 10)
- {
- accel_key = 0;
- accel_number = (tab_number + 1) % 10;
-
- g_snprintf (accel, sizeof (accel), "<alt>%d", accel_number);
-
- gtk_accelerator_parse (accel, &accel_key, &accel_mods);
-
- if (accel_key != 0)
- {
- gtk_accel_map_change_entry (accel_path, accel_key,
- accel_mods, TRUE);
- }
- }
- else
- {
- gtk_accel_map_change_entry (accel_path, 0, 0, TRUE);
- }
-}
-
-static void
-ephy_tabs_menu_update (EphyTabsMenu *menu)
-{
- EphyTabsMenuPrivate *p = menu->priv;
- GtkUIManager *manager;
- GtkAction *action;
- GList *tabs = NULL, *l;
- guint i = 0;
- const char *verb;
-
- LOG ("Rebuilding open tabs menu");
-
- START_PROFILER ("Rebuilding tabs menu")
-
- ephy_tabs_menu_clean (menu);
-
- tabs = ephy_embed_container_get_children (EPHY_EMBED_CONTAINER (p->window));
-
- if (tabs == NULL) return;
-
- manager = GTK_UI_MANAGER (ephy_window_get_ui_manager (p->window));
- p->ui_id = gtk_ui_manager_new_merge_id (manager);
-
- for (l = tabs; l != NULL; l = l->next)
- {
- action = g_object_get_data (G_OBJECT (l->data), DATA_KEY);
- g_return_if_fail (action != NULL);
-
- verb = gtk_action_get_name (action);
-
- tab_set_action_accelerator (p->action_group, action, i++);
-
- gtk_ui_manager_add_ui (manager, p->ui_id,
- "/menubar/TabsMenu/TabsOpen",
- verb, verb,
- GTK_UI_MANAGER_MENUITEM, FALSE);
- }
-
- g_list_free (tabs);
-
- STOP_PROFILER ("Rebuilding tabs menu")
-}
diff --git a/src/ephy-tabs-menu.h b/src/ephy-tabs-menu.h
deleted file mode 100644
index bbff31464..000000000
--- a/src/ephy-tabs-menu.h
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * Copyright © 2003 David Bordoley
- *
- * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- */
-
-#if !defined (__EPHY_EPIPHANY_H_INSIDE__) && !defined (EPIPHANY_COMPILATION)
-#error "Only <epiphany/epiphany.h> can be included directly."
-#endif
-
-#ifndef EPHY_TABS_MENU_H
-#define EPHY_TABS_MENU_H
-
-#include "ephy-window.h"
-
-G_BEGIN_DECLS
-
-#define EPHY_TYPE_TABS_MENU (ephy_tabs_menu_get_type ())
-#define EPHY_TABS_MENU(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), EPHY_TYPE_TABS_MENU, EphyTabsMenu))
-#define EPHY_TABS_MENU_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), EPHY_TYPE_TABS_MENU, EphyTabsMenuClass))
-#define EPHY_IS_TABS_MENU(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), EPHY_TYPE_TABS_MENU))
-#define EPHY_IS_TABS_MENU_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), EPHY_TYPE_TABS_MENU))
-#define EPHY_TABS_MENU_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), EPHY_TYPE_TABS_MENU, EphyTabsMenuClass))
-
-typedef struct _EphyTabsMenu EphyTabsMenu;
-typedef struct _EphyTabsMenuClass EphyTabsMenuClass;
-typedef struct _EphyTabsMenuPrivate EphyTabsMenuPrivate;
-
-struct _EphyTabsMenuClass
-{
- GObjectClass parent_class;
-};
-
-struct _EphyTabsMenu
-{
- GObject parent_object;
-
- /*< private >*/
- EphyTabsMenuPrivate *priv;
-};
-
-GType ephy_tabs_menu_get_type (void);
-
-EphyTabsMenu *ephy_tabs_menu_new (EphyWindow *window);
-
-G_END_DECLS
-
-#endif
diff --git a/src/ephy-window.c b/src/ephy-window.c
index 3dcf58f47..81866f029 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -49,7 +49,6 @@
#include "ephy-shell.h"
#include "ephy-state.h"
#include "ephy-stock-icons.h"
-#include "ephy-tabs-menu.h"
#include "ephy-toolbar.h"
#include "ephy-type-builtins.h"
#include "ephy-web-view.h"
@@ -110,7 +109,6 @@ static const GtkActionEntry ephy_menu_entries [] = {
{ "Bookmarks", NULL, N_("_Bookmarks") },
{ "Go", NULL, N_("_Go") },
{ "Tools", NULL, N_("T_ools") },
- { "Tabs", NULL, N_("_Tabs") },
{ "Help", NULL, N_("_Help") },
{ "Toolbar", NULL, N_("_Toolbars") },
{ "PopupAction", NULL, "" },
@@ -376,6 +374,13 @@ static const struct
{ GDK_KEY_s, GDK_CONTROL_MASK, "FileSaveAs", FALSE },
{ GDK_KEY_R, GDK_CONTROL_MASK |
GDK_SHIFT_MASK, "ViewReload", FALSE },
+ /* Tab navigation */
+ { GDK_KEY_Page_Up, GDK_CONTROL_MASK, "TabsNext", FALSE },
+ { GDK_KEY_Page_Down, GDK_CONTROL_MASK, "TabsPrevious", FALSE },
+ { GDK_KEY_Page_Up, GDK_CONTROL_MASK |
+ GDK_SHIFT_MASK, "TabsMoveRight", FALSE },
+ { GDK_KEY_Page_Down, GDK_CONTROL_MASK |
+ GDK_SHIFT_MASK, "TabsMoveLeft", FALSE },
/* Support all the MSIE tricks as well ;) */
{ GDK_KEY_F5, 0, "ViewReload", FALSE },
{ GDK_KEY_F5, GDK_CONTROL_MASK, "ViewReload", FALSE },
@@ -444,7 +449,6 @@ struct _EphyWindowPrivate
GtkActionGroup *action_group;
GtkActionGroup *popups_action_group;
EphyEncodingMenu *enc_menu;
- EphyTabsMenu *tabs_menu;
GtkNotebook *notebook;
EphyEmbed *active_embed;
EphyFindToolbar *find_toolbar;
@@ -2893,44 +2897,6 @@ ephy_window_set_active_tab (EphyWindow *window, EphyEmbed *new_embed)
}
}
-static void
-update_tabs_menu_sensitivity (EphyWindow *window)
-{
- EphyWindowPrivate *priv = window->priv;
- GtkActionGroup *action_group;
- GtkAction *action;
- GtkNotebook *notebook;
- gboolean wrap_around;
- int page, n_pages;
- gboolean not_first, not_last;
-
- notebook = GTK_NOTEBOOK (priv->notebook);
- action_group = priv->action_group;
- n_pages = gtk_notebook_get_n_pages (notebook);
- page = gtk_notebook_get_current_page (notebook);
- not_first = page > 0;
- not_last = page + 1 < n_pages;
-
- g_object_get (gtk_widget_get_settings (GTK_WIDGET (notebook)),
- "gtk-keynav-wrap-around", &wrap_around,
- NULL);
-
- if (!wrap_around)
- {
- action = gtk_action_group_get_action (action_group, "TabsPrevious");
- gtk_action_set_sensitive (action, not_first);
- action = gtk_action_group_get_action (action_group, "TabsNext");
- gtk_action_set_sensitive (action, not_last);
- }
-
- action = gtk_action_group_get_action (action_group, "TabsMoveLeft");
- gtk_action_set_sensitive (action, not_first);
- action = gtk_action_group_get_action (action_group, "TabsMoveRight");
- gtk_action_set_sensitive (action, not_last);
- action = gtk_action_group_get_action (action_group, "TabsDetach");
- ephy_action_change_sensitivity_flags (action, SENS_FLAG_CHROME, n_pages <= 1);
-}
-
static gboolean
embed_modal_alert_cb (EphyEmbed *embed,
EphyWindow *window)
@@ -3107,8 +3073,6 @@ notebook_page_added_cb (EphyNotebook *notebook,
priv->num_tabs++;
- update_tabs_menu_sensitivity (window);
-
#if 0
g_signal_connect_object (embed, "open-link",
G_CALLBACK (ephy_link_open), window,
@@ -3159,11 +3123,6 @@ notebook_page_removed_cb (EphyNotebook *notebook,
priv->num_tabs--;
- if (priv->num_tabs > 0)
- {
- update_tabs_menu_sensitivity (window);
- }
-
g_signal_handlers_disconnect_by_func
(ephy_embed_get_web_view (embed), G_CALLBACK (embed_modal_alert_cb), window);
g_signal_handlers_disconnect_by_func
@@ -3171,15 +3130,6 @@ notebook_page_removed_cb (EphyNotebook *notebook,
}
static void
-notebook_page_reordered_cb (EphyNotebook *notebook,
- EphyEmbed *embed,
- guint position,
- EphyWindow *window)
-{
- update_tabs_menu_sensitivity (window);
-}
-
-static void
notebook_page_close_request_cb (EphyNotebook *notebook,
EphyEmbed *embed,
EphyWindow *window)
@@ -3248,8 +3198,6 @@ setup_notebook (EphyWindow *window)
G_CALLBACK (notebook_page_added_cb), window);
g_signal_connect (notebook, "page-removed",
G_CALLBACK (notebook_page_removed_cb), window);
- g_signal_connect (notebook, "page-reordered",
- G_CALLBACK (notebook_page_reordered_cb), window);
g_signal_connect (notebook, "tab-close-request",
G_CALLBACK (notebook_page_close_request_cb), window);
@@ -3424,9 +3372,6 @@ ephy_window_dispose (GObject *object)
g_object_unref (priv->enc_menu);
priv->enc_menu = NULL;
- g_object_unref (priv->tabs_menu);
- priv->tabs_menu = NULL;
-
priv->action_group = NULL;
priv->popups_action_group = NULL;
@@ -3775,7 +3720,6 @@ ephy_window_constructor (GType type,
g_object_unref (css_file);
/* Initialize the menus */
- priv->tabs_menu = ephy_tabs_menu_new (window);
priv->enc_menu = ephy_encoding_menu_new (window);
/* Add the toolbars to the window */
@@ -4178,9 +4122,6 @@ notebook_switch_page_cb (GtkNotebook *notebook,
ephy_window_set_active_tab (window, embed);
ephy_find_toolbar_set_embed (priv->find_toolbar, embed);
-
- /* update window controls */
- update_tabs_menu_sensitivity (window);
}
/**