diff options
Diffstat (limited to 'youtube_dl/extractor/twitch.py')
| -rw-r--r-- | youtube_dl/extractor/twitch.py | 17 | 
1 files changed, 10 insertions, 7 deletions
| diff --git a/youtube_dl/extractor/twitch.py b/youtube_dl/extractor/twitch.py index 8af136147..b058891bd 100644 --- a/youtube_dl/extractor/twitch.py +++ b/youtube_dl/extractor/twitch.py @@ -85,6 +85,14 @@ class TwitchBaseIE(InfoExtractor):              raise ExtractorError(                  'Unable to login: %s' % m.group('msg').strip(), expected=True) +    def _prefer_source(self, formats): +        try: +            source = next(f for f in formats if f['format_id'] == 'Source') +            source['preference'] = 10 +        except StopIteration: +            pass  # No Source stream present +        self._sort_formats(formats) +  class TwitchItemBaseIE(TwitchBaseIE):      def _download_info(self, item, item_id): @@ -209,6 +217,7 @@ class TwitchVodIE(TwitchItemBaseIE):              '%s/vod/%s?nauth=%s&nauthsig=%s'              % (self._USHER_BASE, item_id, access_token['token'], access_token['sig']),              item_id, 'mp4') +        self._prefer_source(formats)          info['formats'] = formats          return info @@ -357,13 +366,7 @@ class TwitchStreamIE(TwitchBaseIE):              '%s/api/channel/hls/%s.m3u8?%s'              % (self._USHER_BASE, channel_id, compat_urllib_parse.urlencode(query).encode('utf-8')),              channel_id, 'mp4') - -        # prefer the 'source' stream, the others are limited to 30 fps -        def _sort_source(f): -            if f.get('m3u8_media') is not None and f['m3u8_media'].get('NAME') == 'Source': -                return 1 -            return 0 -        formats = sorted(formats, key=_sort_source) +        self._prefer_source(formats)          view_count = stream.get('viewers')          timestamp = parse_iso8601(stream.get('created_at')) | 
