summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <slomo@circular-chaos.org>2013-07-23 10:21:26 +0200
committerSebastian Dröge <slomo@circular-chaos.org>2013-07-23 10:33:31 +0200
commit2a1877909f037c40e3bae8774853d7b82b6d333c (patch)
tree39f9f99ee572338755e22ff8eb9240f3e664fefc
parent4ec7baa61aaf30cc8ec813eace0c84d820c1d427 (diff)
downloadgstreamer-plugins-bad-2a1877909f037c40e3bae8774853d7b82b6d333c.tar.gz
tsparse: Add support for group-id in the stream-start event
-rw-r--r--gst/mpegtsdemux/mpegtsparse.c47
-rw-r--r--gst/mpegtsdemux/mpegtsparse.h3
2 files changed, 48 insertions, 2 deletions
diff --git a/gst/mpegtsdemux/mpegtsparse.c b/gst/mpegtsdemux/mpegtsparse.c
index dd3b58502..c80c51042 100644
--- a/gst/mpegtsdemux/mpegtsparse.c
+++ b/gst/mpegtsdemux/mpegtsparse.c
@@ -156,6 +156,9 @@ mpegts_parse_init (MpegTSParse2 * parse)
parse->srcpad = gst_pad_new_from_static_template (&src_template, "src");
parse->first = TRUE;
gst_element_add_pad (GST_ELEMENT (parse), parse->srcpad);
+
+ parse->have_group_id = FALSE;
+ parse->group_id = G_MAXUINT;
}
static void
@@ -185,19 +188,40 @@ mpegts_parse_reset (MpegTSBase * base)
MPEGTS_BIT_SET (base->known_psi, 0x1f);
GST_MPEGTS_PARSE (base)->first = TRUE;
+ GST_MPEGTS_PARSE (base)->have_group_id = FALSE;
+ GST_MPEGTS_PARSE (base)->group_id = G_MAXUINT;
}
static void
prepare_src_pad (MpegTSBase * base, MpegTSParse2 * parse)
{
if (base->packetizer->packet_size) {
+ GstEvent *event;
gchar *stream_id;
GstCaps *caps;
stream_id =
gst_pad_create_stream_id (parse->srcpad, GST_ELEMENT_CAST (base),
"multi-program");
- gst_pad_push_event (parse->srcpad, gst_event_new_stream_start (stream_id));
+
+ event =
+ gst_pad_get_sticky_event (parse->parent.sinkpad, GST_EVENT_STREAM_START,
+ 0);
+ if (event) {
+ if (gst_event_parse_group_id (event, &parse->group_id))
+ parse->have_group_id = TRUE;
+ else
+ parse->have_group_id = FALSE;
+ gst_event_unref (event);
+ } else if (!parse->have_group_id) {
+ parse->have_group_id = TRUE;
+ parse->group_id = gst_util_group_id_next ();
+ }
+ event = gst_event_new_stream_start (stream_id);
+ if (parse->have_group_id)
+ gst_event_set_group_id (event, parse->group_id);
+
+ gst_pad_push_event (parse->srcpad, event);
g_free (stream_id);
caps = gst_caps_new_simple ("video/mpegts",
@@ -305,6 +329,7 @@ mpegts_parse_request_new_pad (GstElement * element, GstPadTemplate * template,
MpegTSParseProgram *parseprogram;
GstPad *pad;
gint program_num = -1;
+ GstEvent *event;
gchar *stream_id;
g_return_val_if_fail (template != NULL, NULL);
@@ -337,7 +362,25 @@ mpegts_parse_request_new_pad (GstElement * element, GstPadTemplate * template,
gst_pad_set_active (pad, TRUE);
stream_id = gst_pad_create_stream_id (pad, element, padname + 8);
- gst_pad_push_event (pad, gst_event_new_stream_start (stream_id));
+
+ event =
+ gst_pad_get_sticky_event (parse->parent.sinkpad, GST_EVENT_STREAM_START,
+ 0);
+ if (event) {
+ if (gst_event_parse_group_id (event, &parse->group_id))
+ parse->have_group_id = TRUE;
+ else
+ parse->have_group_id = FALSE;
+ gst_event_unref (event);
+ } else if (!parse->have_group_id) {
+ parse->have_group_id = TRUE;
+ parse->group_id = gst_util_group_id_next ();
+ }
+ event = gst_event_new_stream_start (stream_id);
+ if (parse->have_group_id)
+ gst_event_set_group_id (event, parse->group_id);
+
+ gst_pad_push_event (pad, event);
g_free (stream_id);
gst_element_add_pad (element, pad);
diff --git a/gst/mpegtsdemux/mpegtsparse.h b/gst/mpegtsdemux/mpegtsparse.h
index 50b8eb529..d2f607ac3 100644
--- a/gst/mpegtsdemux/mpegtsparse.h
+++ b/gst/mpegtsdemux/mpegtsparse.h
@@ -48,6 +48,9 @@ typedef struct _MpegTSParse2Class MpegTSParse2Class;
struct _MpegTSParse2 {
MpegTSBase parent;
+ gboolean have_group_id;
+ guint group_id;
+
/* Always present source pad */
GstPad *srcpad;