diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | gst/videoparse/gstvideoparse.c | 18 |
2 files changed, 21 insertions, 3 deletions
@@ -1,5 +1,11 @@ 2007-12-13 Sebastian Dröge <slomo@circular-chaos.org> + * gst/videoparse/gstvideoparse.c: (gst_video_parse_convert), + (gst_video_parse_sink_event): + Handle -1 values for the CONVERT query too. + +2007-12-13 Sebastian Dröge <slomo@circular-chaos.org> + * gst/videoparse/gstvideoparse.c: (gst_video_parse_sink_event): Add YV12 to the pad templates as it is supported too and allow -1 as stop position for NEWSEGMENT events. diff --git a/gst/videoparse/gstvideoparse.c b/gst/videoparse/gstvideoparse.c index c18cb2e6..139a9cff 100644 --- a/gst/videoparse/gstvideoparse.c +++ b/gst/videoparse/gstvideoparse.c @@ -415,6 +415,13 @@ gst_video_parse_convert (GstVideoParse * vp, if (src_format == dest_format) { *dest_value = src_value; ret = TRUE; + goto done; + } + + if (src_value == -1) { + *dest_value = -1; + ret = TRUE; + goto done; } /* bytes to frames */ @@ -426,12 +433,14 @@ gst_video_parse_convert (GstVideoParse * vp, *dest_value = 0; } ret = TRUE; + goto done; } /* frames to bytes */ if (src_format == GST_FORMAT_DEFAULT && dest_format == GST_FORMAT_BYTES) { *dest_value = gst_util_uint64_scale_int (src_value, vp->blocksize, 1); ret = TRUE; + goto done; } /* time to frames */ @@ -444,6 +453,7 @@ gst_video_parse_convert (GstVideoParse * vp, *dest_value = 0; } ret = TRUE; + goto done; } /* frames to time */ @@ -456,6 +466,7 @@ gst_video_parse_convert (GstVideoParse * vp, *dest_value = 0; } ret = TRUE; + goto done; } /* time to bytes */ @@ -468,6 +479,7 @@ gst_video_parse_convert (GstVideoParse * vp, *dest_value = 0; } ret = TRUE; + goto done; } /* bytes to time */ @@ -482,6 +494,8 @@ gst_video_parse_convert (GstVideoParse * vp, ret = TRUE; } +done: + GST_DEBUG ("ret=%d result %" G_GINT64_FORMAT, ret, *dest_value); return ret; @@ -512,9 +526,7 @@ gst_video_parse_sink_event (GstPad * pad, GstEvent * event) ret = gst_video_parse_convert (vp, format, start, GST_FORMAT_TIME, &start); ret &= gst_video_parse_convert (vp, format, time, GST_FORMAT_TIME, &time); - if (stop != GST_CLOCK_TIME_NONE) - ret &= - gst_video_parse_convert (vp, format, stop, GST_FORMAT_TIME, &stop); + ret &= gst_video_parse_convert (vp, format, stop, GST_FORMAT_TIME, &stop); if (!ret) { GST_ERROR_OBJECT (vp, "Failed converting to GST_FORMAT_TIME format (%d)", format); |