diff options
Diffstat (limited to 'youtube_dl/downloader')
| -rw-r--r-- | youtube_dl/downloader/external.py | 9 | ||||
| -rw-r--r-- | youtube_dl/downloader/hls.py | 21 | 
2 files changed, 21 insertions, 9 deletions
| diff --git a/youtube_dl/downloader/external.py b/youtube_dl/downloader/external.py index bdd3545a2..e13cf547d 100644 --- a/youtube_dl/downloader/external.py +++ b/youtube_dl/downloader/external.py @@ -6,7 +6,10 @@ import sys  import re  from .common import FileDownloader -from ..compat import compat_setenv +from ..compat import ( +    compat_setenv, +    compat_str, +)  from ..postprocessor.ffmpeg import FFmpegPostProcessor, EXT_TO_OUT_FORMATS  from ..utils import (      cli_option, @@ -270,6 +273,10 @@ class FFmpegFD(ExternalFD):                  args += ['-rtmp_live', 'live']          args += ['-i', url, '-c', 'copy'] + +        if self.params.get('test', False): +            args += ['-fs', compat_str(self._TEST_FILE_SIZE)] +          if protocol in ('m3u8', 'm3u8_native'):              if self.params.get('hls_use_mpegts', False) or tmpfilename == '-':                  args += ['-f', 'mpegts'] diff --git a/youtube_dl/downloader/hls.py b/youtube_dl/downloader/hls.py index 4989abce1..7534e4da5 100644 --- a/youtube_dl/downloader/hls.py +++ b/youtube_dl/downloader/hls.py @@ -30,6 +30,15 @@ class HlsFD(FragmentFD):      FD_NAME = 'hlsnative' +    def _delegate_to_ffmpeg(self, filename, info_dict): +        self.report_warning( +            'hlsnative has detected features it does not support, ' +            'extraction will be delegated to ffmpeg') +        fd = FFmpegFD(self.ydl, self.params) +        for ph in self._progress_hooks: +            fd.add_progress_hook(ph) +        return fd.real_download(filename, info_dict) +      @staticmethod      def can_download(manifest, info_dict):          UNSUPPORTED_FEATURES = ( @@ -53,10 +62,12 @@ class HlsFD(FragmentFD):          )          check_results = [not re.search(feature, manifest) for feature in UNSUPPORTED_FEATURES]          check_results.append(can_decrypt_frag or '#EXT-X-KEY:METHOD=AES-128' not in manifest) -        check_results.append(not info_dict.get('is_live'))          return all(check_results)      def real_download(self, filename, info_dict): +        if info_dict.get('is_live'): +            return self._delegate_to_ffmpeg(filename, info_dict) +          man_url = info_dict['url']          self.to_screen('[%s] Downloading m3u8 manifest' % self.FD_NAME) @@ -68,13 +79,7 @@ class HlsFD(FragmentFD):              if info_dict.get('extra_param_to_segment_url'):                  self.report_error('pycrypto not found. Please install it.')                  return False -            self.report_warning( -                'hlsnative has detected features it does not support, ' -                'extraction will be delegated to ffmpeg') -            fd = FFmpegFD(self.ydl, self.params) -            for ph in self._progress_hooks: -                fd.add_progress_hook(ph) -            return fd.real_download(filename, info_dict) +            return self._delegate_to_ffmpeg(filename, info_dict)          total_frags = 0          for line in s.splitlines(): | 
