diff options
-rw-r--r-- | src/ephy-session.c | 158 | ||||
-rw-r--r-- | src/ephy-session.h | 5 | ||||
-rw-r--r-- | src/ephy-shell.c | 138 | ||||
-rw-r--r-- | src/ephy-shell.h | 4 | ||||
-rw-r--r-- | tests/ephy-session-test.c | 2 |
5 files changed, 142 insertions, 165 deletions
diff --git a/src/ephy-session.c b/src/ephy-session.c index 3abda1eb6..b9d9c4d50 100644 --- a/src/ephy-session.c +++ b/src/ephy-session.c @@ -32,6 +32,7 @@ #include "ephy-gui.h" #include "ephy-prefs.h" #include "ephy-settings.h" +#include "ephy-shell.h" #include "ephy-string.h" #include "ephy-window.h" @@ -44,7 +45,6 @@ struct _EphySessionPrivate { - guint open_uris_idle_id; GCancellable *save_cancellable; guint dont_save : 1; }; @@ -164,144 +164,6 @@ notebook_page_reordered_cb (GtkWidget *notebook, ephy_session_save (session, SESSION_STATE); } -typedef struct { - EphySession *session; - EphyWindow *window; - char **uris; - EphyNewTabFlags flags; - guint32 user_time; - guint current_uri; -} OpenURIsData; - -static OpenURIsData * -open_uris_data_new (EphySession *session, - const char **uris, - EphyStartupFlags startup_flags, - guint32 user_time) -{ - OpenURIsData *data; - EphyShell *shell; - gboolean new_windows_in_tabs; - gboolean have_uris; - - shell = ephy_shell_get_default (); - - data = g_slice_new0 (OpenURIsData); - data->session = g_object_ref (session); - data->uris = g_strdupv ((char **)uris); - data->user_time = user_time; - - data->window = ephy_shell_get_main_window (shell); - - new_windows_in_tabs = g_settings_get_boolean (EPHY_SETTINGS_MAIN, - EPHY_PREFS_NEW_WINDOWS_IN_TABS); - - have_uris = ! (g_strv_length ((char **)uris) == 1 && g_str_equal (uris[0], "")); - - if (startup_flags & EPHY_STARTUP_NEW_TAB) - { - data->flags |= EPHY_NEW_TAB_FROM_EXTERNAL; - } - if (startup_flags & EPHY_STARTUP_NEW_WINDOW) - { - data->window = NULL; - data->flags |= EPHY_NEW_TAB_IN_NEW_WINDOW; - } - else if (startup_flags & EPHY_STARTUP_NEW_TAB || (new_windows_in_tabs && have_uris)) - { - data->flags |= EPHY_NEW_TAB_IN_EXISTING_WINDOW | EPHY_NEW_TAB_JUMP | EPHY_NEW_TAB_PRESENT_WINDOW; - } - else if (!have_uris) - { - data->window = NULL; - data->flags |= EPHY_NEW_TAB_IN_NEW_WINDOW; - } - - g_application_hold (G_APPLICATION (shell)); - - return data; -} - -static void -open_uris_data_free (OpenURIsData *data) -{ - g_application_release (G_APPLICATION (ephy_shell_get_default ())); - g_object_unref (data->session); - g_strfreev (data->uris); - - g_slice_free (OpenURIsData, data); -} - -static gboolean -ephy_session_open_uris_idle (OpenURIsData *data) -{ - EphyEmbed *embed; - EphyNewTabFlags page_flags; - const char *url; -#ifdef HAVE_WEBKIT2 - WebKitURIRequest *request = NULL; -#else - WebKitNetworkRequest *request = NULL; -#endif - - url = data->uris[data->current_uri]; - if (url[0] == '\0') - { - page_flags = EPHY_NEW_TAB_HOME_PAGE; - } - else - { - page_flags = EPHY_NEW_TAB_OPEN_PAGE; -#ifdef HAVE_WEBKIT2 - request = webkit_uri_request_new (url); -#else - request = webkit_network_request_new (url); -#endif - } - - embed = ephy_shell_new_tab_full (ephy_shell_get_default (), - data->window, - NULL /* parent tab */, - request, - data->flags | page_flags, - EPHY_WEB_VIEW_CHROME_ALL, - FALSE /* is popup? */, - data->user_time); - - if (request) - { - g_object_unref (request); - } - - data->window = EPHY_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (embed))); - data->current_uri++; - - return data->uris[data->current_uri] != NULL; -} - -static void -ephy_session_open_uris_idle_done (OpenURIsData *data) -{ - data->session->priv->open_uris_idle_id = 0; - open_uris_data_free (data); -} - -void -ephy_session_open_uris (EphySession *session, - const char **uris, - EphyStartupFlags startup_flags, - guint32 user_time) -{ - if (session->priv->open_uris_idle_id == 0) - { - session->priv->open_uris_idle_id = - g_idle_add_full (G_PRIORITY_DEFAULT_IDLE, - (GSourceFunc)ephy_session_open_uris_idle, - open_uris_data_new (session, uris, startup_flags, user_time), - (GDestroyNotify)ephy_session_open_uris_idle_done); - } -} - static void session_maybe_open_window (EphySession *session, guint32 user_time) @@ -393,28 +255,10 @@ ephy_session_init (EphySession *session) } static void -ephy_session_dispose (GObject *object) -{ - EphySession *session = EPHY_SESSION (object); - - LOG ("EphySession disposing"); - - if (session->priv->open_uris_idle_id > 0) - { - g_source_remove (session->priv->open_uris_idle_id); - session->priv->open_uris_idle_id = 0; - } - - G_OBJECT_CLASS (ephy_session_parent_class)->dispose (object); -} - -static void ephy_session_class_init (EphySessionClass *class) { GObjectClass *object_class = G_OBJECT_CLASS (class); - object_class->dispose = ephy_session_dispose; - g_type_class_add_private (object_class, sizeof (EphySessionPrivate)); } diff --git a/src/ephy-session.h b/src/ephy-session.h index 32012bd75..6f3b36c4e 100644 --- a/src/ephy-session.h +++ b/src/ephy-session.h @@ -26,7 +26,6 @@ #ifndef EPHY_SESSION_H #define EPHY_SESSION_H -#include "ephy-shell.h" #include "ephy-window.h" #include <gtk/gtk.h> @@ -64,10 +63,6 @@ struct _EphySessionClass GType ephy_session_get_type (void); -void ephy_session_open_uris (EphySession *session, - const char **uris, - EphyStartupFlags startup_flags, - guint32 user_time); void ephy_session_save (EphySession *session, const char *filename); void ephy_session_load (EphySession *session, diff --git a/src/ephy-shell.c b/src/ephy-shell.c index 42209bd5c..5236f2aff 100644 --- a/src/ephy-shell.c +++ b/src/ephy-shell.c @@ -64,6 +64,7 @@ struct _EphyShellPrivate { GList *del_on_exit; EphyShellStartupContext *startup_context; guint embed_single_connected : 1; + guint open_uris_idle_id; }; EphyShell *ephy_shell = NULL; @@ -129,8 +130,8 @@ ephy_shell_startup_continue (EphyShell *shell) else if (ctx->arguments != NULL) { /* Don't queue any window openings if no extra arguments given, */ /* since session autoresume will open one for us. */ - ephy_session_open_uris (session, (const char **)ctx->arguments, - ctx->startup_flags, ctx->user_time); + ephy_shell_open_uris (shell, (const char **)ctx->arguments, + ctx->startup_flags, ctx->user_time); } } @@ -690,6 +691,11 @@ ephy_shell_dispose (GObject *object) priv->windows = NULL; } + if (priv->open_uris_idle_id > 0) { + g_source_remove (priv->open_uris_idle_id); + priv->open_uris_idle_id = 0; + } + G_OBJECT_CLASS (ephy_shell_parent_class)->dispose (object); } @@ -1151,3 +1157,131 @@ ephy_shell_close_all_windows (EphyShell *shell) return retval; } + +typedef struct { + EphyShell *shell; + EphySession *session; + EphyWindow *window; + char **uris; + EphyNewTabFlags flags; + guint32 user_time; + guint current_uri; +} OpenURIsData; + +static OpenURIsData * +open_uris_data_new (EphyShell *shell, + const char **uris, + EphyStartupFlags startup_flags, + guint32 user_time) +{ + OpenURIsData *data; + gboolean new_windows_in_tabs; + gboolean have_uris; + + data = g_slice_new0 (OpenURIsData); + data->shell = shell; + data->session = g_object_ref (ephy_shell_get_session (shell)); + data->uris = g_strdupv ((char **)uris); + data->user_time = user_time; + + data->window = ephy_shell_get_main_window (shell); + + new_windows_in_tabs = g_settings_get_boolean (EPHY_SETTINGS_MAIN, + EPHY_PREFS_NEW_WINDOWS_IN_TABS); + + have_uris = ! (g_strv_length ((char **)uris) == 1 && g_str_equal (uris[0], "")); + + if (startup_flags & EPHY_STARTUP_NEW_TAB) + data->flags |= EPHY_NEW_TAB_FROM_EXTERNAL; + + if (startup_flags & EPHY_STARTUP_NEW_WINDOW) { + data->window = NULL; + data->flags |= EPHY_NEW_TAB_IN_NEW_WINDOW; + } else if (startup_flags & EPHY_STARTUP_NEW_TAB || (new_windows_in_tabs && have_uris)) { + data->flags |= EPHY_NEW_TAB_IN_EXISTING_WINDOW | EPHY_NEW_TAB_JUMP | EPHY_NEW_TAB_PRESENT_WINDOW; + } else if (!have_uris) { + data->window = NULL; + data->flags |= EPHY_NEW_TAB_IN_NEW_WINDOW; + } + + g_application_hold (G_APPLICATION (shell)); + + return data; +} + +static void +open_uris_data_free (OpenURIsData *data) +{ + g_application_release (G_APPLICATION (data->shell)); + g_object_unref (data->session); + g_strfreev (data->uris); + + g_slice_free (OpenURIsData, data); +} + +static gboolean +ephy_shell_open_uris_idle (OpenURIsData *data) +{ + EphyEmbed *embed; + EphyNewTabFlags page_flags; + const char *url; +#ifdef HAVE_WEBKIT2 + WebKitURIRequest *request = NULL; +#else + WebKitNetworkRequest *request = NULL; +#endif + + url = data->uris[data->current_uri]; + if (url[0] == '\0') { + page_flags = EPHY_NEW_TAB_HOME_PAGE; + } else { + page_flags = EPHY_NEW_TAB_OPEN_PAGE; +#ifdef HAVE_WEBKIT2 + request = webkit_uri_request_new (url); +#else + request = webkit_network_request_new (url); +#endif + } + + embed = ephy_shell_new_tab_full (ephy_shell_get_default (), + data->window, + NULL /* parent tab */, + request, + data->flags | page_flags, + EPHY_WEB_VIEW_CHROME_ALL, + FALSE /* is popup? */, + data->user_time); + + if (request) + g_object_unref (request); + + data->window = EPHY_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (embed))); + data->current_uri++; + + return data->uris[data->current_uri] != NULL; +} + +static void +ephy_shell_open_uris_idle_done (OpenURIsData *data) +{ + data->shell->priv->open_uris_idle_id = 0; + open_uris_data_free (data); +} + +void +ephy_shell_open_uris (EphyShell *shell, + const char **uris, + EphyStartupFlags startup_flags, + guint32 user_time) +{ + g_return_if_fail (EPHY_IS_SHELL (shell)); + + if (shell->priv->open_uris_idle_id == 0) { + shell->priv->open_uris_idle_id = + g_idle_add_full (G_PRIORITY_DEFAULT_IDLE, + (GSourceFunc)ephy_shell_open_uris_idle, + open_uris_data_new (shell, uris, startup_flags, user_time), + (GDestroyNotify)ephy_shell_open_uris_idle_done); + } +} + diff --git a/src/ephy-shell.h b/src/ephy-shell.h index 057d7cbe5..5d0ca9fe8 100644 --- a/src/ephy-shell.h +++ b/src/ephy-shell.h @@ -180,6 +180,10 @@ EphyWindow *ephy_shell_get_main_window (EphyShell *shell); gboolean ephy_shell_close_all_windows (EphyShell *shell); +void ephy_shell_open_uris (EphyShell *shell, + const char **uris, + EphyStartupFlags startup_flags, + guint32 user_time); G_END_DECLS #endif diff --git a/tests/ephy-session-test.c b/tests/ephy-session-test.c index 5c9863245..6fb2c6eab 100644 --- a/tests/ephy-session-test.c +++ b/tests/ephy-session-test.c @@ -237,7 +237,7 @@ open_uris_after_loading_session (const char** uris, int final_num_windows) * command - it should bail after noticing there are windows * already. */ - ephy_session_open_uris (session, uris, 0, user_time); + ephy_shell_open_uris (ephy_shell_get_default (), uris, 0, user_time); while (gtk_events_pending ()) gtk_main_iteration_do (FALSE); |