hlsdemux2: Add gst_hls_demux_stream_set_playlist_uri

Add a method that configures the new playlist URI for a stream.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/3883>
This commit is contained in:
Jan Schmidt 2022-12-24 01:36:52 +11:00 committed by GStreamer Marge Bot
parent 2c822735ba
commit d5edd48f13
3 changed files with 32 additions and 6 deletions

View file

@ -1294,11 +1294,6 @@ download_media_playlist (GstHLSDemuxStream * stream, gchar * orig_uri,
const gchar *main_uri = gst_adaptive_demux_get_manifest_ref_uri (demux); const gchar *main_uri = gst_adaptive_demux_get_manifest_ref_uri (demux);
struct PlaylistDownloadParams dl_params; struct PlaylistDownloadParams dl_params;
/* FIXME: Set this URI when the variant is changed */
if (stream->playlistloader)
gst_hls_demux_playlist_loader_set_playlist_uri (stream->playlistloader,
main_uri, orig_uri);
retry: retry:
memset (&dl_params, 0, sizeof (struct PlaylistDownloadParams)); memset (&dl_params, 0, sizeof (struct PlaylistDownloadParams));
@ -1527,6 +1522,23 @@ gst_hls_demux_stream_submit_request (GstAdaptiveDemux2Stream * stream,
(stream, download_req); (stream, download_req);
} }
void
gst_hls_demux_stream_set_playlist_uri (GstHLSDemuxStream * hls_stream,
gchar * uri)
{
GstAdaptiveDemux *demux = GST_ADAPTIVE_DEMUX2_STREAM_CAST (hls_stream)->demux;
if (hls_stream->playlistloader == NULL) {
hls_stream->playlistloader =
gst_hls_demux_playlist_loader_new (demux, demux->download_helper,
hls_stream->llhls_enabled);
}
const gchar *main_uri = gst_adaptive_demux_get_manifest_ref_uri (demux);
gst_hls_demux_playlist_loader_set_playlist_uri (hls_stream->playlistloader,
main_uri, uri);
}
GstFlowReturn GstFlowReturn
gst_hls_demux_stream_update_media_playlist (GstHLSDemuxStream * stream, gst_hls_demux_stream_update_media_playlist (GstHLSDemuxStream * stream,
gchar ** uri, GError ** err) gchar ** uri, GError ** err)
@ -2114,6 +2126,9 @@ gst_hls_demux_update_rendition_stream (GstHLSDemux * hlsdemux,
} }
hls_stream->pending_rendition = hls_stream->pending_rendition =
gst_hls_rendition_stream_ref (replacement_media); gst_hls_rendition_stream_ref (replacement_media);
gst_hls_demux_stream_set_playlist_uri (hls_stream, replacement_media->uri);
return TRUE; return TRUE;
} }

View file

@ -166,6 +166,9 @@ GstFlowReturn
gst_hls_demux_stream_seek (GstAdaptiveDemux2Stream * stream, gboolean forward, gst_hls_demux_stream_seek (GstAdaptiveDemux2Stream * stream, gboolean forward,
GstSeekFlags flags, GstClockTimeDiff ts, GstClockTimeDiff * final_ts); GstSeekFlags flags, GstClockTimeDiff ts, GstClockTimeDiff * final_ts);
void
gst_hls_demux_stream_set_playlist_uri (GstHLSDemuxStream * stream, gchar * uri);
GstFlowReturn GstFlowReturn
gst_hls_demux_stream_update_media_playlist (GstHLSDemuxStream * stream, gchar ** uri, GError ** err); gst_hls_demux_stream_update_media_playlist (GstHLSDemuxStream * stream, gchar ** uri, GError ** err);

View file

@ -426,6 +426,10 @@ create_main_variant_stream (GstHLSDemux * demux)
stream = create_common_hls_stream (demux, "hlsstream-variant"); stream = create_common_hls_stream (demux, "hlsstream-variant");
demux->main_stream = hlsdemux_stream = (GstHLSDemuxStream *) stream; demux->main_stream = hlsdemux_stream = (GstHLSDemuxStream *) stream;
gst_hls_demux_stream_set_playlist_uri (hlsdemux_stream,
demux->current_variant->uri);
hlsdemux_stream->is_variant = TRUE; hlsdemux_stream->is_variant = TRUE;
hlsdemux_stream->playlist_fetched = TRUE; hlsdemux_stream->playlist_fetched = TRUE;
/* Due to HLS manifest information being so unreliable/inconsistent, we will /* Due to HLS manifest information being so unreliable/inconsistent, we will
@ -626,6 +630,10 @@ gst_hls_demux_set_current_variant (GstHLSDemux * hlsdemux,
GST_DEBUG_OBJECT (hlsdemux, "Setting variant '%s'", variant->name); GST_DEBUG_OBJECT (hlsdemux, "Setting variant '%s'", variant->name);
hlsdemux->current_variant = gst_hls_variant_stream_ref (variant); hlsdemux->current_variant = gst_hls_variant_stream_ref (variant);
} }
if (hlsdemux->main_stream) {
gst_hls_demux_stream_set_playlist_uri (hlsdemux->main_stream, variant->uri);
}
} }
static gboolean static gboolean
@ -684,7 +692,7 @@ gst_hls_demux_process_manifest (GstAdaptiveDemux * demux, GstBuffer * buf)
if (variant) { if (variant) {
GST_INFO_OBJECT (hlsdemux, GST_INFO_OBJECT (hlsdemux,
"Manifest processed, initial variant selected : `%s`", variant->name); "Manifest processed, initial variant selected : `%s`", variant->name);
gst_hls_demux_set_current_variant (hlsdemux, variant); // FIXME: inline? gst_hls_demux_set_current_variant (hlsdemux, variant);
} }
GST_DEBUG_OBJECT (hlsdemux, "Manifest handled, now setting up streams"); GST_DEBUG_OBJECT (hlsdemux, "Manifest handled, now setting up streams");