diff options
| author | Philipp Hagemeister <phihag@phihag.de> | 2014-01-17 03:36:03 +0100 | 
|---|---|---|
| committer | Philipp Hagemeister <phihag@phihag.de> | 2014-01-17 03:36:03 +0100 | 
| commit | d0da491e1e5bfc1e67f07539350002fa0717baec (patch) | |
| tree | c7ebcb0f4d551e43842015a3a40b58e4f6703b9c | |
| parent | 6e249060cf2225fd4dc2c72c99bb1ab70ce40079 (diff) | |
[condenast] Allow multiple formats, and sort centralized
| -rw-r--r-- | youtube_dl/extractor/condenast.py | 26 | 
1 files changed, 14 insertions, 12 deletions
| diff --git a/youtube_dl/extractor/condenast.py b/youtube_dl/extractor/condenast.py index fef36fdfd..03b75b80d 100644 --- a/youtube_dl/extractor/condenast.py +++ b/youtube_dl/extractor/condenast.py @@ -79,19 +79,21 @@ class CondeNastIE(InfoExtractor):          video_info = self._search_regex(r'var video = ({.+?});', info_page, 'video info')          video_info = json.loads(video_info) -        def _formats_sort_key(f): -            type_ord = 1 if f['type'] == 'video/mp4' else 0 -            quality_ord = 1 if f['quality'] == 'high' else 0 -            return (quality_ord, type_ord) -        best_format = sorted(video_info['sources'][0], key=_formats_sort_key)[-1] +        formats = [{ +            'format_id': '%s-%s' % (fdata['type'].split('/')[-1], fdata['quality']), +            'url': fdata['src'], +            'ext': fdata['type'].split('/')[-1], +            'quality': 1 if fdata['quality'] == 'high' else 0, +        } for fdata in video_info['sources'][0]] +        self._sort_formats(formats) -        return {'id': video_id, -                'url': best_format['src'], -                'ext': best_format['type'].split('/')[-1], -                'title': video_info['title'], -                'thumbnail': video_info['poster_frame'], -                'description': description, -                } +        return { +            'id': video_id, +            'formats': formats, +            'title': video_info['title'], +            'thumbnail': video_info['poster_frame'], +            'description': description, +        }      def _real_extract(self, url):          mobj = re.match(self._VALID_URL, url) | 
