diff options
| -rw-r--r-- | test/test_YoutubeDL.py | 5 | ||||
| -rwxr-xr-x | youtube_dl/YoutubeDL.py | 13 | 
2 files changed, 11 insertions, 7 deletions
diff --git a/test/test_YoutubeDL.py b/test/test_YoutubeDL.py index 8f7aef512..709e3100f 100644 --- a/test/test_YoutubeDL.py +++ b/test/test_YoutubeDL.py @@ -317,6 +317,11 @@ class TestFormatSelection(unittest.TestCase):          downloaded = ydl.downloaded_info_dicts[0]          self.assertEqual(downloaded['format_id'], 'G') +        ydl = YDL({'format': 'all[width>=400][width<=600]'}) +        ydl.process_ie_result(info_dict) +        downloaded_ids = [info['format_id'] for info in ydl.downloaded_info_dicts] +        self.assertEqual(downloaded_ids, ['B', 'C', 'D']) +  class TestYoutubeDL(unittest.TestCase):      def test_subtitles(self): diff --git a/youtube_dl/YoutubeDL.py b/youtube_dl/YoutubeDL.py index 17a5407b9..258e612af 100755 --- a/youtube_dl/YoutubeDL.py +++ b/youtube_dl/YoutubeDL.py @@ -990,7 +990,10 @@ class YoutubeDL(object):                  format_spec = selector.selector                  def selector_function(formats): -                    if format_spec in ['best', 'worst', None]: +                    if format_spec == 'all': +                        for f in formats: +                            yield f +                    elif format_spec in ['best', 'worst', None]:                          format_idx = 0 if format_spec == 'worst' else -1                          audiovideo_formats = [                              f for f in formats @@ -1226,12 +1229,8 @@ class YoutubeDL(object):                      req_format_list.append('bestvideo+bestaudio')              req_format_list.append('best')              req_format = '/'.join(req_format_list) -        formats_to_download = [] -        if req_format == 'all': -            formats_to_download = formats -        else: -            format_selector = self.build_format_selector(req_format) -            formats_to_download = list(format_selector(formats)) +        format_selector = self.build_format_selector(req_format) +        formats_to_download = list(format_selector(formats))          if not formats_to_download:              raise ExtractorError('requested format not available',                                   expected=True)  | 
