downloadbuffer: small cleanups

This commit is contained in:
Wim Taymans 2014-05-08 16:49:53 +02:00
parent 451d0e3b0d
commit 3d69028797

View file

@ -42,8 +42,15 @@
* When the downloadbuffer has completely downloaded the media, it will * When the downloadbuffer has completely downloaded the media, it will
* post an application message named <classname>&quot;GstCacheDownloadComplete&quot;</classname> * post an application message named <classname>&quot;GstCacheDownloadComplete&quot;</classname>
* with the following information: * with the following information:
* * <itemizedlist>
* * <listitem>
* <para>
* G_TYPE_STRING
* <classname>&quot;location&quot;</classname>:
* the location of the completely downloaded file.
* </para>
* </listitem>
* </itemizedlist>
*/ */
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
@ -1032,6 +1039,8 @@ gst_download_buffer_handle_sink_event (GstPad * pad, GstObject * parent,
* filled and we can read all data from the dlbuf. */ * filled and we can read all data from the dlbuf. */
/* update the buffering status */ /* update the buffering status */
update_levels (dlbuf, dlbuf->max_level.bytes); update_levels (dlbuf, dlbuf->max_level.bytes);
/* wakeup the waiter and let it recheck */
GST_DOWNLOAD_BUFFER_SIGNAL_ADD (dlbuf, -1);
break; break;
case GST_EVENT_SEGMENT: case GST_EVENT_SEGMENT:
gst_event_replace (&dlbuf->segment_event, event); gst_event_replace (&dlbuf->segment_event, event);
@ -1137,6 +1146,9 @@ gst_download_buffer_chain (GstPad * pad, GstObject * parent, GstBuffer * buffer)
if (res == 0) if (res == 0)
goto write_error; goto write_error;
gst_buffer_unmap (buffer, &info);
gst_buffer_unref (buffer);
dlbuf->write_pos = offset + info.size; dlbuf->write_pos = offset + info.size;
dlbuf->bytes_in += info.size; dlbuf->bytes_in += info.size;
@ -1152,13 +1164,8 @@ gst_download_buffer_chain (GstPad * pad, GstObject * parent, GstBuffer * buffer)
/* a hole to fill, seek to its end */ /* a hole to fill, seek to its end */
perform_seek_to_offset (dlbuf, stop); perform_seek_to_offset (dlbuf, stop);
} else { } else {
/* we filled all the holes, post a message */ /* we filled all the holes, we are done */
dlbuf->filling = FALSE; goto completed;
update_levels (dlbuf, dlbuf->max_level.bytes);
gst_element_post_message (GST_ELEMENT_CAST (dlbuf),
gst_message_new_element (GST_OBJECT_CAST (dlbuf),
gst_structure_new ("GstCacheDownloadComplete",
"location", G_TYPE_STRING, dlbuf->temp_location, NULL)));
} }
} }
} else { } else {
@ -1181,9 +1188,6 @@ gst_download_buffer_chain (GstPad * pad, GstObject * parent, GstBuffer * buffer)
GST_DOWNLOAD_BUFFER_MUTEX_UNLOCK (dlbuf); GST_DOWNLOAD_BUFFER_MUTEX_UNLOCK (dlbuf);
gst_buffer_unmap (buffer, &info);
gst_buffer_unref (buffer);
return GST_FLOW_OK; return GST_FLOW_OK;
/* ERRORS */ /* ERRORS */
@ -1219,6 +1223,20 @@ write_error:
g_clear_error (&error); g_clear_error (&error);
return GST_FLOW_ERROR; return GST_FLOW_ERROR;
} }
completed:
{
GST_LOG_OBJECT (dlbuf, "we completed the download");
dlbuf->write_pos = dlbuf->upstream_size;
dlbuf->filling = FALSE;
update_levels (dlbuf, dlbuf->max_level.bytes);
gst_element_post_message (GST_ELEMENT_CAST (dlbuf),
gst_message_new_element (GST_OBJECT_CAST (dlbuf),
gst_structure_new ("GstCacheDownloadComplete",
"location", G_TYPE_STRING, dlbuf->temp_location, NULL)));
GST_DOWNLOAD_BUFFER_MUTEX_UNLOCK (dlbuf);
return GST_FLOW_EOS;
}
} }
/* called repeatedly with @pad as the source pad. This function should push out /* called repeatedly with @pad as the source pad. This function should push out