souphttpsrc: Fix buffer handling
authorSebastian Dröge <sebastian.droege@collabora.co.uk>
Wed, 11 Jan 2012 13:10:46 +0000 (14:10 +0100)
committerSebastian Dröge <sebastian.droege@collabora.co.uk>
Wed, 11 Jan 2012 13:10:46 +0000 (14:10 +0100)
souphttpsrc is now usable again and doesn't crash anymore
whenever something is read from a HTTP connection.

ext/soup/gstsouphttpsrc.c

index 85587d17a7d0c209108114d17bcb8398d824f95a..42723ee4b0c3bcda279b817742c3358600721582 100644 (file)
@@ -933,6 +933,7 @@ gst_soup_http_src_got_chunk_cb (SoupMessage * msg, SoupBuffer * chunk,
 {
   GstBaseSrc *basesrc;
   guint64 new_position;
+  SoupGstChunk *gchunk;
 
   if (G_UNLIKELY (msg != src->msg)) {
     GST_DEBUG_OBJECT (src, "got chunk, but not for current message");
@@ -948,7 +949,8 @@ gst_soup_http_src_got_chunk_cb (SoupMessage * msg, SoupBuffer * chunk,
       chunk->length);
 
   /* Extract the GstBuffer from the SoupBuffer and set its fields. */
-  *src->outbuf = GST_BUFFER_CAST (soup_buffer_get_owner (chunk));
+  gchunk = (SoupGstChunk *) soup_buffer_get_owner (chunk);
+  *src->outbuf = gchunk->buffer;
 
   gst_buffer_resize (*src->outbuf, 0, chunk->length);
   GST_BUFFER_OFFSET (*src->outbuf) = basesrc->segment.position;