baseparse: minor code simplification

Use gst_pad_peer_query_duration() and remove a few
unnecessary levels of indentation. Rest of code might
looks a bit questionable, but leave it as is for now.
This commit is contained in:
Tim-Philipp Müller 2015-08-15 16:39:40 +01:00
parent 1176fbf6dc
commit bc1fb2d8b0

View file

@ -1543,27 +1543,19 @@ no_duration_bytes:
} }
static void static void
gst_base_parse_update_duration (GstBaseParse * baseparse) gst_base_parse_update_duration (GstBaseParse * parse)
{ {
GstPad *peer;
GstBaseParse *parse;
parse = GST_BASE_PARSE (baseparse);
peer = gst_pad_get_peer (parse->sinkpad);
if (peer) {
gboolean qres = FALSE;
gint64 ptot, dest_value; gint64 ptot, dest_value;
qres = gst_pad_query_duration (peer, GST_FORMAT_BYTES, &ptot); if (!gst_pad_peer_query_duration (parse->sinkpad, GST_FORMAT_BYTES, &ptot))
gst_object_unref (GST_OBJECT (peer)); return;
if (qres) {
if (gst_base_parse_convert (parse, GST_FORMAT_BYTES, ptot, if (!gst_base_parse_convert (parse, GST_FORMAT_BYTES, ptot,
GST_FORMAT_TIME, &dest_value)) { GST_FORMAT_TIME, &dest_value))
return;
/* inform if duration changed, but try to avoid spamming */ /* inform if duration changed, but try to avoid spamming */
parse->priv->estimated_drift += parse->priv->estimated_drift += dest_value - parse->priv->estimated_duration;
dest_value - parse->priv->estimated_duration;
parse->priv->estimated_duration = dest_value; parse->priv->estimated_duration = dest_value;
GST_LOG_OBJECT (parse, GST_LOG_OBJECT (parse,
@ -1576,9 +1568,6 @@ gst_base_parse_update_duration (GstBaseParse * baseparse)
gst_message_new_duration_changed (GST_OBJECT (parse))); gst_message_new_duration_changed (GST_OBJECT (parse)));
parse->priv->estimated_drift = 0; parse->priv->estimated_drift = 0;
} }
}
}
}
} }
static void static void