summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Nauwelaerts <mark.nauwelaerts@collabora.co.uk>2009-09-23 17:19:34 +0200
committerMark Nauwelaerts <mark.nauwelaerts@collabora.co.uk>2009-09-23 17:24:22 +0200
commit02581dd2a5f6d193eecb19568a4d425e26d5bb64 (patch)
tree9019d69c3b2e3e335cdb62bb6bdbd1a1ea2aec81
parent702df566c3d6cbd7ccd576e3177d6f98c46c3507 (diff)
matroskademux: use proper order for no-more-pads and newsegment and tag sending
-rw-r--r--gst/matroska/matroska-demux.c59
-rw-r--r--gst/matroska/matroska-demux.h1
2 files changed, 48 insertions, 12 deletions
diff --git a/gst/matroska/matroska-demux.c b/gst/matroska/matroska-demux.c
index c42fa4bd8..191eaac28 100644
--- a/gst/matroska/matroska-demux.c
+++ b/gst/matroska/matroska-demux.c
@@ -203,6 +203,11 @@ gst_matroska_demux_finalize (GObject * object)
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);
}
@@ -398,6 +403,11 @@ gst_matroska_demux_reset (GstElement * element)
demux->element_index = NULL;
}
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
@@ -2010,6 +2020,23 @@ gst_matroskademux_do_index_seek (GstMatroskaDemux * demux,
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! */
static gboolean
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_pad_push_event (stream->pad, event);
- if (stream->pending_tags) {
- GST_DEBUG_OBJECT (demux, "Sending pending_tags %p for pad %s:%s",
- stream->pending_tags, GST_DEBUG_PAD_NAME (stream->pad));
+ if (G_UNLIKELY (stream->pending_tags)) {
+ GST_DEBUG_OBJECT (demux, "Sending pending_tags %p for pad %s:%s : %"
+ 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,
stream->pending_tags);
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);
return ret;
}
@@ -2827,7 +2865,7 @@ gst_matroska_demux_parse_info (GstMatroskaDemux * demux)
taglist = gst_tag_list_new ();
gst_tag_list_add (taglist, GST_TAG_MERGE_APPEND, GST_TAG_TITLE, text,
NULL);
- gst_element_found_tags (GST_ELEMENT (ebml), taglist);
+ gst_matroska_demux_found_global_tag (demux, taglist);
g_free (text);
break;
}
@@ -3109,10 +3147,7 @@ gst_matroska_demux_parse_metadata (GstMatroskaDemux * demux)
DEBUG_ELEMENT_STOP (demux, ebml, "Tags", ret);
- /* FIXME: tags must be pushed *after* the initial newsegment event */
- gst_tag_list_add (taglist, GST_TAG_MERGE_REPLACE, GST_TAG_CONTAINER_FORMAT,
- "Matroska", NULL);
- gst_element_found_tags (GST_ELEMENT (ebml), taglist);
+ gst_matroska_demux_found_global_tag (demux, taglist);
return ret;
}
@@ -3327,8 +3362,8 @@ gst_matroska_demux_parse_attachments (GstMatroskaDemux * demux)
DEBUG_ELEMENT_STOP (demux, ebml, "Attachments", ret);
if (gst_structure_n_fields (GST_STRUCTURE (taglist)) > 0) {
- GST_DEBUG_OBJECT (demux, "Posting attachment tags");
- gst_element_found_tags (GST_ELEMENT (ebml), taglist);
+ GST_DEBUG_OBJECT (demux, "Storing attachment tags");
+ gst_matroska_demux_found_global_tag (demux, taglist);
} else {
GST_DEBUG_OBJECT (demux, "No valid attachments found");
gst_tag_list_free (taglist);
@@ -4899,14 +4934,14 @@ gst_matroska_demux_loop_stream_parse_id (GstMatroskaDemux * demux,
return ret;
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 */
gst_matroska_demux_send_event (demux,
gst_event_new_new_segment (FALSE, 1.0,
GST_FORMAT_TIME, 0,
(demux->segment.duration > 0) ? demux->segment.duration : -1,
0));
- GST_DEBUG_OBJECT (demux, "signaling no more pads");
- gst_element_no_more_pads (GST_ELEMENT (demux));
} else {
/* The idea is that we parse one cluster per loop and
* then break out of the loop here. In the next call
diff --git a/gst/matroska/matroska-demux.h b/gst/matroska/matroska-demux.h
index e032c2743..9a5a4166c 100644
--- a/gst/matroska/matroska-demux.h
+++ b/gst/matroska/matroska-demux.h
@@ -95,6 +95,7 @@ typedef struct _GstMatroskaDemux {
GstEvent *close_segment;
GstEvent *new_segment;
+ GstTagList *global_tags;
} GstMatroskaDemux;
typedef struct _GstMatroskaDemuxClass {