summaryrefslogtreecommitdiff
path: root/daemon/gvfshttpinputstream.c
diff options
context:
space:
mode:
authorRoss Lagerwall <rosslagerwall@gmail.com>2013-12-08 12:44:06 +0200
committerRoss Lagerwall <rosslagerwall@gmail.com>2013-12-08 13:15:57 +0200
commit0ea226568dec4ff8738c835e68dce3c98501cefb (patch)
tree69c0ecd99124e60261fd72309e15c6019a2df260 /daemon/gvfshttpinputstream.c
parent02144460d8af7de84e5b1be071a84adc866f283f (diff)
downloadgvfs-0ea226568dec4ff8738c835e68dce3c98501cefb.tar.gz
http: Fix segfault when seeking on read
Previously, the dav backend would segfault when reading after a seek (or also if you did a read_async() without an explicit send()/send_async() first) because the stream from soup_request_send_finish() was not being stored, so store it. https://bugzilla.gnome.org/show_bug.cgi?id=710534
Diffstat (limited to 'daemon/gvfshttpinputstream.c')
-rw-r--r--daemon/gvfshttpinputstream.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/daemon/gvfshttpinputstream.c b/daemon/gvfshttpinputstream.c
index 85c997ac..5cee9578 100644
--- a/daemon/gvfshttpinputstream.c
+++ b/daemon/gvfshttpinputstream.c
@@ -328,7 +328,8 @@ read_send_callback (GObject *object,
ReadAfterSendData *rasd = g_task_get_task_data (task);
GError *error = NULL;
- if (!soup_request_send_finish (SOUP_REQUEST (object), result, &error))
+ priv->stream = soup_request_send_finish (SOUP_REQUEST (object), result, &error);
+ if (!priv->stream)
{
g_task_return_error (task, error);
g_object_unref (task);