0
0
Fork 0
mirror of https://github.com/yt-dlp/yt-dlp.git synced 2025-01-03 06:01:02 +00:00

[FormatSort] Fix bug for audio with unknown codec

This commit is contained in:
pukkandan 2021-07-31 15:59:52 +05:30
parent e4f0275711
commit f5510afef0
No known key found for this signature in database
GPG key ID: 0F00D95A001F4698
2 changed files with 6 additions and 8 deletions

View file

@ -1756,6 +1756,7 @@ def _merge(formats_pair):
if not allow_multiple_streams[aud_vid] and fmt_info.get(aud_vid[0] + 'codec') != 'none': if not allow_multiple_streams[aud_vid] and fmt_info.get(aud_vid[0] + 'codec') != 'none':
if get_no_more[aud_vid]: if get_no_more[aud_vid]:
formats_info.pop(i) formats_info.pop(i)
break
get_no_more[aud_vid] = True get_no_more[aud_vid] = True
if len(formats_info) == 1: if len(formats_info) == 1:

View file

@ -1497,7 +1497,7 @@ class FormatSort:
'order': ('m4a', 'aac', 'mp3', 'ogg', 'opus', 'webm', '', 'none'), 'order': ('m4a', 'aac', 'mp3', 'ogg', 'opus', 'webm', '', 'none'),
'order_free': ('opus', 'ogg', 'webm', 'm4a', 'mp3', 'aac', '', 'none')}, 'order_free': ('opus', 'ogg', 'webm', 'm4a', 'mp3', 'aac', '', 'none')},
'hidden': {'visible': False, 'forced': True, 'type': 'extractor', 'max': -1000}, 'hidden': {'visible': False, 'forced': True, 'type': 'extractor', 'max': -1000},
'aud_or_vid': {'visible': False, 'forced': True, 'type': 'multiple', 'default': 1, 'aud_or_vid': {'visible': False, 'forced': True, 'type': 'multiple',
'field': ('vcodec', 'acodec'), 'field': ('vcodec', 'acodec'),
'function': lambda it: int(any(v != 'none' for v in it))}, 'function': lambda it: int(any(v != 'none' for v in it))},
'ie_pref': {'priority': True, 'type': 'extractor'}, 'ie_pref': {'priority': True, 'type': 'extractor'},
@ -1521,7 +1521,8 @@ class FormatSort:
'br': {'type': 'combined', 'field': ('tbr', 'vbr', 'abr'), 'same_limit': True}, 'br': {'type': 'combined', 'field': ('tbr', 'vbr', 'abr'), 'same_limit': True},
'size': {'type': 'combined', 'same_limit': True, 'field': ('filesize', 'fs_approx')}, 'size': {'type': 'combined', 'same_limit': True, 'field': ('filesize', 'fs_approx')},
'ext': {'type': 'combined', 'field': ('vext', 'aext')}, 'ext': {'type': 'combined', 'field': ('vext', 'aext')},
'res': {'type': 'multiple', 'field': ('height', 'width'), 'function': min}, 'res': {'type': 'multiple', 'field': ('height', 'width'),
'function': lambda it: (lambda l: min(l) if l else 0)(tuple(filter(None, it)))},
# Most of these exist only for compatibility reasons # Most of these exist only for compatibility reasons
'dimension': {'type': 'alias', 'field': 'res'}, 'dimension': {'type': 'alias', 'field': 'res'},
@ -1565,7 +1566,7 @@ def _get_field_setting(self, field, key):
elif key == 'convert': elif key == 'convert':
default = 'order' if type == 'ordered' else 'float_string' if field else 'ignore' default = 'order' if type == 'ordered' else 'float_string' if field else 'ignore'
else: else:
default = {'type': 'field', 'visible': True, 'order': [], 'not_in_list': (None,), 'function': max}.get(key, None) default = {'type': 'field', 'visible': True, 'order': [], 'not_in_list': (None,)}.get(key, None)
propObj[key] = default propObj[key] = default
return propObj[key] return propObj[key]
@ -1705,11 +1706,7 @@ def _calculate_field_preference(self, format, field):
type = 'field' # Only 'field' is allowed in multiple for now type = 'field' # Only 'field' is allowed in multiple for now
actual_fields = self._get_field_setting(field, 'field') actual_fields = self._get_field_setting(field, 'field')
def wrapped_function(values): value = self._get_field_setting(field, 'function')(get_value(f) for f in actual_fields)
values = tuple(filter(lambda x: x is not None, values))
return self._get_field_setting(field, 'function')(values) if values else None
value = wrapped_function((get_value(f) for f in actual_fields))
else: else:
value = get_value(field) value = get_value(field)
return self._calculate_field_preference_from_value(format, field, type, value) return self._calculate_field_preference_from_value(format, field, type, value)