aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-tab.c
diff options
context:
space:
mode:
authorCosimo Cecchi <cosimoc@src.gnome.org>2007-11-05 06:48:27 +0800
committerCosimo Cecchi <cosimoc@src.gnome.org>2007-11-05 06:48:27 +0800
commita5b20741d26dff5f0bb702455e0e4aee366b5686 (patch)
tree64e343d56bebdfff7a696d0b74840c04cf0cc1d4 /src/ephy-tab.c
parentedd96383847c6e7fcb9bf0d41b0a08c6e52fb06f (diff)
downloadgsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.tar
gsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.tar.gz
gsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.tar.bz2
gsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.tar.lz
gsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.tar.xz
gsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.tar.zst
gsoc2013-epiphany-a5b20741d26dff5f0bb702455e0e4aee366b5686.zip
Moved dom_mouse_click from EphyTab to EphyWindow.
This also makes Modifiers+Click shortcuts work again. svn path=/trunk/; revision=7621
Diffstat (limited to 'src/ephy-tab.c')
-rw-r--r--src/ephy-tab.c175
1 files changed, 0 insertions, 175 deletions
diff --git a/src/ephy-tab.c b/src/ephy-tab.c
index 3d7d86d36..8a3a7119a 100644
--- a/src/ephy-tab.c
+++ b/src/ephy-tab.c
@@ -36,7 +36,6 @@
#include "ephy-file-helpers.h"
#include "ephy-zoom.h"
#include "ephy-favicon-cache.h"
-#include "ephy-embed-persist.h"
#include "ephy-history.h"
#include "ephy-embed-shell.h"
#include "ephy-embed-single.h"
@@ -405,176 +404,6 @@ ephy_tab_set_size (EphyTab *tab,
/* Private callbacks for embed signals */
-static gboolean
-open_link_in_new (EphyTab *tab,
- const char *link_address,
- guint state)
-{
- EphyTab *dest;
-
- if (!address_has_web_scheme (link_address)) return FALSE;
-
- dest = ephy_link_open (EPHY_LINK (tab), link_address, tab,
- state & GDK_SHIFT_MASK ? EPHY_LINK_NEW_WINDOW
- : EPHY_LINK_NEW_TAB);
-
- if (dest)
- {
- ephy_embed_shistory_copy (ephy_tab_get_embed (tab),
- ephy_tab_get_embed (dest),
- TRUE, /* back history */
- FALSE, /* forward history */
- FALSE); /* current index */
- return TRUE;
- }
-
- return FALSE;
-}
-
-static gboolean
-save_property_url (EphyEmbed *embed,
- EphyEmbedEvent *event,
- const char *property,
- const char *key)
-{
- const char *location;
- const GValue *value;
- EphyEmbedPersist *persist;
-
- value = ephy_embed_event_get_property (event, property);
- location = g_value_get_string (value);
-
- if (!address_has_web_scheme (location)) return FALSE;
-
- persist = EPHY_EMBED_PERSIST
- (ephy_embed_factory_new_object (EPHY_TYPE_EMBED_PERSIST));
-
- ephy_embed_persist_set_embed (persist, embed);
- ephy_embed_persist_set_flags (persist, 0);
- ephy_embed_persist_set_persist_key (persist, key);
- ephy_embed_persist_set_source (persist, location);
-
- ephy_embed_persist_save (persist);
-
- g_object_unref (G_OBJECT(persist));
-
- return TRUE;
-}
-
-static void
-clipboard_text_received_cb (GtkClipboard *clipboard,
- const char *text,
- gpointer *weak_ptr)
-{
- if (*weak_ptr != NULL && text != NULL)
- {
- EphyEmbed *embed = (EphyEmbed *) *weak_ptr;
- EphyTab *tab = ephy_tab_for_embed (embed);
-
- ephy_link_open (EPHY_LINK (tab), text, tab, 0);
- }
-
- if (*weak_ptr != NULL)
- {
- g_object_remove_weak_pointer (G_OBJECT (*weak_ptr), weak_ptr);
- }
-
- g_free (weak_ptr);
-}
-
-static gboolean
-ephy_tab_dom_mouse_click_cb (EphyEmbed *embed,
- EphyEmbedEvent *event,
- EphyTab *tab)
-{
- EphyEmbedEventContext context;
- guint button, modifier;
- gboolean handled = TRUE;
- gboolean with_control, with_shift, with_shift_control;
- gboolean is_left_click, is_middle_click;
- gboolean is_link, is_image, is_middle_clickable;
- gboolean middle_click_opens;
- gboolean is_input;
-
- g_return_val_if_fail (EPHY_IS_EMBED_EVENT(event), FALSE);
-
- button = ephy_embed_event_get_button (event);
- context = ephy_embed_event_get_context (event);
- modifier = ephy_embed_event_get_modifier (event);
-
- LOG ("ephy_tab_dom_mouse_click_cb: button %d, context %x, modifier %x",
- button, context, modifier);
-
- with_control = (modifier & GDK_CONTROL_MASK) == GDK_CONTROL_MASK;
- with_shift = (modifier & GDK_SHIFT_MASK) == GDK_SHIFT_MASK;
- with_shift_control = (modifier & (GDK_SHIFT_MASK | GDK_CONTROL_MASK)) == (GDK_SHIFT_MASK | GDK_CONTROL_MASK);
- is_left_click = (button == 1);
- is_middle_click = (button == 2);
-
- middle_click_opens =
- eel_gconf_get_boolean (CONF_INTERFACE_MIDDLE_CLICK_OPEN_URL) &&
- !eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_ARBITRARY_URL);
-
- is_link = (context & EPHY_EMBED_CONTEXT_LINK) != 0;
- is_image = (context & EPHY_EMBED_CONTEXT_IMAGE) != 0;
- is_middle_clickable = !((context & EPHY_EMBED_CONTEXT_LINK)
- || (context & EPHY_EMBED_CONTEXT_INPUT)
- || (context & EPHY_EMBED_CONTEXT_EMAIL_LINK));
- is_input = (context & EPHY_EMBED_CONTEXT_INPUT) != 0;
-
- /* ctrl+click or middle click opens the link in new tab */
- if (is_link &&
- ((is_left_click && (with_control || with_shift_control)) ||
- is_middle_click))
- {
- const GValue *value;
- const char *link_address;
-
- value = ephy_embed_event_get_property (event, "link");
- link_address = g_value_get_string (value);
- handled = open_link_in_new (tab, link_address, modifier);
- }
- /* shift+click saves the link target */
- else if (is_link && is_left_click && with_shift)
- {
- handled = save_property_url (embed, event, "link", CONF_STATE_SAVE_DIR);
- }
- /* shift+click saves the non-link image
- * Note: pressing enter to submit a form synthesizes a mouse click event
- */
- else if (is_image && is_left_click && with_shift && !is_input)
- {
- handled = save_property_url (embed, event, "image", CONF_STATE_SAVE_IMAGE_DIR);
- }
- /* middle click opens the selection url */
- else if (is_middle_clickable && is_middle_click && middle_click_opens)
- {
- /* See bug #133633 for why we do it this way */
-
- /* We need to make sure we know if the embed is destroyed between
- * requesting the clipboard contents, and receiving them.
- */
- gpointer *weak_ptr;
-
- weak_ptr = g_new (gpointer, 1);
- *weak_ptr = embed;
- g_object_add_weak_pointer (G_OBJECT (embed), weak_ptr);
-
- gtk_clipboard_request_text
- (gtk_widget_get_clipboard (GTK_WIDGET (embed),
- GDK_SELECTION_PRIMARY),
- (GtkClipboardTextReceivedFunc) clipboard_text_received_cb,
- weak_ptr);
- }
- /* we didn't handle the event */
- else
- {
- handled = FALSE;
- }
-
- return handled;
-}
-
static void
ephy_tab_init (EphyTab *tab)
{
@@ -593,8 +422,4 @@ ephy_tab_init (EphyTab *tab)
gtk_container_add (GTK_CONTAINER (tab), GTK_WIDGET (embed));
gtk_widget_show (GTK_WIDGET (embed));
-
- g_signal_connect_object (embed, "ge_dom_mouse_click",
- G_CALLBACK (ephy_tab_dom_mouse_click_cb),
- tab, 0);
}