summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2015-07-10 18:56:29 +0300
committerSebastian Dröge <sebastian@centricular.com>2015-10-02 11:01:17 +0300
commit693d3a24032cbf3e1e19dd05497bdc06dd71be6f (patch)
tree28c52008e9682da02f130a3d593493116a29fd7f
parent1df82cddeb1e67b842d84266637b6cd0cf4dadef (diff)
downloadgstreamer-plugins-bad-693d3a24032cbf3e1e19dd05497bdc06dd71be6f.tar.gz
mpdparser: Parse xlink attributes from Period, AdaptationSet and SegmentList
We still have to do something useful with them, like actually loading the content behind the URL. https://bugzilla.gnome.org/show_bug.cgi?id=752230
-rw-r--r--ext/dash/gstmpdparser.c63
-rw-r--r--ext/dash/gstmpdparser.h15
2 files changed, 78 insertions, 0 deletions
diff --git a/ext/dash/gstmpdparser.c b/ext/dash/gstmpdparser.c
index 091a81eac..a2d34b606 100644
--- a/ext/dash/gstmpdparser.c
+++ b/ext/dash/gstmpdparser.c
@@ -35,6 +35,9 @@
/* Property parsing */
static gboolean gst_mpdparser_get_xml_prop_string (xmlNode * a_node,
const gchar * property_name, gchar ** property_value);
+static gboolean gst_mpdparser_get_xml_ns_prop_string (xmlNode * a_node,
+ const gchar * ns_name, const gchar * property_name,
+ gchar ** property_value);
static gboolean gst_mpdparser_get_xml_prop_string_vector_type (xmlNode * a_node,
const gchar * property_name, gchar *** property_value);
static gboolean gst_mpdparser_get_xml_prop_signed_integer (xmlNode * a_node,
@@ -258,6 +261,25 @@ gst_mpdparser_get_xml_prop_string (xmlNode * a_node,
}
static gboolean
+gst_mpdparser_get_xml_ns_prop_string (xmlNode * a_node,
+ const gchar * ns_name, const gchar * property_name, gchar ** property_value)
+{
+ xmlChar *prop_string;
+ gboolean exists = FALSE;
+
+ prop_string =
+ xmlGetNsProp (a_node, (const xmlChar *) property_name,
+ (const xmlChar *) ns_name);
+ if (prop_string) {
+ *property_value = (gchar *) prop_string;
+ exists = TRUE;
+ GST_LOG (" - %s:%s: %s", ns_name, property_name, prop_string);
+ }
+
+ return exists;
+}
+
+static gboolean
gst_mpdparser_get_xml_prop_string_vector_type (xmlNode * a_node,
const gchar * property_name, gchar *** property_value)
{
@@ -1427,6 +1449,7 @@ gst_mpdparser_parse_segment_list_node (GstSegmentListNode ** pointer,
{
xmlNode *cur_node;
GstSegmentListNode *new_segment_list;
+ gchar *actuate;
gst_mpdparser_free_segment_list_node (*pointer);
*pointer = new_segment_list = g_slice_new0 (GstSegmentListNode);
@@ -1444,6 +1467,16 @@ gst_mpdparser_parse_segment_list_node (GstSegmentListNode ** pointer,
}
}
+ new_segment_list->actuate = GST_XLINK_ACTUATE_ON_REQUEST;
+ if (gst_mpdparser_get_xml_ns_prop_string (a_node,
+ "http://www.w3.org/1999/xlink", "href", &new_segment_list->xlink_href)
+ && gst_mpdparser_get_xml_ns_prop_string (a_node,
+ "http://www.w3.org/1999/xlink", "actuate", &actuate)) {
+ if (strcmp (actuate, "onLoad") == 0)
+ new_segment_list->actuate = GST_XLINK_ACTUATE_ON_LOAD;
+ xmlFree (actuate);
+ }
+
GST_LOG ("extension of SegmentList node:");
gst_mpdparser_parse_mult_seg_base_type_ext
(&new_segment_list->MultSegBaseType, a_node,
@@ -1574,11 +1607,23 @@ gst_mpdparser_parse_adaptation_set_node (GList ** list, xmlNode * a_node,
{
xmlNode *cur_node;
GstAdaptationSetNode *new_adap_set;
+ gchar *actuate;
new_adap_set = g_slice_new0 (GstAdaptationSetNode);
*list = g_list_append (*list, new_adap_set);
GST_LOG ("attributes of AdaptationSet node:");
+
+ new_adap_set->actuate = GST_XLINK_ACTUATE_ON_REQUEST;
+ if (gst_mpdparser_get_xml_ns_prop_string (a_node,
+ "http://www.w3.org/1999/xlink", "href", &new_adap_set->xlink_href)
+ && gst_mpdparser_get_xml_ns_prop_string (a_node,
+ "http://www.w3.org/1999/xlink", "actuate", &actuate)) {
+ if (strcmp (actuate, "onLoad") == 0)
+ new_adap_set->actuate = GST_XLINK_ACTUATE_ON_LOAD;
+ xmlFree (actuate);
+ }
+
gst_mpdparser_get_xml_prop_unsigned_integer (a_node, "id", 0,
&new_adap_set->id);
gst_mpdparser_get_xml_prop_unsigned_integer (a_node, "group", 0,
@@ -1726,11 +1771,23 @@ gst_mpdparser_parse_period_node (GList ** list, xmlNode * a_node)
{
xmlNode *cur_node;
GstPeriodNode *new_period;
+ gchar *actuate;
new_period = g_slice_new0 (GstPeriodNode);
*list = g_list_append (*list, new_period);
GST_LOG ("attributes of Period node:");
+
+ new_period->actuate = GST_XLINK_ACTUATE_ON_REQUEST;
+ if (gst_mpdparser_get_xml_ns_prop_string (a_node,
+ "http://www.w3.org/1999/xlink", "href", &new_period->xlink_href)
+ && gst_mpdparser_get_xml_ns_prop_string (a_node,
+ "http://www.w3.org/1999/xlink", "actuate", &actuate)) {
+ if (strcmp (actuate, "onLoad") == 0)
+ new_period->actuate = GST_XLINK_ACTUATE_ON_LOAD;
+ xmlFree (actuate);
+ }
+
gst_mpdparser_get_xml_prop_string (a_node, "id", &new_period->id);
gst_mpdparser_get_xml_prop_duration (a_node, "start", -1, &new_period->start);
gst_mpdparser_get_xml_prop_duration (a_node, "duration", -1,
@@ -2230,6 +2287,8 @@ gst_mpdparser_free_period_node (GstPeriodNode * period_node)
(GDestroyNotify) gst_mpdparser_free_subset_node);
g_list_free_full (period_node->BaseURLs,
(GDestroyNotify) gst_mpdparser_free_base_url_node);
+ if (period_node->xlink_href)
+ xmlFree (period_node->xlink_href);
g_slice_free (GstPeriodNode, period_node);
}
}
@@ -2329,6 +2388,8 @@ gst_mpdparser_free_adaptation_set_node (GstAdaptationSetNode *
(GDestroyNotify) gst_mpdparser_free_representation_node);
g_list_free_full (adaptation_set_node->ContentComponents,
(GDestroyNotify) gst_mpdparser_free_content_component_node);
+ if (adaptation_set_node->xlink_href)
+ xmlFree (adaptation_set_node->xlink_href);
g_slice_free (GstAdaptationSetNode, adaptation_set_node);
}
}
@@ -2444,6 +2505,8 @@ gst_mpdparser_free_segment_list_node (GstSegmentListNode * segment_list_node)
/* MultipleSegmentBaseType extension */
gst_mpdparser_free_mult_seg_base_type_ext
(segment_list_node->MultSegBaseType);
+ if (segment_list_node->xlink_href)
+ xmlFree (segment_list_node->xlink_href);
g_slice_free (GstSegmentListNode, segment_list_node);
}
}
diff --git a/ext/dash/gstmpdparser.h b/ext/dash/gstmpdparser.h
index 14a239021..c2fde5500 100644
--- a/ext/dash/gstmpdparser.h
+++ b/ext/dash/gstmpdparser.h
@@ -93,6 +93,12 @@ typedef enum
typedef enum
{
+ GST_XLINK_ACTUATE_ON_REQUEST,
+ GST_XLINK_ACTUATE_ON_LOAD
+} GstXLinkActuate;
+
+typedef enum
+{
GST_MPD_UTCTIMING_TYPE_UNKNOWN = 0x00,
GST_MPD_UTCTIMING_TYPE_NTP = 0x01,
GST_MPD_UTCTIMING_TYPE_SNTP = 0x02,
@@ -183,6 +189,9 @@ struct _GstSegmentListNode
GstMultSegmentBaseType *MultSegBaseType;
/* list of SegmentURL nodes */
GList *SegmentURL;
+
+ gchar *xlink_href;
+ GstXLinkActuate actuate;
};
struct _GstSegmentTemplateNode
@@ -322,6 +331,9 @@ struct _GstAdaptationSetNode
GList *Representations;
/* list of ContentComponent nodes */
GList *ContentComponents;
+
+ gchar *xlink_href;
+ GstXLinkActuate actuate;
};
struct _GstSubsetNode
@@ -348,6 +360,9 @@ struct _GstPeriodNode
GList *Subsets;
/* list of BaseURL nodes */
GList *BaseURLs;
+
+ gchar *xlink_href;
+ GstXLinkActuate actuate;
};
struct _GstProgramInformationNode