mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
downloadbuffer: small cleanups
This commit is contained in:
parent
451d0e3b0d
commit
3d69028797
1 changed files with 30 additions and 12 deletions
|
@ -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>"GstCacheDownloadComplete"</classname>
|
* post an application message named <classname>"GstCacheDownloadComplete"</classname>
|
||||||
* with the following information:
|
* with the following information:
|
||||||
*
|
* <itemizedlist>
|
||||||
*
|
* <listitem>
|
||||||
|
* <para>
|
||||||
|
* G_TYPE_STRING
|
||||||
|
* <classname>"location"</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
|
||||||
|
|
Loading…
Reference in a new issue