mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 18:35:35 +00:00
matroskademux: use proper order for no-more-pads and newsegment and tag sending
This commit is contained in:
parent
702df566c3
commit
02581dd2a5
2 changed files with 48 additions and 12 deletions
|
@ -203,6 +203,11 @@ gst_matroska_demux_finalize (GObject * object)
|
||||||
demux->src = NULL;
|
demux->src = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (demux->global_tags) {
|
||||||
|
gst_tag_list_free (demux->global_tags);
|
||||||
|
demux->global_tags = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
G_OBJECT_CLASS (parent_class)->finalize (object);
|
G_OBJECT_CLASS (parent_class)->finalize (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -398,6 +403,11 @@ gst_matroska_demux_reset (GstElement * element)
|
||||||
demux->element_index = NULL;
|
demux->element_index = NULL;
|
||||||
}
|
}
|
||||||
demux->element_index_writer_id = -1;
|
demux->element_index_writer_id = -1;
|
||||||
|
|
||||||
|
if (demux->global_tags) {
|
||||||
|
gst_tag_list_free (demux->global_tags);
|
||||||
|
}
|
||||||
|
demux->global_tags = gst_tag_list_new ();
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint
|
static gint
|
||||||
|
@ -2010,6 +2020,23 @@ gst_matroskademux_do_index_seek (GstMatroskaDemux * demux,
|
||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* takes ownership of taglist */
|
||||||
|
static void
|
||||||
|
gst_matroska_demux_found_global_tag (GstMatroskaDemux * demux,
|
||||||
|
GstTagList * taglist)
|
||||||
|
{
|
||||||
|
if (demux->global_tags) {
|
||||||
|
/* nothing sent yet, add to cache */
|
||||||
|
gst_tag_list_insert (demux->global_tags, taglist, GST_TAG_MERGE_APPEND);
|
||||||
|
gst_tag_list_free (taglist);
|
||||||
|
} else {
|
||||||
|
/* hm, already sent, no need to cache and wait anymore */
|
||||||
|
GST_DEBUG_OBJECT (demux, "Sending late global tags %" GST_PTR_FORMAT,
|
||||||
|
demux->global_tags);
|
||||||
|
gst_element_found_tags (GST_ELEMENT (demux), demux->global_tags);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* takes ownership of the passed event! */
|
/* takes ownership of the passed event! */
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_matroska_demux_send_event (GstMatroskaDemux * demux, GstEvent * event)
|
gst_matroska_demux_send_event (GstMatroskaDemux * demux, GstEvent * event)
|
||||||
|
@ -2030,14 +2057,25 @@ gst_matroska_demux_send_event (GstMatroskaDemux * demux, GstEvent * event)
|
||||||
gst_event_ref (event);
|
gst_event_ref (event);
|
||||||
gst_pad_push_event (stream->pad, event);
|
gst_pad_push_event (stream->pad, event);
|
||||||
|
|
||||||
if (stream->pending_tags) {
|
if (G_UNLIKELY (stream->pending_tags)) {
|
||||||
GST_DEBUG_OBJECT (demux, "Sending pending_tags %p for pad %s:%s",
|
GST_DEBUG_OBJECT (demux, "Sending pending_tags %p for pad %s:%s : %"
|
||||||
stream->pending_tags, GST_DEBUG_PAD_NAME (stream->pad));
|
GST_PTR_FORMAT, stream->pending_tags,
|
||||||
|
GST_DEBUG_PAD_NAME (stream->pad), stream->pending_tags);
|
||||||
gst_element_found_tags_for_pad (GST_ELEMENT (demux), stream->pad,
|
gst_element_found_tags_for_pad (GST_ELEMENT (demux), stream->pad,
|
||||||
stream->pending_tags);
|
stream->pending_tags);
|
||||||
stream->pending_tags = NULL;
|
stream->pending_tags = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (G_UNLIKELY (demux->global_tags)) {
|
||||||
|
gst_tag_list_add (demux->global_tags, GST_TAG_MERGE_REPLACE,
|
||||||
|
GST_TAG_CONTAINER_FORMAT, "Matroska", NULL);
|
||||||
|
GST_DEBUG_OBJECT (demux, "Sending global_tags %p : %" GST_PTR_FORMAT,
|
||||||
|
demux->global_tags, demux->global_tags);
|
||||||
|
gst_element_found_tags (GST_ELEMENT (demux), demux->global_tags);
|
||||||
|
demux->global_tags = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
gst_event_unref (event);
|
gst_event_unref (event);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -2827,7 +2865,7 @@ gst_matroska_demux_parse_info (GstMatroskaDemux * demux)
|
||||||
taglist = gst_tag_list_new ();
|
taglist = gst_tag_list_new ();
|
||||||
gst_tag_list_add (taglist, GST_TAG_MERGE_APPEND, GST_TAG_TITLE, text,
|
gst_tag_list_add (taglist, GST_TAG_MERGE_APPEND, GST_TAG_TITLE, text,
|
||||||
NULL);
|
NULL);
|
||||||
gst_element_found_tags (GST_ELEMENT (ebml), taglist);
|
gst_matroska_demux_found_global_tag (demux, taglist);
|
||||||
g_free (text);
|
g_free (text);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -3109,10 +3147,7 @@ gst_matroska_demux_parse_metadata (GstMatroskaDemux * demux)
|
||||||
|
|
||||||
DEBUG_ELEMENT_STOP (demux, ebml, "Tags", ret);
|
DEBUG_ELEMENT_STOP (demux, ebml, "Tags", ret);
|
||||||
|
|
||||||
/* FIXME: tags must be pushed *after* the initial newsegment event */
|
gst_matroska_demux_found_global_tag (demux, taglist);
|
||||||
gst_tag_list_add (taglist, GST_TAG_MERGE_REPLACE, GST_TAG_CONTAINER_FORMAT,
|
|
||||||
"Matroska", NULL);
|
|
||||||
gst_element_found_tags (GST_ELEMENT (ebml), taglist);
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -3327,8 +3362,8 @@ gst_matroska_demux_parse_attachments (GstMatroskaDemux * demux)
|
||||||
DEBUG_ELEMENT_STOP (demux, ebml, "Attachments", ret);
|
DEBUG_ELEMENT_STOP (demux, ebml, "Attachments", ret);
|
||||||
|
|
||||||
if (gst_structure_n_fields (GST_STRUCTURE (taglist)) > 0) {
|
if (gst_structure_n_fields (GST_STRUCTURE (taglist)) > 0) {
|
||||||
GST_DEBUG_OBJECT (demux, "Posting attachment tags");
|
GST_DEBUG_OBJECT (demux, "Storing attachment tags");
|
||||||
gst_element_found_tags (GST_ELEMENT (ebml), taglist);
|
gst_matroska_demux_found_global_tag (demux, taglist);
|
||||||
} else {
|
} else {
|
||||||
GST_DEBUG_OBJECT (demux, "No valid attachments found");
|
GST_DEBUG_OBJECT (demux, "No valid attachments found");
|
||||||
gst_tag_list_free (taglist);
|
gst_tag_list_free (taglist);
|
||||||
|
@ -4899,14 +4934,14 @@ gst_matroska_demux_loop_stream_parse_id (GstMatroskaDemux * demux,
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
demux->state = GST_MATROSKA_DEMUX_STATE_DATA;
|
demux->state = GST_MATROSKA_DEMUX_STATE_DATA;
|
||||||
|
GST_DEBUG_OBJECT (demux, "signaling no more pads");
|
||||||
|
gst_element_no_more_pads (GST_ELEMENT (demux));
|
||||||
/* send initial discont */
|
/* send initial discont */
|
||||||
gst_matroska_demux_send_event (demux,
|
gst_matroska_demux_send_event (demux,
|
||||||
gst_event_new_new_segment (FALSE, 1.0,
|
gst_event_new_new_segment (FALSE, 1.0,
|
||||||
GST_FORMAT_TIME, 0,
|
GST_FORMAT_TIME, 0,
|
||||||
(demux->segment.duration > 0) ? demux->segment.duration : -1,
|
(demux->segment.duration > 0) ? demux->segment.duration : -1,
|
||||||
0));
|
0));
|
||||||
GST_DEBUG_OBJECT (demux, "signaling no more pads");
|
|
||||||
gst_element_no_more_pads (GST_ELEMENT (demux));
|
|
||||||
} else {
|
} else {
|
||||||
/* The idea is that we parse one cluster per loop and
|
/* The idea is that we parse one cluster per loop and
|
||||||
* then break out of the loop here. In the next call
|
* then break out of the loop here. In the next call
|
||||||
|
|
|
@ -95,6 +95,7 @@ typedef struct _GstMatroskaDemux {
|
||||||
|
|
||||||
GstEvent *close_segment;
|
GstEvent *close_segment;
|
||||||
GstEvent *new_segment;
|
GstEvent *new_segment;
|
||||||
|
GstTagList *global_tags;
|
||||||
} GstMatroskaDemux;
|
} GstMatroskaDemux;
|
||||||
|
|
||||||
typedef struct _GstMatroskaDemuxClass {
|
typedef struct _GstMatroskaDemuxClass {
|
||||||
|
|
Loading…
Reference in a new issue