diff options
author | pukkandan <pukkandan.ytdlp@gmail.com> | 2023-06-21 05:15:03 +0530 |
---|---|---|
committer | pukkandan <pukkandan.ytdlp@gmail.com> | 2023-06-21 06:10:39 +0530 |
commit | ebe1b4e34f43c3acad30e4bcb8484681a030c114 (patch) | |
tree | e9f4c6f29c1f6ac8b4a8030552d6d3759108d835 | |
parent | a35af4306d24c56c6358f89cdf204860d1cd62b4 (diff) | |
download | hypervideo-pre-ebe1b4e34f43c3acad30e4bcb8484681a030c114.tar.lz hypervideo-pre-ebe1b4e34f43c3acad30e4bcb8484681a030c114.tar.xz hypervideo-pre-ebe1b4e34f43c3acad30e4bcb8484681a030c114.zip |
[outtmpl] Fix some minor bugs
Closes #7164
-rw-r--r-- | test/test_YoutubeDL.py | 2 | ||||
-rw-r--r-- | yt_dlp/YoutubeDL.py | 10 | ||||
-rw-r--r-- | yt_dlp/utils/_utils.py | 2 |
3 files changed, 7 insertions, 7 deletions
diff --git a/test/test_YoutubeDL.py b/test/test_YoutubeDL.py index ee6c52713..ccc9e36f3 100644 --- a/test/test_YoutubeDL.py +++ b/test/test_YoutubeDL.py @@ -755,7 +755,7 @@ class TestYoutubeDL(unittest.TestCase): test('%(id)d %(id)r', "1234 '1234'") test('%(id)r %(height)r', "'1234' 1080") test('%(ext)s-%(ext|def)d', 'mp4-def') - test('%(width|0)04d', '0000') + test('%(width|0)04d', '0') test('a%(width|b)d', 'ab', outtmpl_na_placeholder='none') FORMATS = self.outtmpl_info['formats'] diff --git a/yt_dlp/YoutubeDL.py b/yt_dlp/YoutubeDL.py index 077a37b30..a546ce65b 100644 --- a/yt_dlp/YoutubeDL.py +++ b/yt_dlp/YoutubeDL.py @@ -1286,17 +1286,17 @@ class YoutubeDL: if fmt == 's' and value is not None and key in field_size_compat_map.keys(): fmt = f'0{field_size_compat_map[key]:d}d' - if value is None: - value = default - elif replacement is not None: + if None not in (value, replacement): try: value = replacement_formatter.format(replacement, value) except ValueError: - value = na + value, default = None, na flags = outer_mobj.group('conversion') or '' str_fmt = f'{fmt[:-1]}s' - if fmt[-1] == 'l': # list + if value is None: + value, fmt = default, 's' + elif fmt[-1] == 'l': # list delim = '\n' if '#' in flags else ', ' value, fmt = delim.join(map(str, variadic(value, allowed_types=(str, bytes)))), str_fmt elif fmt[-1] == 'j': # json diff --git a/yt_dlp/utils/_utils.py b/yt_dlp/utils/_utils.py index 256e2db5a..d10d621d5 100644 --- a/yt_dlp/utils/_utils.py +++ b/yt_dlp/utils/_utils.py @@ -3302,7 +3302,7 @@ STR_FORMAT_RE_TMPL = r'''(?x) ''' -STR_FORMAT_TYPES = 'diouxXeEfFgGcrs' +STR_FORMAT_TYPES = 'diouxXeEfFgGcrsa' def limit_length(s, length): |