diff options
-rw-r--r-- | src/ephy-session.c | 42 |
1 files changed, 20 insertions, 22 deletions
diff --git a/src/ephy-session.c b/src/ephy-session.c index d4b9a6837..47dfe08bd 100644 --- a/src/ephy-session.c +++ b/src/ephy-session.c @@ -831,30 +831,28 @@ write_ephy_window (xmlTextWriterPtr writer, } static void -session_save_finished (EphySession *session) +save_session_in_thread_cb (GObject *source_object, + GAsyncResult *res, + gpointer user_data) { g_application_release (G_APPLICATION (ephy_shell_get_default ())); } -static gboolean -save_session_in_thread (GIOSchedulerJob *job, - GCancellable *cancellable, - gpointer user_data) +static void +save_session_sync (GTask *task, + gpointer source_object, + gpointer task_data, + GCancellable *cancellable) { - SaveData *data = (SaveData *)user_data; + SaveData *data = (SaveData *)g_task_get_task_data (task); xmlBufferPtr buffer; xmlTextWriterPtr writer; GList *w; - int ret; + int ret = -1; buffer = xmlBufferCreate (); writer = xmlNewTextWriterMemory (buffer, 0); - if (writer == NULL) - { - xmlBufferFree (buffer); - - return FALSE; - } + if (writer == NULL) goto out; ret = xmlTextWriterSetIndent (writer, 1); if (ret < 0) goto out; @@ -884,7 +882,8 @@ save_session_in_thread (GIOSchedulerJob *job, ret = xmlTextWriterEndDocument (writer); out: - xmlFreeTextWriter (writer); + if (writer) + xmlFreeTextWriter (writer); if (ret >= 0 && !g_cancellable_is_cancelled (cancellable)) { @@ -906,14 +905,9 @@ out: xmlBufferFree (buffer); - g_io_scheduler_job_send_to_mainloop_async (job, - (GSourceFunc) session_save_finished, - g_object_ref (data->session), - (GDestroyNotify) g_object_unref); + g_task_return_boolean (task, TRUE); STOP_PROFILER ("Saving session") - - return FALSE; } void @@ -923,6 +917,7 @@ ephy_session_save (EphySession *session, EphySessionPrivate *priv; EphyShell *shell; SaveData *data; + GTask *task; g_return_if_fail (EPHY_IS_SESSION (session)); @@ -953,8 +948,11 @@ ephy_session_save (EphySession *session, priv->save_cancellable = g_cancellable_new (); data = save_data_new (session, filename); g_application_hold (G_APPLICATION (shell)); - g_io_scheduler_push_job (save_session_in_thread, data, (GDestroyNotify)save_data_free, - G_PRIORITY_DEFAULT, priv->save_cancellable); + + task = g_task_new (session, priv->save_cancellable, + save_session_in_thread_cb, NULL); + g_task_set_task_data (task, data, (GDestroyNotify)save_data_free); + g_task_run_in_thread (task, save_session_sync); } static void |