summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2015-08-21 12:06:07 +0300
committerSebastian Dröge <sebastian@centricular.com>2015-10-02 11:01:23 +0300
commitbdf5f252c17e71b729c0f84d2f9e970fda7bfdeb (patch)
tree6a591d04fb097e636d510c1809a4ac9b4ed63835
parent693d3a24032cbf3e1e19dd05497bdc06dd71be6f (diff)
downloadgstreamer-plugins-bad-bdf5f252c17e71b729c0f84d2f9e970fda7bfdeb.tar.gz
mpdparser: Store an URI downloader in the parser for downloading additional MPD resources if needed
https://bugzilla.gnome.org/show_bug.cgi?id=752230
-rw-r--r--ext/dash/gstdashdemux.c3
-rw-r--r--ext/dash/gstmpdparser.c13
-rw-r--r--ext/dash/gstmpdparser.h5
-rw-r--r--tests/check/Makefile.am5
4 files changed, 24 insertions, 2 deletions
diff --git a/ext/dash/gstdashdemux.c b/ext/dash/gstdashdemux.c
index ae349d170..5445ad4a4 100644
--- a/ext/dash/gstdashdemux.c
+++ b/ext/dash/gstdashdemux.c
@@ -724,6 +724,7 @@ gst_dash_demux_process_manifest (GstAdaptiveDemux * demux, GstBuffer * buf)
if (dashdemux->client)
gst_mpd_client_free (dashdemux->client);
dashdemux->client = gst_mpd_client_new ();
+ gst_mpd_client_set_uri_downloader (dashdemux->client, demux->downloader);
dashdemux->client->mpd_uri = g_strdup (demux->manifest_uri);
dashdemux->client->mpd_base_uri = g_strdup (demux->manifest_base_uri);
@@ -801,6 +802,7 @@ gst_dash_demux_reset (GstAdaptiveDemux * ademux)
gst_dash_demux_clock_drift_free (demux->clock_drift);
demux->clock_drift = NULL;
demux->client = gst_mpd_client_new ();
+ gst_mpd_client_set_uri_downloader (demux->client, ademux->downloader);
demux->n_audio_streams = 0;
demux->n_video_streams = 0;
@@ -1273,6 +1275,7 @@ gst_dash_demux_update_manifest_data (GstAdaptiveDemux * demux,
/* parse the manifest file */
new_client = gst_mpd_client_new ();
+ gst_mpd_client_set_uri_downloader (new_client, demux->downloader);
new_client->mpd_uri = g_strdup (demux->manifest_uri);
new_client->mpd_base_uri = g_strdup (demux->manifest_base_uri);
gst_buffer_map (buffer, &mapinfo, GST_MAP_READ);
diff --git a/ext/dash/gstmpdparser.c b/ext/dash/gstmpdparser.c
index a2d34b606..5d596425d 100644
--- a/ext/dash/gstmpdparser.c
+++ b/ext/dash/gstmpdparser.c
@@ -3051,9 +3051,22 @@ gst_mpd_client_free (GstMpdClient * client)
g_free (client->mpd_base_uri);
client->mpd_base_uri = NULL;
+ if (client->downloader)
+ gst_object_unref (client->downloader);
+ client->downloader = NULL;
+
g_free (client);
}
+void
+gst_mpd_client_set_uri_downloader (GstMpdClient * client,
+ GstUriDownloader * downloader)
+{
+ if (client->downloader)
+ gst_object_unref (client->downloader);
+ client->downloader = gst_object_ref (downloader);
+}
+
static void
gst_mpd_client_check_profiles (GstMpdClient * client)
{
diff --git a/ext/dash/gstmpdparser.h b/ext/dash/gstmpdparser.h
index c2fde5500..85ddc8476 100644
--- a/ext/dash/gstmpdparser.h
+++ b/ext/dash/gstmpdparser.h
@@ -28,6 +28,7 @@
#define __GST_MPDPARSER_H__
#include <gst/gst.h>
+#include <gst/uridownloader/gsturidownloader.h>
G_BEGIN_DECLS
@@ -514,6 +515,8 @@ struct _GstMpdClient
/* profiles */
gboolean profile_isoff_ondemand;
+
+ GstUriDownloader * downloader;
};
/* Basic initialization/deinitialization functions */
@@ -522,6 +525,8 @@ void gst_active_streams_free (GstMpdClient * client);
void gst_mpd_client_free (GstMpdClient * client);
void gst_media_fragment_info_clear (GstMediaFragmentInfo * fragment);
+void gst_mpd_client_set_uri_downloader (GstMpdClient * client, GstUriDownloader * download);
+
/* MPD file parsing */
gboolean gst_mpd_parse (GstMpdClient *client, const gchar *data, gint size);
diff --git a/tests/check/Makefile.am b/tests/check/Makefile.am
index 1e5c23a91..fbce4d7c0 100644
--- a/tests/check/Makefile.am
+++ b/tests/check/Makefile.am
@@ -441,8 +441,9 @@ elements_mpg123audiodec_LDADD = \
elements_uvch264demux_CFLAGS = -DUVCH264DEMUX_DATADIR="$(srcdir)/elements/uvch264demux_data" \
$(AM_CFLAGS)
-elements_dash_mpd_CFLAGS = $(AM_CFLAGS) $(LIBXML2_CFLAGS)
-elements_dash_mpd_LDADD = $(LDADD) $(LIBXML2_LIBS)
+elements_dash_mpd_CFLAGS = $(AM_CFLAGS) $(GST_PLUGINS_BAD_CFLAGS) $(LIBXML2_CFLAGS)
+elements_dash_mpd_LDADD = $(LDADD) $(LIBXML2_LIBS) \
+ $(top_builddir)/gst-libs/gst/uridownloader/libgsturidownloader-@GST_API_VERSION@.la
elements_dash_mpd_SOURCES = elements/dash_mpd.c
pipelines_streamheader_CFLAGS = $(GIO_CFLAGS) $(AM_CFLAGS)