aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ephy-notebook.c53
-rw-r--r--src/ephy-window.c64
-rw-r--r--src/ephy-window.h4
3 files changed, 52 insertions, 69 deletions
diff --git a/src/ephy-notebook.c b/src/ephy-notebook.c
index e37e3cb7f..fe10ca09b 100644
--- a/src/ephy-notebook.c
+++ b/src/ephy-notebook.c
@@ -32,9 +32,10 @@
#include "ephy-embed.h"
#include "ephy-window.h"
#include "ephy-shell.h"
-#include "ephy-debug.h"
#include "ephy-favicon-cache.h"
#include "ephy-spinner.h"
+#include "ephy-link.h"
+#include "ephy-debug.h"
#include <glib-object.h>
#include <gtk/gtkeventbox.h>
@@ -56,6 +57,8 @@
#define AFTER_ALL_TABS -1
#define NOT_IN_APP_WINDOWS -2
+#define INSANE_NUMBER_OF_URLS 20
+
#define EPHY_NOTEBOOK_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_NOTEBOOK, EphyNotebookPrivate))
struct EphyNotebookPrivate
@@ -103,11 +106,11 @@ static GObjectClass *parent_class = NULL;
GType
ephy_notebook_get_type (void)
{
- static GType type = 0;
+ static GType type = 0;
- if (G_UNLIKELY (type == 0))
- {
- static const GTypeInfo our_info =
+ if (G_UNLIKELY (type == 0))
+ {
+ static const GTypeInfo our_info =
{
sizeof (EphyNotebookClass),
NULL, /* base_init */
@@ -120,12 +123,22 @@ ephy_notebook_get_type (void)
(GInstanceInitFunc) ephy_notebook_init
};
- type = g_type_register_static (GTK_TYPE_NOTEBOOK,
- "EphyNotebook",
- &our_info, 0);
- }
+ static const GInterfaceInfo link_info =
+ {
+ NULL,
+ NULL,
+ NULL
+ };
+
+ type = g_type_register_static (GTK_TYPE_NOTEBOOK,
+ "EphyNotebook",
+ &our_info, 0);
+ g_type_add_interface_static (type,
+ EPHY_TYPE_LINK,
+ &link_info);
+ }
- return type;
+ return type;
}
static void
@@ -575,6 +588,7 @@ notebook_drag_data_received_cb (GtkWidget* widget, GdkDragContext *context,
guint info, guint time, EphyTab *tab)
{
EphyWindow *window;
+ GtkWidget *notebook;
g_signal_stop_emission_by_name (widget, "drag_data_received");
@@ -583,33 +597,36 @@ notebook_drag_data_received_cb (GtkWidget* widget, GdkDragContext *context,
if (selection_data->length <= 0 || selection_data->data == NULL) return;
window = EPHY_WINDOW (gtk_widget_get_toplevel (widget));
+ notebook = ephy_window_get_notebook (window);
if (selection_data->target == gdk_atom_intern (EPHY_DND_URL_TYPE, FALSE))
{
- char *uris[2] = { NULL, NULL };
char **split;
/* URL_TYPE has format: url \n title */
split = g_strsplit (selection_data->data, "\n", 2);
- if (split != NULL && split[0] != NULL)
+ if (split != NULL && split[0] != NULL && split[0][0] != '\0')
{
- uris[0] = split[0];
- ephy_window_load_in_tabs (window, tab, uris);
+ ephy_link_open (EPHY_LINK (notebook), split[0], tab,
+ tab ? 0 : EPHY_LINK_NEW_TAB);
}
g_strfreev (split);
}
else if (selection_data->target == gdk_atom_intern (EPHY_DND_URI_LIST_TYPE, FALSE))
{
char **uris;
+ int i;
uris = gtk_selection_data_get_uris (selection_data);
+ if (uris == NULL) return;
- if (uris != NULL)
+ for (i = 0; uris[i] != NULL && i < INSANE_NUMBER_OF_URLS; i++)
{
- ephy_window_load_in_tabs (window, tab, uris);
-
- g_strfreev (uris);
+ tab = ephy_link_open (EPHY_LINK (notebook), uris[i],
+ tab, i == 0 ? 0 : EPHY_LINK_NEW_TAB);
}
+
+ g_strfreev (uris);
}
else
{
diff --git a/src/ephy-window.c b/src/ephy-window.c
index 6d624ab54..58c1b4326 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -343,7 +343,6 @@ static guint ephy_popups_n_entries = G_N_ELEMENTS (ephy_popups_entries);
#define CONF_LOCKDOWN_HIDE_MENUBAR "/apps/epiphany/lockdown/hide_menubar"
#define CONF_DESKTOP_BG_PICTURE "/desktop/gnome/background/picture_filename"
-#define INSANE_NUMBER_OF_URLS 20
#define BOOKMARKS_MENU_PATH "/menubar/BookmarksMenu"
@@ -2418,6 +2417,11 @@ open_link_cb (EphyLink *link,
g_return_val_if_fail (address != NULL, NULL);
+ if (tab == NULL)
+ {
+ tab = ephy_window_get_active_tab (window);
+ }
+
if (flags != 0)
{
EphyNewTabFlags ntflags = EPHY_NEW_TAB_OPEN_PAGE;
@@ -2437,15 +2441,19 @@ open_link_cb (EphyLink *link,
new_tab = ephy_shell_new_tab
(ephy_shell,
- tab ? EPHY_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (tab)))
- : window,
- tab ? tab : ephy_window_get_active_tab (window),
- address, ntflags);
+ EPHY_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (tab))),
+ tab, address, ntflags);
}
else
{
- ephy_window_load_url (window, address);
- new_tab = ephy_window_get_active_tab (window);
+ EphyEmbed *embed;
+
+ embed = ephy_tab_get_embed (tab);
+
+ ephy_embed_load_url (embed, address);
+ ephy_embed_activate (embed);
+
+ new_tab = tab;
}
return new_tab;
@@ -2473,6 +2481,8 @@ ephy_window_init (EphyWindow *window)
setup_ui_manager (window);
window->priv->notebook = setup_notebook (window);
+ g_signal_connect (window->priv->notebook, "open-link",
+ G_CALLBACK (open_link_cb), window);
gtk_box_pack_start (GTK_BOX (window->priv->main_vbox),
GTK_WIDGET (window->priv->notebook),
TRUE, TRUE, 0);
@@ -3132,46 +3142,6 @@ ephy_window_set_zoom (EphyWindow *window,
}
}
-void
-ephy_window_load_in_tabs (EphyWindow *window,
- EphyTab *tab,
- char **uris)
-{
- EphyEmbed *embed = NULL;
- guint num;
-
- g_return_if_fail (uris != NULL);
-
- if (tab != NULL)
- {
- embed = ephy_tab_get_embed (tab);
- g_return_if_fail (EPHY_IS_EMBED (embed));
- }
-
- for (num = 0; uris[num] != NULL && num < INSANE_NUMBER_OF_URLS; num++)
- {
- const char *url = uris[num];
-
- if (num == 0 && embed != NULL)
- {
- /**
- * The first url is special: if the drag was to an
- * existing tab, load it there
- */
- ephy_embed_load_url (embed, url);
- }
- else
- {
- tab = ephy_shell_new_tab (ephy_shell, window,
- tab, url,
- EPHY_NEW_TAB_OPEN_PAGE |
- EPHY_NEW_TAB_IN_EXISTING_WINDOW |
- (tab ? EPHY_NEW_TAB_APPEND_AFTER :
- EPHY_NEW_TAB_APPEND_LAST));
- }
- }
-}
-
static void
sync_prefs_with_chrome (EphyWindow *window)
{
diff --git a/src/ephy-window.h b/src/ephy-window.h
index 73d95b80d..fb0a8180b 100644
--- a/src/ephy-window.h
+++ b/src/ephy-window.h
@@ -89,10 +89,6 @@ void ephy_window_jump_to_tab (EphyWindow *window,
void ephy_window_load_url (EphyWindow *window,
const char *url);
-void ephy_window_load_in_tabs (EphyWindow *window,
- EphyTab *first_tab,
- char **uris);
-
void ephy_window_set_zoom (EphyWindow *window,
float zoom);