|
@@ -2007,16 +2007,14 @@ class InfoExtractor(object):
|
|
|
f['url'] = initialization_url
|
|
|
f['fragments'].append({location_key(initialization_url): initialization_url})
|
|
|
f['fragments'].extend(representation_ms_info['fragments'])
|
|
|
- try:
|
|
|
- existing_format = next(
|
|
|
- fo for fo in formats
|
|
|
- if fo['format_id'] == representation_id)
|
|
|
- except StopIteration:
|
|
|
- full_info = formats_dict.get(representation_id, {}).copy()
|
|
|
- full_info.update(f)
|
|
|
- formats.append(full_info)
|
|
|
- else:
|
|
|
- existing_format.update(f)
|
|
|
+ # According to [1, 5.3.5.2, Table 7, page 35] @id of Representation
|
|
|
+ # is not necessarily unique within a Period thus formats with
|
|
|
+ # the same `format_id` are quite possible. There are numerous examples
|
|
|
+ # of such manifests (see https://github.com/rg3/youtube-dl/issues/15111,
|
|
|
+ # https://github.com/rg3/youtube-dl/issues/13919)
|
|
|
+ full_info = formats_dict.get(representation_id, {}).copy()
|
|
|
+ full_info.update(f)
|
|
|
+ formats.append(full_info)
|
|
|
else:
|
|
|
self.report_warning('Unknown MIME type %s in DASH manifest' % mime_type)
|
|
|
return formats
|