mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-30 21:51:09 +00:00
mxfdemux: Add support for group-id in the stream-start event
This commit is contained in:
parent
44e404fe41
commit
46e85b4a6c
2 changed files with 28 additions and 6 deletions
|
@ -277,6 +277,9 @@ gst_mxf_demux_reset (GstMXFDemux * demux)
|
||||||
|
|
||||||
gst_mxf_demux_reset_mxf_state (demux);
|
gst_mxf_demux_reset_mxf_state (demux);
|
||||||
gst_mxf_demux_reset_metadata (demux);
|
gst_mxf_demux_reset_metadata (demux);
|
||||||
|
|
||||||
|
demux->have_group_id = FALSE;
|
||||||
|
demux->group_id = G_MAXUINT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstFlowReturn
|
static GstFlowReturn
|
||||||
|
@ -1188,6 +1191,7 @@ gst_mxf_demux_update_tracks (GstMXFDemux * demux)
|
||||||
if (pad_caps && !gst_caps_is_equal (pad_caps, etrack->caps)) {
|
if (pad_caps && !gst_caps_is_equal (pad_caps, etrack->caps)) {
|
||||||
gst_pad_set_caps (GST_PAD_CAST (pad), etrack->caps);
|
gst_pad_set_caps (GST_PAD_CAST (pad), etrack->caps);
|
||||||
} else if (!pad_caps) {
|
} else if (!pad_caps) {
|
||||||
|
GstEvent *event;
|
||||||
gchar *stream_id;
|
gchar *stream_id;
|
||||||
|
|
||||||
gst_pad_set_event_function (GST_PAD_CAST (pad),
|
gst_pad_set_event_function (GST_PAD_CAST (pad),
|
||||||
|
@ -1202,8 +1206,24 @@ gst_mxf_demux_update_tracks (GstMXFDemux * demux)
|
||||||
stream_id =
|
stream_id =
|
||||||
gst_pad_create_stream_id_printf (GST_PAD_CAST (pad),
|
gst_pad_create_stream_id_printf (GST_PAD_CAST (pad),
|
||||||
GST_ELEMENT_CAST (demux), "%03u", pad->track_id);
|
GST_ELEMENT_CAST (demux), "%03u", pad->track_id);
|
||||||
gst_pad_push_event (GST_PAD_CAST (pad),
|
|
||||||
gst_event_new_stream_start (stream_id));
|
event =
|
||||||
|
gst_pad_get_sticky_event (demux->sinkpad, GST_EVENT_STREAM_START, 0);
|
||||||
|
if (event) {
|
||||||
|
if (gst_event_parse_group_id (event, &demux->group_id))
|
||||||
|
demux->have_group_id = TRUE;
|
||||||
|
else
|
||||||
|
demux->have_group_id = FALSE;
|
||||||
|
gst_event_unref (event);
|
||||||
|
} else if (!demux->have_group_id) {
|
||||||
|
demux->have_group_id = TRUE;
|
||||||
|
demux->group_id = gst_util_group_id_next ();
|
||||||
|
}
|
||||||
|
event = gst_event_new_stream_start (stream_id);
|
||||||
|
if (demux->have_group_id)
|
||||||
|
gst_event_set_group_id (event, demux->group_id);
|
||||||
|
|
||||||
|
gst_pad_push_event (GST_PAD_CAST (pad), event);
|
||||||
g_free (stream_id);
|
g_free (stream_id);
|
||||||
|
|
||||||
gst_pad_set_caps (GST_PAD_CAST (pad), etrack->caps);
|
gst_pad_set_caps (GST_PAD_CAST (pad), etrack->caps);
|
||||||
|
@ -3184,8 +3204,8 @@ gst_mxf_demux_seek_push (GstMXFDemux * demux, GstEvent * event)
|
||||||
if (format != GST_FORMAT_TIME)
|
if (format != GST_FORMAT_TIME)
|
||||||
goto wrong_format;
|
goto wrong_format;
|
||||||
|
|
||||||
flush = !!(flags & GST_SEEK_FLAG_FLUSH);
|
flush = ! !(flags & GST_SEEK_FLAG_FLUSH);
|
||||||
keyframe = !!(flags & GST_SEEK_FLAG_KEY_UNIT);
|
keyframe = ! !(flags & GST_SEEK_FLAG_KEY_UNIT);
|
||||||
|
|
||||||
/* Work on a copy until we are sure the seek succeeded. */
|
/* Work on a copy until we are sure the seek succeeded. */
|
||||||
memcpy (&seeksegment, &demux->segment, sizeof (GstSegment));
|
memcpy (&seeksegment, &demux->segment, sizeof (GstSegment));
|
||||||
|
@ -3317,8 +3337,8 @@ gst_mxf_demux_seek_pull (GstMXFDemux * demux, GstEvent * event)
|
||||||
if (rate <= 0.0)
|
if (rate <= 0.0)
|
||||||
goto wrong_rate;
|
goto wrong_rate;
|
||||||
|
|
||||||
flush = !!(flags & GST_SEEK_FLAG_FLUSH);
|
flush = ! !(flags & GST_SEEK_FLAG_FLUSH);
|
||||||
keyframe = !!(flags & GST_SEEK_FLAG_KEY_UNIT);
|
keyframe = ! !(flags & GST_SEEK_FLAG_KEY_UNIT);
|
||||||
|
|
||||||
if (flush) {
|
if (flush) {
|
||||||
GstEvent *e;
|
GstEvent *e;
|
||||||
|
|
|
@ -126,6 +126,8 @@ struct _GstMXFDemux
|
||||||
GPtrArray *src;
|
GPtrArray *src;
|
||||||
|
|
||||||
/* < private > */
|
/* < private > */
|
||||||
|
gboolean have_group_id;
|
||||||
|
guint group_id;
|
||||||
|
|
||||||
GstAdapter *adapter;
|
GstAdapter *adapter;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue