mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-02 05:28:48 +00:00
basevideoencoder: elaborate finish to draining
This commit is contained in:
parent
4b5623d687
commit
d68288b597
2 changed files with 40 additions and 3 deletions
|
@ -80,6 +80,7 @@ gst_base_video_encoder_reset (GstBaseVideoEncoder * base_video_encoder)
|
||||||
base_video_encoder->force_keyframe = FALSE;
|
base_video_encoder->force_keyframe = FALSE;
|
||||||
|
|
||||||
base_video_encoder->set_output_caps = FALSE;
|
base_video_encoder->set_output_caps = FALSE;
|
||||||
|
base_video_encoder->drained = TRUE;
|
||||||
base_video_encoder->min_latency = 0;
|
base_video_encoder->min_latency = 0;
|
||||||
base_video_encoder->max_latency = 0;
|
base_video_encoder->max_latency = 0;
|
||||||
|
|
||||||
|
@ -121,6 +122,43 @@ gst_base_video_encoder_init (GstBaseVideoEncoder * base_video_encoder,
|
||||||
base_video_encoder->sink_clipping = TRUE;
|
base_video_encoder->sink_clipping = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_base_video_encoder_drain (GstBaseVideoEncoder * enc)
|
||||||
|
{
|
||||||
|
GstBaseVideoCodec *codec;
|
||||||
|
GstBaseVideoEncoderClass *enc_class;
|
||||||
|
gboolean ret = TRUE;
|
||||||
|
|
||||||
|
codec = GST_BASE_VIDEO_CODEC (enc);
|
||||||
|
enc_class = GST_BASE_VIDEO_ENCODER_GET_CLASS (enc);
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (enc, "draining");
|
||||||
|
|
||||||
|
if (enc->drained) {
|
||||||
|
GST_DEBUG_OBJECT (enc, "already drained");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (enc_class->finish) {
|
||||||
|
GST_DEBUG_OBJECT (enc, "requesting subclass to finish");
|
||||||
|
ret = enc_class->finish (enc);
|
||||||
|
}
|
||||||
|
/* everything should be away now */
|
||||||
|
if (codec->frames) {
|
||||||
|
/* not fatal/impossible though if subclass/codec eats stuff */
|
||||||
|
GST_WARNING_OBJECT (enc, "still %d frames left after draining",
|
||||||
|
g_list_length (codec->frames));
|
||||||
|
#if 0
|
||||||
|
/* FIXME should do this, but subclass may come up with it later on ?
|
||||||
|
* and would then need refcounting or so on frames */
|
||||||
|
g_list_foreach (codec->frames,
|
||||||
|
(GFunc) gst_base_video_codec_free_frame, NULL);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_base_video_encoder_sink_setcaps (GstPad * pad, GstCaps * caps)
|
gst_base_video_encoder_sink_setcaps (GstPad * pad, GstCaps * caps)
|
||||||
{
|
{
|
||||||
|
@ -197,9 +235,7 @@ gst_base_video_encoder_sink_eventfunc (GstBaseVideoEncoder * base_video_encoder,
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
{
|
{
|
||||||
base_video_encoder->a.at_eos = TRUE;
|
base_video_encoder->a.at_eos = TRUE;
|
||||||
if (base_video_encoder_class->finish) {
|
gst_base_video_encoder_drain (base_video_encoder);
|
||||||
base_video_encoder_class->finish (base_video_encoder);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GST_EVENT_NEWSEGMENT:
|
case GST_EVENT_NEWSEGMENT:
|
||||||
|
|
|
@ -74,6 +74,7 @@ struct _GstBaseVideoEncoder
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
/* FIXME move to real private part ? */
|
/* FIXME move to real private part ? */
|
||||||
gboolean set_output_caps;
|
gboolean set_output_caps;
|
||||||
|
gboolean drained;
|
||||||
|
|
||||||
gint64 min_latency;
|
gint64 min_latency;
|
||||||
gint64 max_latency;
|
gint64 max_latency;
|
||||||
|
|
Loading…
Reference in a new issue