aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog12
-rw-r--r--src/ephy-home-action.c100
-rw-r--r--src/ephy-lockdown.c2
-rwxr-xr-xsrc/ephy-toolbar.c23
-rw-r--r--src/ephy-window.c10
-rw-r--r--src/window-commands.c29
-rw-r--r--src/window-commands.h6
7 files changed, 135 insertions, 47 deletions
diff --git a/ChangeLog b/ChangeLog
index 43bda9854..2c01a3470 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+2006-09-24 Jean-François Rameau <jframeau@cvs.gnome.org>
+
+ * src/ephy-window.c: (ephy_window_constructor):
+ * src/ephy-lockdown.c: (update_window):
+ * src/window-commands.c: (window_cmd_file_new_window), (window_cmd_file_new_tab):
+ * src/window-commands.h: (window_cmd_file_new_window), (window_cmd_file_new_tab):
+ * src/ephy-toolbar.c: (ephy_toolbar_set_window):
+ * src/ephy-home-action.c: (ephy_home_action_activate):
+
+ Add middle-click on New Tab/Window button to open URL on clipboard. Fix bug 149715.
+ Both New Tab and New Window actions are now EphyHomeAction.
+
2006-09-23 Christian Persch <chpe@cvs.gnome.org>
* embed/mozilla/GtkNSSClientAuthDialogs.h:
diff --git a/src/ephy-home-action.c b/src/ephy-home-action.c
index d00315586..672a55f80 100644
--- a/src/ephy-home-action.c
+++ b/src/ephy-home-action.c
@@ -26,17 +26,109 @@
#include "ephy-gui.h"
#include "eel-gconf-extensions.h"
+#include <string.h>
+
+#include <gtk/gtkclipboard.h>
+
+typedef struct
+{
+ GObject *weak_ptr;
+ EphyLinkFlags flags;
+} ClipboardCtx;
+
+static void
+clipboard_text_received_cb (GtkClipboard *clipboard,
+ const char *text,
+ ClipboardCtx *ctx)
+{
+ if (ctx->weak_ptr != NULL && text != NULL)
+ {
+ ephy_link_open (EPHY_LINK (ctx->weak_ptr), text, NULL, ctx->flags);
+ }
+
+ if (ctx->weak_ptr != NULL)
+ {
+ GObject **object = &(ctx->weak_ptr);
+ g_object_remove_weak_pointer (G_OBJECT (ctx->weak_ptr),
+ (gpointer *)object);
+ }
+
+ g_free (ctx);
+}
+
+static void
+ephy_home_action_with_clipboard (GtkAction *action,
+ EphyLinkFlags flags)
+{
+ ClipboardCtx *ctx;
+ GObject **object;
+
+ ctx = g_new (ClipboardCtx, 1);
+ ctx->flags = flags;
+
+ /* We need to make sure we know if the action is destroyed between
+ * requesting the clipboard contents, and receiving them.
+ */
+ ctx->weak_ptr = G_OBJECT (action);
+ object = &(ctx->weak_ptr);
+ g_object_add_weak_pointer (ctx->weak_ptr, (gpointer *)object);
+
+ gtk_clipboard_request_text
+ (gtk_clipboard_get_for_display (gdk_display_get_default(),
+ GDK_SELECTION_PRIMARY),
+ (GtkClipboardTextReceivedFunc) clipboard_text_received_cb,
+ ctx);
+
+}
+
+static void
+ephy_home_action_open (GtkAction *action,
+ const char *address,
+ EphyLinkFlags flags)
+{
+ if (ephy_gui_is_middle_click ())
+ {
+ ephy_home_action_with_clipboard (action, flags);
+ }
+ else /* Left button */
+ {
+ ephy_link_open (EPHY_LINK (action),
+ address != NULL && address[0] != '\0' ? address : "about:blank",
+ NULL,
+ flags);
+ }
+}
+
static void
ephy_home_action_activate (GtkAction *action)
{
+ char *action_name;
char *address;
+ g_object_get (G_OBJECT (action), "name", &action_name, NULL);
+
address = eel_gconf_get_string (CONF_GENERAL_HOMEPAGE);
- ephy_link_open (EPHY_LINK (action),
- address != NULL && address[0] != '\0' ? address : "about:blank",
- NULL,
- ephy_link_flags_from_current_event ());
+ if (strcmp (action_name, "GoHome") == 0)
+ {
+
+ ephy_link_open (EPHY_LINK (action),
+ address != NULL && address[0] != '\0' ? address : "about:blank",
+ NULL,
+ ephy_link_flags_from_current_event ());
+ }
+ else if (strcmp (action_name, "FileNewTab") == 0)
+ {
+ ephy_home_action_open (action,
+ address,
+ EPHY_LINK_NEW_TAB | EPHY_LINK_JUMP_TO);
+ }
+ else if (strcmp (action_name, "FileNewWindow") == 0)
+ {
+ ephy_home_action_open (action,
+ address,
+ EPHY_LINK_NEW_WINDOW);
+ }
g_free (address);
}
diff --git a/src/ephy-lockdown.c b/src/ephy-lockdown.c
index 6c880d413..10753d2af 100644
--- a/src/ephy-lockdown.c
+++ b/src/ephy-lockdown.c
@@ -197,7 +197,7 @@ update_window (EphyWindow *window,
ephy_action_change_sensitivity_flags (action, LOCKDOWN_FLAG, disabled);
fullscreen = eel_gconf_get_boolean (CONF_LOCKDOWN_FULLSCREEN);
- action = gtk_action_group_get_action (action_group, "FileNewWindow");
+ action = gtk_action_group_get_action (toolbar_action_group, "FileNewWindow");
ephy_action_change_sensitivity_flags (action, LOCKDOWN_FLAG, fullscreen);
action = gtk_action_group_get_action (action_group, "ViewFullscreen");
ephy_action_change_sensitivity_flags (action, LOCKDOWN_FLAG, fullscreen);
diff --git a/src/ephy-toolbar.c b/src/ephy-toolbar.c
index 83a89f2a7..60acce052 100755
--- a/src/ephy-toolbar.c
+++ b/src/ephy-toolbar.c
@@ -359,6 +359,29 @@ ephy_toolbar_set_window (EphyToolbar *toolbar,
G_CALLBACK (ephy_link_open), toolbar);
gtk_action_group_add_action_with_accel (priv->action_group, action, "<alt>Home");
g_object_unref (action);
+
+ action = g_object_new (EPHY_TYPE_HOME_ACTION,
+ "name", "FileNewTab",
+ "label", _("New _Tab"),
+ "stock_id", STOCK_NEW_TAB,
+ "tooltip", _("Open a new tab"),
+ NULL);
+ g_signal_connect_swapped (action, "open-link",
+ G_CALLBACK (ephy_link_open), toolbar);
+ gtk_action_group_add_action_with_accel (priv->action_group, action, "<control>T");
+ g_object_unref (action);
+
+ action = g_object_new (EPHY_TYPE_HOME_ACTION,
+ "name", "FileNewWindow",
+ "label", _("_New Window"),
+ "stock_id", STOCK_NEW_WINDOW,
+ "tooltip", _("Open a new window"),
+ NULL);
+ g_signal_connect_swapped (action, "open-link",
+ G_CALLBACK (ephy_link_open), toolbar);
+ gtk_action_group_add_action_with_accel (priv->action_group, action, "<control>N");
+ g_object_unref (action);
+
}
/* public functions */
diff --git a/src/ephy-window.c b/src/ephy-window.c
index 4039f112f..04539f2b9 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -126,12 +126,6 @@ static const GtkActionEntry ephy_menu_entries [] = {
/* File menu */
- { "FileNewWindow", STOCK_NEW_WINDOW, N_("_New Window"), "<control>N",
- N_("Open a new window"),
- G_CALLBACK (window_cmd_file_new_window) },
- { "FileNewTab", STOCK_NEW_TAB, N_("New _Tab"), "<control>T",
- N_("Open a new tab"),
- G_CALLBACK (window_cmd_file_new_tab) },
{ "FileOpen", GTK_STOCK_OPEN, N_("_Open..."), "<control>O",
N_("Open a file"),
G_CALLBACK (window_cmd_file_open) },
@@ -3070,6 +3064,7 @@ ephy_window_constructor (GType type,
EggToolbarsModel *model;
GtkSettings *settings;
GtkAction *action;
+ GtkActionGroup *toolbar_action_group;
GError *error = NULL;
guint settings_connection;
@@ -3204,7 +3199,8 @@ ephy_window_constructor (GType type,
G_CALLBACK (sync_network_status), window);
/* Popup part */
- action = gtk_action_group_get_action (priv->action_group, "FileNewTab");
+ toolbar_action_group = ephy_toolbar_get_action_group (priv->toolbar);
+ action = gtk_action_group_get_action (toolbar_action_group, "FileNewTab");
ephy_action_change_sensitivity_flags (action, SENS_FLAG_CHROME, priv->is_popup);
action = gtk_action_group_get_action (priv->popups_action_group, "OpenLinkInNewTab");
diff --git a/src/window-commands.c b/src/window-commands.c
index c12bfd746..97f15d709 100644
--- a/src/window-commands.c
+++ b/src/window-commands.c
@@ -203,35 +203,6 @@ window_cmd_view_reload (GtkAction *action,
}
void
-window_cmd_file_new_window (GtkAction *action,
- EphyWindow *window)
-{
- EphyTab *tab;
-
- tab = ephy_window_get_active_tab (window);
- g_return_if_fail (tab != NULL);
-
- ephy_shell_new_tab (ephy_shell, window, tab, NULL,
- EPHY_NEW_TAB_NEW_PAGE |
- EPHY_NEW_TAB_IN_NEW_WINDOW);
-}
-
-void
-window_cmd_file_new_tab (GtkAction *action,
- EphyWindow *window)
-{
- EphyTab *tab;
-
- tab = ephy_window_get_active_tab (window);
- g_return_if_fail (tab != NULL);
-
- ephy_shell_new_tab (ephy_shell, window, tab, NULL,
- EPHY_NEW_TAB_NEW_PAGE |
- EPHY_NEW_TAB_IN_EXISTING_WINDOW |
- EPHY_NEW_TAB_JUMP);
-}
-
-void
window_cmd_go_bookmarks (GtkAction *action,
EphyWindow *window)
{
diff --git a/src/window-commands.h b/src/window-commands.h
index b271332bf..f25ddbc46 100644
--- a/src/window-commands.h
+++ b/src/window-commands.h
@@ -43,12 +43,6 @@ void window_cmd_view_reload (GtkAction *action,
void window_cmd_new (GtkAction *action,
EphyWindow *window);
-void window_cmd_file_new_window (GtkAction *action,
- EphyWindow *window);
-
-void window_cmd_file_new_tab (GtkAction *action,
- EphyWindow *window);
-
void window_cmd_file_bookmark_page(GtkAction *action,
EphyWindow *window);