mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
appsink: put the correct segment in the preroll sample
last_segment is only being updated in dequeue_buffer(), which is only called from _pull_sample(). _pull_preroll() simply re-uses an old or dummy segment while the actual one sits and waits in the queue. https://bugzilla.gnome.org/show_bug.cgi?id=751147
This commit is contained in:
parent
ea9b6a7e3c
commit
c411819452
1 changed files with 5 additions and 1 deletions
|
@ -86,6 +86,7 @@ struct _GstAppSinkPrivate
|
||||||
GstBuffer *preroll;
|
GstBuffer *preroll;
|
||||||
GstCaps *preroll_caps;
|
GstCaps *preroll_caps;
|
||||||
GstCaps *last_caps;
|
GstCaps *last_caps;
|
||||||
|
GstSegment preroll_segment;
|
||||||
GstSegment last_segment;
|
GstSegment last_segment;
|
||||||
gboolean flushing;
|
gboolean flushing;
|
||||||
gboolean unlock;
|
gboolean unlock;
|
||||||
|
@ -519,6 +520,7 @@ gst_app_sink_start (GstBaseSink * psink)
|
||||||
GST_DEBUG_OBJECT (appsink, "starting");
|
GST_DEBUG_OBJECT (appsink, "starting");
|
||||||
priv->flushing = FALSE;
|
priv->flushing = FALSE;
|
||||||
priv->started = TRUE;
|
priv->started = TRUE;
|
||||||
|
gst_segment_init (&priv->preroll_segment, GST_FORMAT_TIME);
|
||||||
gst_segment_init (&priv->last_segment, GST_FORMAT_TIME);
|
gst_segment_init (&priv->last_segment, GST_FORMAT_TIME);
|
||||||
g_mutex_unlock (&priv->mutex);
|
g_mutex_unlock (&priv->mutex);
|
||||||
|
|
||||||
|
@ -569,6 +571,8 @@ gst_app_sink_event (GstBaseSink * sink, GstEvent * event)
|
||||||
g_mutex_lock (&priv->mutex);
|
g_mutex_lock (&priv->mutex);
|
||||||
GST_DEBUG_OBJECT (appsink, "receiving SEGMENT");
|
GST_DEBUG_OBJECT (appsink, "receiving SEGMENT");
|
||||||
g_queue_push_tail (priv->queue, gst_event_ref (event));
|
g_queue_push_tail (priv->queue, gst_event_ref (event));
|
||||||
|
if (!priv->preroll)
|
||||||
|
gst_event_copy_segment (event, &priv->preroll_segment);
|
||||||
g_mutex_unlock (&priv->mutex);
|
g_mutex_unlock (&priv->mutex);
|
||||||
break;
|
break;
|
||||||
case GST_EVENT_EOS:{
|
case GST_EVENT_EOS:{
|
||||||
|
@ -1140,7 +1144,7 @@ gst_app_sink_pull_preroll (GstAppSink * appsink)
|
||||||
g_cond_wait (&priv->cond, &priv->mutex);
|
g_cond_wait (&priv->cond, &priv->mutex);
|
||||||
}
|
}
|
||||||
sample =
|
sample =
|
||||||
gst_sample_new (priv->preroll, priv->preroll_caps, &priv->last_segment,
|
gst_sample_new (priv->preroll, priv->preroll_caps, &priv->preroll_segment,
|
||||||
NULL);
|
NULL);
|
||||||
GST_DEBUG_OBJECT (appsink, "we have the preroll sample %p", sample);
|
GST_DEBUG_OBJECT (appsink, "we have the preroll sample %p", sample);
|
||||||
g_mutex_unlock (&priv->mutex);
|
g_mutex_unlock (&priv->mutex);
|
||||||
|
|
Loading…
Reference in a new issue