1
1
mirror of https://github.com/ytdl-org/youtube-dl synced 2025-01-12 09:55:52 +01:00

[downloader/f4m] Prefer bootstrap url attribute over inline bootstrap info

This commit is contained in:
Sergey M․ 2016-01-30 18:28:38 +06:00
parent c140629995
commit 8ab3fe81d8

View File

@ -273,15 +273,21 @@ class F4mFD(FragmentFD):
return fragments_list return fragments_list
def _parse_bootstrap_node(self, node, base_url): def _parse_bootstrap_node(self, node, base_url):
if node.text is None: # Sometimes non empty inline bootstrap info can be specified along
# with bootstrap url attribute (e.g. dummy inline bootstrap info
# contains whitespace characters in [1]). We will prefer bootstrap
# url over inline bootstrap info when present.
# 1. http://live-1-1.rutube.ru/stream/1024/HDS/SD/C2NKsS85HQNckgn5HdEmOQ/1454167650/S-s604419906/move/four/dirs/upper/1024-576p.f4m
bootstrap_url = node.get('url')
if bootstrap_url:
bootstrap_url = compat_urlparse.urljoin( bootstrap_url = compat_urlparse.urljoin(
base_url, node.attrib['url']) base_url, bootstrap_url)
boot_info = self._get_bootstrap_from_url(bootstrap_url) boot_info = self._get_bootstrap_from_url(bootstrap_url)
else: else:
bootstrap_url = None bootstrap_url = None
bootstrap = base64.b64decode(node.text.encode('ascii')) bootstrap = base64.b64decode(node.text.encode('ascii'))
boot_info = read_bootstrap_info(bootstrap) boot_info = read_bootstrap_info(bootstrap)
return (boot_info, bootstrap_url) return boot_info, bootstrap_url
def real_download(self, filename, info_dict): def real_download(self, filename, info_dict):
man_url = info_dict['url'] man_url = info_dict['url']