aboutsummaryrefslogtreecommitdiffstats
path: root/embed/ephy-web-view.c
diff options
context:
space:
mode:
Diffstat (limited to 'embed/ephy-web-view.c')
-rw-r--r--embed/ephy-web-view.c89
1 files changed, 79 insertions, 10 deletions
diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c
index f49164284..04ffa5c05 100644
--- a/embed/ephy-web-view.c
+++ b/embed/ephy-web-view.c
@@ -76,6 +76,7 @@ struct _EphyWebViewPrivate {
/* Flags */
guint is_blank : 1;
guint is_setting_zoom : 1;
+ guint is_archiving : 1;
guint load_failed : 1;
guint history_frozen : 1;
@@ -111,6 +112,9 @@ struct _EphyWebViewPrivate {
/* TLS information. */
GTlsCertificate *certificate;
GTlsCertificateFlags tls_errors;
+
+ /* Archive cancellable */
+ GCancellable *archive_cancellable;
};
typedef struct {
@@ -133,6 +137,7 @@ enum {
PROP_EMBED_TITLE,
PROP_TYPED_ADDRESS,
PROP_IS_BLANK,
+ PROP_IS_ARCHIVING
};
#define EPHY_WEB_VIEW_GET_PRIVATE(object) (G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_WEB_VIEW, EphyWebViewPrivate))
@@ -403,6 +408,9 @@ ephy_web_view_get_property (GObject *object,
case PROP_IS_BLANK:
g_value_set_boolean (value, priv->is_blank);
break;
+ case PROP_IS_ARCHIVING:
+ g_value_set_boolean (value, priv->is_archiving);
+ break;
default:
break;
}
@@ -432,6 +440,7 @@ ephy_web_view_set_property (GObject *object,
case PROP_STATUS_MESSAGE:
case PROP_EMBED_TITLE:
case PROP_IS_BLANK:
+ case PROP_IS_ARCHIVING:
/* read only */
break;
default:
@@ -681,6 +690,11 @@ ephy_web_view_dispose (GObject *object)
g_clear_object(&priv->certificate);
+ if (priv->archive_cancellable) {
+ g_cancellable_cancel (priv->archive_cancellable);
+ g_clear_object (&priv->archive_cancellable);
+ }
+
G_OBJECT_CLASS (ephy_web_view_parent_class)->dispose (object);
}
@@ -1062,6 +1076,19 @@ ephy_web_view_class_init (EphyWebViewClass *klass)
G_PARAM_READABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB));
/**
+ * EphyWebView:is-archiving:
+ *
+ * Whether the view is archiving files.
+ **/
+ g_object_class_install_property (gobject_class,
+ PROP_IS_ARCHIVING,
+ g_param_spec_boolean ("is-archiving",
+ "Is archiving",
+ "If the EphyWebView is archiving",
+ FALSE,
+ G_PARAM_READABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB));
+
+/**
* EphyWebView::new-window:
* @view: the #EphyWebView that received the signal
* @new_view: the newly opened #EphyWebView
@@ -1891,7 +1918,6 @@ typedef struct {
typedef struct {
FileChooserInfo *info;
- GCancellable *cancellable;
GPtrArray *wk_filenames;
GSList *filenames;
char *dest;
@@ -1930,8 +1956,6 @@ archive_info_free (ArchiveInfo *ainfo)
{
if (ainfo->info != NULL)
g_free (ainfo->info);
- if (ainfo->cancellable != NULL)
- g_object_unref (ainfo->cancellable);
if (ainfo->wk_filenames != NULL)
g_ptr_array_unref (ainfo->wk_filenames);
if (ainfo->filenames != NULL)
@@ -1966,6 +1990,8 @@ run_file_chooser_cancel (ArchiveInfo *ainfo, GError *error, const char *reason)
gtk_widget_destroy (error_dialog);
}
+ web_view->priv->is_archiving = FALSE;
+ g_cancellable_reset (web_view->priv->archive_cancellable);
archive_info_free (ainfo);
}
@@ -1983,6 +2009,8 @@ run_file_chooser_complete (ArchiveInfo *ainfo)
web_view->priv->status_message = NULL;
g_object_notify (G_OBJECT (web_view), "status-message");
+ web_view->priv->is_archiving = FALSE;
+ g_cancellable_reset (web_view->priv->archive_cancellable);
archive_info_free (ainfo);
}
@@ -2003,12 +2031,14 @@ run_file_chooser_next (ArchiveInfo *ainfo, gboolean add_to_wk_filenames)
run_file_chooser_complete (ainfo);
} else {
GFile *file;
+ EphyWebView *web_view;
file = g_file_new_for_path (ainfo->filenames->data);
+ web_view = EPHY_WEB_VIEW (ainfo->info->web_view);
g_file_query_info_async (file,
G_FILE_ATTRIBUTE_STANDARD_TYPE,
G_FILE_QUERY_INFO_NONE,
G_PRIORITY_DEFAULT,
- ainfo->cancellable,
+ web_view->priv->archive_cancellable,
(GAsyncReadyCallback)file_query_info_cb,
ainfo);
}
@@ -2069,6 +2099,7 @@ file_query_info_cb (GFile *file,
GAsyncResult *res,
ArchiveInfo *ainfo)
{
+ EphyWebView *web_view;
GFileInfo *file_info;
GFileType file_type;
GError *error;
@@ -2083,6 +2114,12 @@ file_query_info_cb (GFile *file,
return;
}
+ web_view = EPHY_WEB_VIEW (ainfo->info->web_view);
+ if (g_cancellable_is_cancelled (web_view->priv->archive_cancellable)) {
+ run_file_chooser_cancel (ainfo, NULL, NULL);
+ return;
+ }
+
file_type = g_file_info_get_file_type (file_info);
if (file_type == G_FILE_TYPE_DIRECTORY) {
AutoarCreate *arcreate;
@@ -2105,7 +2142,7 @@ file_query_info_cb (GFile *file,
g_signal_connect (arcreate, "error",
G_CALLBACK (archive_error_cb), ainfo);
- autoar_create_start_async (arcreate, ainfo->cancellable);
+ autoar_create_start_async (arcreate, web_view->priv->archive_cancellable);
g_object_unref (arcreate);
g_free (output);
g_free (tmp);
@@ -2120,21 +2157,27 @@ run_file_chooser_response_cb (GtkFileChooser *file_chooser,
int response_id,
FileChooserInfo *info)
{
+ EphyWebView *web_view;
+ GCancellable *cancellable;
+
+ web_view = EPHY_WEB_VIEW (info->web_view);
+ cancellable = web_view->priv->archive_cancellable;
+ g_cancellable_reset (cancellable);
+
if (response_id == GTK_RESPONSE_OK || response_id == EPHY_RESPONSE_SELECT) {
ArchiveInfo *ainfo;
- GCancellable *cancellable;
GSList *filenames, *iter;
int format, filter;
int c;
+ web_view->priv->is_archiving = TRUE;
+
filenames = gtk_file_chooser_get_filenames (file_chooser);
autoar_gtk_format_filter_simple_get (info->format, &format, &filter);
for (iter = filenames, c = 0; iter != NULL; iter = iter->next, c++);
- cancellable = g_cancellable_new ();
ainfo = g_new (ArchiveInfo, 1);
ainfo->info = info;
- ainfo->cancellable = g_object_ref (cancellable);
ainfo->wk_filenames = g_ptr_array_new_with_free_func (g_free);
ainfo->filenames = NULL;
ainfo->dest = NULL;
@@ -2204,8 +2247,6 @@ run_file_chooser_response_cb (GtkFileChooser *file_chooser,
ainfo);
}
- g_object_unref (cancellable);
-
} else {
webkit_file_chooser_request_cancel (info->request);
file_chooser_info_free (info);
@@ -2464,6 +2505,7 @@ ephy_web_view_init (EphyWebView *web_view)
priv = web_view->priv = EPHY_WEB_VIEW_GET_PRIVATE (web_view);
priv->is_blank = TRUE;
+ priv->is_archiving = TRUE;
priv->title = g_strdup (EMPTY_PAGE);
priv->document_type = EPHY_WEB_VIEW_DOCUMENT_HTML;
priv->security_level = EPHY_WEB_VIEW_STATE_IS_UNKNOWN;
@@ -2478,6 +2520,7 @@ ephy_web_view_init (EphyWebView *web_view)
priv->history_service = EPHY_HISTORY_SERVICE (ephy_embed_shell_get_global_history_service (ephy_embed_shell_get_default ()));
priv->history_service_cancellable = g_cancellable_new ();
+ priv->archive_cancellable = g_cancellable_new ();
g_signal_connect (priv->history_service,
"cleared", G_CALLBACK (ephy_web_view_history_cleared_cb),
@@ -2806,6 +2849,32 @@ ephy_web_view_get_is_blank (EphyWebView *view)
}
/**
+ * ephy_web_view_get_is_archiving:
+ * @view: an #EphyWebView
+ *
+ * Returns whether the @view is archiving files.
+ *
+ * Return value: %TRUE if the @view is archiving files.
+ **/
+gboolean
+ephy_web_view_get_is_archiving (EphyWebView *view)
+{
+ return view->priv->is_archiving;
+}
+
+/**
+ * ephy_web_view_cancel_archiving:
+ * @view: an #EphyWebView
+ *
+ * Cancel the @view's archive work.
+ **/
+void
+ephy_web_view_cancel_archiving (EphyWebView *view)
+{
+ g_cancellable_cancel (view->priv->archive_cancellable);
+}
+
+/**
* ephy_web_view_get_address:
* @view: an #EphyWebView
*