dashdemux: Handle case without an initialization segment

If no initialization segment is defined, then don't print a
critical or a warning, just ignore it.

https://bugzilla.gnome.org/show_bug.cgi?id=701961
This commit is contained in:
Olivier Crête 2013-06-10 18:01:14 -04:00 committed by Thiago Santos
parent 4c89fab390
commit 3f26bb9154
2 changed files with 20 additions and 14 deletions

View file

@ -1728,18 +1728,24 @@ gst_dash_demux_get_next_header (GstDashDemux * demux, guint stream_idx)
initializationURL, range_start, range_end); initializationURL, range_start, range_end);
/* check if we have an index */ /* check if we have an index */
if (gst_mpd_client_get_next_header_index (demux->client, &initializationURL, if (header_buffer
stream_idx, &range_start, &range_end)) { && gst_mpd_client_get_next_header_index (demux->client,
GST_INFO_OBJECT (demux, "Fetching index %s %" G_GINT64_FORMAT "-%" &initializationURL, stream_idx, &range_start, &range_end)) {
G_GINT64_FORMAT, initializationURL, range_start, range_end); GST_INFO_OBJECT (demux,
index_buffer = gst_dash_demux_download_header_fragment (demux, stream_idx, "Fetching index %s %" G_GINT64_FORMAT "-%" G_GINT64_FORMAT,
initializationURL, range_start, range_end);
index_buffer =
gst_dash_demux_download_header_fragment (demux, stream_idx,
initializationURL, range_start, range_end); initializationURL, range_start, range_end);
} }
if (index_buffer && header_buffer) { if (header_buffer == NULL) {
GST_WARNING_OBJECT (demux, "Unable to fetch header");
return NULL;
}
if (index_buffer) {
header_buffer = gst_buffer_append (header_buffer, index_buffer); header_buffer = gst_buffer_append (header_buffer, index_buffer);
} else if (index_buffer) {
gst_buffer_unref (index_buffer);
} }
return header_buffer; return header_buffer;
@ -1975,9 +1981,7 @@ gst_dash_demux_get_next_fragment (GstDashDemux * demux)
if (selected_stream->need_header) { if (selected_stream->need_header) {
/* We need to fetch a new header */ /* We need to fetch a new header */
if ((header_buffer = if ((header_buffer =
gst_dash_demux_get_next_header (demux, stream_idx)) == NULL) { gst_dash_demux_get_next_header (demux, stream_idx)) != NULL) {
GST_WARNING_OBJECT (demux, "Unable to fetch header");
} else {
buffer = gst_buffer_append (header_buffer, buffer); buffer = gst_buffer_append (header_buffer, buffer);
} }
selected_stream->need_header = FALSE; selected_stream->need_header = FALSE;

View file

@ -3437,10 +3437,12 @@ gst_mpd_client_get_next_header (GstMpdClient * client, gchar ** uri,
&& stream_period->period->SegmentTemplate->initialization) { && stream_period->period->SegmentTemplate->initialization) {
initialization = stream_period->period->SegmentTemplate->initialization; initialization = stream_period->period->SegmentTemplate->initialization;
} }
if (initialization) {
*uri = gst_mpdparser_build_URL_from_template (initialization, *uri = gst_mpdparser_build_URL_from_template (initialization,
stream->cur_representation->id, 0, stream->cur_representation->id, 0,
stream->cur_representation->bandwidth, 0); stream->cur_representation->bandwidth, 0);
} }
}
GST_MPD_CLIENT_UNLOCK (client); GST_MPD_CLIENT_UNLOCK (client);
return *uri == NULL ? FALSE : TRUE; return *uri == NULL ? FALSE : TRUE;