aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpukkandan <pukkandan.ytdlp@gmail.com>2023-03-09 22:09:23 +0530
committerpukkandan <pukkandan.ytdlp@gmail.com>2023-03-09 22:13:03 +0530
commitc9abebb851e6188cb34b9eb744c1863dd46af919 (patch)
tree64f6ba50988ce07d4e0ac50be114fd71cccd07b3
parent66aeaac9aa30b5959069ba84e53a5508232deb38 (diff)
downloadhypervideo-pre-c9abebb851e6188cb34b9eb744c1863dd46af919.tar.lz
hypervideo-pre-c9abebb851e6188cb34b9eb744c1863dd46af919.tar.xz
hypervideo-pre-c9abebb851e6188cb34b9eb744c1863dd46af919.zip
[extractor/youtube] Bypass throttling for `-f17`
and related cleanup Thanks @AudricV for the finding
-rw-r--r--yt_dlp/extractor/youtube.py19
1 files changed, 7 insertions, 12 deletions
diff --git a/yt_dlp/extractor/youtube.py b/yt_dlp/extractor/youtube.py
index acd4077f4..6e6abd65b 100644
--- a/yt_dlp/extractor/youtube.py
+++ b/yt_dlp/extractor/youtube.py
@@ -3745,13 +3745,11 @@ class YoutubeIE(YoutubeBaseInfoExtractor):
if mime_mobj:
dct['ext'] = mimetype2ext(mime_mobj.group(1))
dct.update(parse_codecs(mime_mobj.group(2)))
- no_audio = dct.get('acodec') == 'none'
- no_video = dct.get('vcodec') == 'none'
- if no_audio:
- dct['vbr'] = tbr
- if no_video:
- dct['abr'] = tbr
- if no_audio or no_video:
+
+ single_stream = 'none' in (dct.get('acodec'), dct.get('vcodec'))
+ if single_stream and dct.get('ext'):
+ dct['container'] = dct['ext'] + '_dash'
+ if single_stream or itag == '17':
CHUNK_SIZE = 10 << 20
dct.update({
'protocol': 'http_dash_segments',
@@ -3760,13 +3758,10 @@ class YoutubeIE(YoutubeBaseInfoExtractor):
'range': f'{range_start}-{min(range_start + CHUNK_SIZE - 1, dct["filesize"])}'
})
} for range_start in range(0, dct['filesize'], CHUNK_SIZE)]
- } if dct['filesize'] else {
- 'downloader_options': {'http_chunk_size': CHUNK_SIZE} # No longer useful?
+ } if itag != '17' and dct['filesize'] else {
+ 'downloader_options': {'http_chunk_size': CHUNK_SIZE}
})
- if dct.get('ext'):
- dct['container'] = dct['ext'] + '_dash'
-
if itag:
itags[itag].add(('https', dct.get('language')))
stream_ids.append(stream_id)