mssdemux2: Ensure stream/track uniqueness
authorEdward Hervey <edward@centricular.com>
Thu, 28 Apr 2022 08:46:34 +0000 (10:46 +0200)
committerGStreamer Marge Bot <gitlab-merge-bot@gstreamer-foundation.org>
Thu, 28 Apr 2022 10:45:37 +0000 (10:45 +0000)
If there is more than one track of the same type (say audio), we would end up
creating several stream/types with the same name.

Instead use the MSS stream name property to make them unique

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2319>

subprojects/gst-plugins-good/ext/adaptivedemux2/mss/gstmssdemux.c
subprojects/gst-plugins-good/ext/adaptivedemux2/mss/gstmssmanifest.c
subprojects/gst-plugins-good/ext/adaptivedemux2/mss/gstmssmanifest.h

index 843f0c67f7174df44fb957e59562344cd4f6ec6e..3175effe5bf16fbcd6101221c5367fcd147bfde1 100644 (file)
@@ -369,14 +369,28 @@ gst_mss_demux_setup_streams (GstAdaptiveDemux * demux)
     GstStreamType stream_type =
         gst_stream_type_from_mss_type (gst_mss_stream_get_type
         (manifeststream));
-    const gchar *lang, *stream_id = gst_stream_type_get_name (stream_type);
-    gchar *name;
+    const gchar *lang = gst_mss_stream_get_lang (manifeststream);
+    const gchar *name = gst_mss_stream_get_name (manifeststream);
+    gchar *stream_id;
     GstCaps *caps;
     GstTagList *tags = NULL;
 
-    name = g_strdup_printf ("mss-stream-%s", stream_id);
-    mss_stream = g_object_new (GST_TYPE_MSS_DEMUX_STREAM, "name", name, NULL);
-    g_free (name);
+    if (name)
+      stream_id =
+          g_strdup_printf ("mss-stream-%s-%s",
+          gst_stream_type_get_name (stream_type),
+          gst_mss_stream_get_name (manifeststream));
+    else if (lang)
+      stream_id =
+          g_strdup_printf ("mss-stream-%s-%s",
+          gst_stream_type_get_name (stream_type), lang);
+    else
+      stream_id =
+          g_strdup_printf ("mss-stream-%s",
+          gst_stream_type_get_name (stream_type));
+
+    mss_stream =
+        g_object_new (GST_TYPE_MSS_DEMUX_STREAM, "name", stream_id, NULL);
 
     stream = GST_ADAPTIVE_DEMUX2_STREAM_CAST (mss_stream);
     stream->stream_type = stream_type;
@@ -391,7 +405,6 @@ gst_mss_demux_setup_streams (GstAdaptiveDemux * demux)
     caps = gst_mss_stream_get_caps (mss_stream->manifest_stream);
     gst_adaptive_demux2_stream_set_caps (stream, create_mss_caps (mss_stream,
             caps));
-    lang = gst_mss_stream_get_lang (mss_stream->manifest_stream);
     if (lang != NULL)
       tags = gst_tag_list_new (GST_TAG_LANGUAGE_CODE, lang, NULL);
 
@@ -399,6 +412,7 @@ gst_mss_demux_setup_streams (GstAdaptiveDemux * demux)
         GST_STREAM_FLAG_NONE, (gchar *) stream_id, create_mss_caps (mss_stream,
             caps), tags);
 
+    g_free (stream_id);
     gst_adaptive_demux2_add_stream (demux, stream);
     gst_adaptive_demux2_stream_add_track (stream, track);
     gst_adaptive_demux_track_unref (track);
index 514033a480dcc98d56295d7236733b525273e0cc..110aa681c91c46e11720082f861b5d8895300492 100644 (file)
@@ -44,6 +44,7 @@ GST_DEBUG_CATEGORY_EXTERN (mssdemux2_debug);
 #define MSS_PROP_DURATION             "d"
 #define MSS_PROP_DVR_WINDOW_LENGTH    "DVRWindowLength"
 #define MSS_PROP_LANGUAGE             "Language"
+#define MSS_PROP_NAME                 "Name"
 #define MSS_PROP_NUMBER               "n"
 #define MSS_PROP_REPETITIONS          "r"
 #define MSS_PROP_STREAM_DURATION      "Duration"
@@ -84,6 +85,7 @@ struct _GstMssStream
 
   gchar *url;
   gchar *lang;
+  gchar *name;
 
   GstMssFragmentParser fragment_parser;
 
@@ -254,6 +256,7 @@ _gst_mss_stream_init (GstMssManifest * manifest, GstMssStream * stream,
   stream->xmlnode = node;
 
   /* get the base url path generator */
+  stream->name = (gchar *) xmlGetProp (node, (xmlChar *) MSS_PROP_NAME);
   stream->url = (gchar *) xmlGetProp (node, (xmlChar *) MSS_PROP_URL);
   stream->lang = (gchar *) xmlGetProp (node, (xmlChar *) MSS_PROP_LANGUAGE);
 
@@ -263,12 +266,14 @@ _gst_mss_stream_init (GstMssManifest * manifest, GstMssStream * stream,
    * of the manifest.
    */
 
+  GST_DEBUG ("lang '%s' url %s", stream->lang, stream->url);
   GST_DEBUG ("Live stream: %s, look-ahead fragments: %" G_GUINT64_FORMAT,
       manifest->is_live ? "yes" : "no", manifest->look_ahead_fragment_count);
   stream->has_live_fragments = manifest->is_live
       && manifest->look_ahead_fragment_count;
 
   for (iter = node->children; iter; iter = iter->next) {
+    GST_LOG ("Handling child '%s'", iter->name);
     if (node_has_type (iter, MSS_NODE_STREAM_FRAGMENT)) {
       gst_mss_fragment_list_builder_add (&builder, iter);
     } else if (node_has_type (iter, MSS_NODE_STREAM_QUALITY)) {
@@ -439,6 +444,7 @@ gst_mss_stream_free (GstMssStream * stream)
   g_list_free_full (stream->qualities,
       (GDestroyNotify) gst_mss_stream_quality_free);
   xmlFree (stream->url);
+  xmlFree (stream->name);
   xmlFree (stream->lang);
   g_regex_unref (stream->regex_position);
   g_regex_unref (stream->regex_bitrate);
@@ -1499,6 +1505,12 @@ gst_mss_stream_get_lang (GstMssStream * stream)
   return stream->lang;
 }
 
+const gchar *
+gst_mss_stream_get_name (GstMssStream * stream)
+{
+  return stream->name;
+}
+
 static GstClockTime
 gst_mss_manifest_get_dvr_window_length_clock_time (GstMssManifest * manifest)
 {
index a88f5d72d615ec2dd2725887798770cbfa1a1967..86da662e806a4c0ee88b6710904161527fdc3110 100644 (file)
@@ -71,6 +71,7 @@ GstFlowReturn gst_mss_stream_advance_fragment (GstMssStream * stream);
 GstFlowReturn gst_mss_stream_regress_fragment (GstMssStream * stream);
 void gst_mss_stream_seek (GstMssStream * stream, gboolean forward, GstSeekFlags flags, gint64 time, gint64 * final_time);
 const gchar * gst_mss_stream_get_lang (GstMssStream * stream);
+const gchar * gst_mss_stream_get_name (GstMssStream * stream);
 
 const gchar * gst_mss_stream_type_name (GstMssStreamType streamtype);