mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 14:38:48 +00:00
basetransform: Report the output position on POSITION queries on the srcpad
There can be a difference between input and output last_stop. Fixes bug #629410.
This commit is contained in:
parent
53a3392e3c
commit
14023fff89
1 changed files with 23 additions and 3 deletions
|
@ -258,6 +258,8 @@ struct _GstBaseTransformPrivate
|
||||||
/* QoS stats */
|
/* QoS stats */
|
||||||
guint64 processed;
|
guint64 processed;
|
||||||
guint64 dropped;
|
guint64 dropped;
|
||||||
|
|
||||||
|
GstClockTime last_stop_out;
|
||||||
};
|
};
|
||||||
|
|
||||||
static GstElementClass *parent_class = NULL;
|
static GstElementClass *parent_class = NULL;
|
||||||
|
@ -1208,9 +1210,12 @@ gst_base_transform_query (GstPad * pad, GstQuery * query)
|
||||||
gst_query_parse_position (query, &format, NULL);
|
gst_query_parse_position (query, &format, NULL);
|
||||||
if (format == GST_FORMAT_TIME && trans->segment.format == GST_FORMAT_TIME) {
|
if (format == GST_FORMAT_TIME && trans->segment.format == GST_FORMAT_TIME) {
|
||||||
ret = TRUE;
|
ret = TRUE;
|
||||||
|
|
||||||
gst_query_set_position (query, format,
|
gst_query_set_position (query, format,
|
||||||
gst_segment_to_stream_time (&trans->segment, GST_FORMAT_TIME,
|
gst_segment_to_stream_time (&trans->segment, GST_FORMAT_TIME,
|
||||||
trans->segment.last_stop));
|
(pad ==
|
||||||
|
trans->sinkpad) ? trans->segment.last_stop : trans->
|
||||||
|
priv->last_stop_out));
|
||||||
} else {
|
} else {
|
||||||
ret = gst_pad_peer_query (otherpad, query);
|
ret = gst_pad_peer_query (otherpad, query);
|
||||||
}
|
}
|
||||||
|
@ -1947,6 +1952,7 @@ gst_base_transform_sink_eventfunc (GstBaseTransform * trans, GstEvent * event)
|
||||||
/* we need new segment info after the flush. */
|
/* we need new segment info after the flush. */
|
||||||
trans->have_newsegment = FALSE;
|
trans->have_newsegment = FALSE;
|
||||||
gst_segment_init (&trans->segment, GST_FORMAT_UNDEFINED);
|
gst_segment_init (&trans->segment, GST_FORMAT_UNDEFINED);
|
||||||
|
trans->priv->last_stop_out = GST_CLOCK_TIME_NONE;
|
||||||
break;
|
break;
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
break;
|
break;
|
||||||
|
@ -2319,11 +2325,24 @@ gst_base_transform_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
* GST_BASE_TRANSFORM_FLOW_DROPPED we will not push either. */
|
* GST_BASE_TRANSFORM_FLOW_DROPPED we will not push either. */
|
||||||
if (outbuf != NULL) {
|
if (outbuf != NULL) {
|
||||||
if ((ret == GST_FLOW_OK)) {
|
if ((ret == GST_FLOW_OK)) {
|
||||||
|
GstClockTime last_stop_out = GST_CLOCK_TIME_NONE;
|
||||||
|
|
||||||
/* Remember last stop position */
|
/* Remember last stop position */
|
||||||
if ((last_stop != GST_CLOCK_TIME_NONE) &&
|
if (last_stop != GST_CLOCK_TIME_NONE &&
|
||||||
(trans->segment.format == GST_FORMAT_TIME))
|
trans->segment.format == GST_FORMAT_TIME)
|
||||||
gst_segment_set_last_stop (&trans->segment, GST_FORMAT_TIME, last_stop);
|
gst_segment_set_last_stop (&trans->segment, GST_FORMAT_TIME, last_stop);
|
||||||
|
|
||||||
|
if (GST_BUFFER_TIMESTAMP_IS_VALID (outbuf)) {
|
||||||
|
last_stop_out = GST_BUFFER_TIMESTAMP (outbuf);
|
||||||
|
if (GST_BUFFER_DURATION_IS_VALID (outbuf))
|
||||||
|
last_stop_out += GST_BUFFER_DURATION (outbuf);
|
||||||
|
} else if (last_stop != GST_CLOCK_TIME_NONE) {
|
||||||
|
last_stop_out = last_stop;
|
||||||
|
}
|
||||||
|
if (last_stop_out != GST_CLOCK_TIME_NONE
|
||||||
|
&& trans->segment.format == GST_FORMAT_TIME)
|
||||||
|
trans->priv->last_stop_out = last_stop_out;
|
||||||
|
|
||||||
/* apply DISCONT flag if the buffer is not yet marked as such */
|
/* apply DISCONT flag if the buffer is not yet marked as such */
|
||||||
if (trans->priv->discont) {
|
if (trans->priv->discont) {
|
||||||
if (!GST_BUFFER_IS_DISCONT (outbuf)) {
|
if (!GST_BUFFER_IS_DISCONT (outbuf)) {
|
||||||
|
@ -2409,6 +2428,7 @@ gst_base_transform_activate (GstBaseTransform * trans, gboolean active)
|
||||||
trans->negotiated = FALSE;
|
trans->negotiated = FALSE;
|
||||||
trans->have_newsegment = FALSE;
|
trans->have_newsegment = FALSE;
|
||||||
gst_segment_init (&trans->segment, GST_FORMAT_UNDEFINED);
|
gst_segment_init (&trans->segment, GST_FORMAT_UNDEFINED);
|
||||||
|
trans->priv->last_stop_out = GST_CLOCK_TIME_NONE;
|
||||||
trans->priv->proportion = 1.0;
|
trans->priv->proportion = 1.0;
|
||||||
trans->priv->earliest_time = -1;
|
trans->priv->earliest_time = -1;
|
||||||
trans->priv->discont = FALSE;
|
trans->priv->discont = FALSE;
|
||||||
|
|
Loading…
Reference in a new issue