summaryrefslogtreecommitdiff
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:19:32 +0200
commit957f11be4d02c4cb2ee8b3a1181e7973d297eea7 (patch)
tree2534158ef71b72e7ce6f4688809927800d7da0de
parent7fa1dc9c2ebff2583c1d661dd3a7aa7bf02fe737 (diff)
downloadgvfs-957f11be4d02c4cb2ee8b3a1181e7973d297eea7.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
-rw-r--r--daemon/gvfshttpinputstream.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/daemon/gvfshttpinputstream.c b/daemon/gvfshttpinputstream.c
index d7eed197..4d18bcf7 100644
--- a/daemon/gvfshttpinputstream.c
+++ b/daemon/gvfshttpinputstream.c
@@ -330,7 +330,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);