gboolean res = TRUE;
gint64 cstart, cstop;
+
if ((!GST_CLOCK_TIME_IS_VALID (GST_BUFFER_TIMESTAMP (buffer))) ||
(!GST_CLOCK_TIME_IS_VALID (GST_BUFFER_DURATION (buffer))) ||
(dec->segment.format != GST_FORMAT_TIME))
goto beach;
+ cstart = GST_BUFFER_TIMESTAMP (buffer);
+ cstop = GST_BUFFER_DURATION (buffer);
+
if ((res = gst_segment_clip (&dec->segment, GST_FORMAT_TIME,
- GST_BUFFER_TIMESTAMP (buffer),
- GST_BUFFER_TIMESTAMP (buffer) + GST_BUFFER_DURATION (buffer),
- &cstart, &cstop))) {
+ cstart, cstart + cstop, &cstart, &cstop))) {
GST_BUFFER_TIMESTAMP (buffer) = cstart;
GST_BUFFER_DURATION (buffer) = cstop - cstart;
}
GstPngDec *pngdec;
GstBuffer *buffer;
GstFlowReturn ret = GST_FLOW_OK;
+ guint size;
pngdec = GST_PNGDEC (png_ptr->io_ptr);
pngdec->offset);
ret = gst_pad_pull_range (pngdec->sinkpad, pngdec->offset, length, &buffer);
- if ((ret != GST_FLOW_OK) || (GST_BUFFER_SIZE (buffer) != length))
+ if (ret != GST_FLOW_OK)
goto pause;
- memcpy (data, GST_BUFFER_DATA (buffer), GST_BUFFER_SIZE (buffer));
+ size = GST_BUFFER_SIZE (buffer);
+
+ if (size != length)
+ goto short_buffer;
+
+ memcpy (data, GST_BUFFER_DATA (buffer), size);
gst_buffer_unref (buffer);
return;
+ /* ERRORS */
pause:
- GST_INFO_OBJECT (pngdec, "pausing task, reason %s", gst_flow_get_name (ret));
- gst_pad_pause_task (pngdec->sinkpad);
- if (GST_FLOW_IS_FATAL (ret) || ret == GST_FLOW_NOT_LINKED) {
- gst_pad_push_event (pngdec->srcpad, gst_event_new_eos ());
+ {
+ GST_INFO_OBJECT (pngdec, "pausing task, reason %s",
+ gst_flow_get_name (ret));
+ gst_pad_pause_task (pngdec->sinkpad);
+ if (GST_FLOW_IS_FATAL (ret) || ret == GST_FLOW_NOT_LINKED) {
+ GST_ELEMENT_ERROR (pngdec, STREAM, FAILED,
+ (_("Internal data stream error.")),
+ ("stream stopped, reason %s", gst_flow_get_name (ret)));
+ gst_pad_push_event (pngdec->srcpad, gst_event_new_eos ());
+ }
+ return;
+ }
+short_buffer:
+ {
+ gst_buffer_unref (buffer);
GST_ELEMENT_ERROR (pngdec, STREAM, FAILED,
(_("Internal data stream error.")),
- ("stream stopped, reason %s", gst_flow_get_name (ret)));
+ ("Read %u, needed %u bytes", size, length));
+ ret = GST_FLOW_ERROR;
+ goto pause;
}
}
ret =
gst_pad_alloc_buffer_and_set_caps (pngdec->srcpad, GST_BUFFER_OFFSET_NONE,
buffer_size, GST_PAD_CAPS (pngdec->srcpad), &buffer);
- if (ret != GST_FLOW_OK) {
+ if (ret != GST_FLOW_OK)
goto pause;
- }
rows = (png_bytep *) g_malloc (sizeof (png_bytep) * pngdec->height);
/* Push the raw RGB frame */
ret = gst_pad_push (pngdec->srcpad, buffer);
- if (ret != GST_FLOW_OK) {
+ if (ret != GST_FLOW_OK)
goto pause;
- }
/* And we are done */
gst_pad_pause_task (pngdec->sinkpad);
return;
pause:
- GST_INFO_OBJECT (pngdec, "pausing task, reason %s", gst_flow_get_name (ret));
- gst_pad_pause_task (pngdec->sinkpad);
- if (GST_FLOW_IS_FATAL (ret) || ret == GST_FLOW_NOT_LINKED) {
- GST_ELEMENT_ERROR (pngdec, STREAM, FAILED,
- (_("Internal data stream error.")),
- ("stream stopped, reason %s", gst_flow_get_name (ret)));
- gst_pad_push_event (pngdec->srcpad, gst_event_new_eos ());
+ {
+ GST_INFO_OBJECT (pngdec, "pausing task, reason %s",
+ gst_flow_get_name (ret));
+ gst_pad_pause_task (pngdec->sinkpad);
+ if (GST_FLOW_IS_FATAL (ret) || ret == GST_FLOW_NOT_LINKED) {
+ GST_ELEMENT_ERROR (pngdec, STREAM, FAILED,
+ (_("Internal data stream error.")),
+ ("stream stopped, reason %s", gst_flow_get_name (ret)));
+ gst_pad_push_event (pngdec->srcpad, gst_event_new_eos ());
+ }
}
}