diff options
| author | pukkandan <pukkandan.ytdlp@gmail.com> | 2021-10-12 16:50:04 +0530 | 
|---|---|---|
| committer | pukkandan <pukkandan.ytdlp@gmail.com> | 2021-10-13 04:14:11 +0530 | 
| commit | c111cefa5de2337fc677367ee2d727b8a56e3fd0 (patch) | |
| tree | f61af2abd16266103820b98655d47cb87cf2461a /yt_dlp/downloader | |
| parent | 975a0d0df98a68d936c86a77175f2b0e86b576f5 (diff) | |
| download | hypervideo-pre-c111cefa5de2337fc677367ee2d727b8a56e3fd0.tar.lz hypervideo-pre-c111cefa5de2337fc677367ee2d727b8a56e3fd0.tar.xz hypervideo-pre-c111cefa5de2337fc677367ee2d727b8a56e3fd0.zip | |
[downloader/ffmpeg] Improve simultaneous download and merge
Diffstat (limited to 'yt_dlp/downloader')
| -rw-r--r-- | yt_dlp/downloader/__init__.py | 15 | ||||
| -rw-r--r-- | yt_dlp/downloader/external.py | 4 | 
2 files changed, 14 insertions, 5 deletions
| diff --git a/yt_dlp/downloader/__init__.py b/yt_dlp/downloader/__init__.py index 739d98c2b..2449c7411 100644 --- a/yt_dlp/downloader/__init__.py +++ b/yt_dlp/downloader/__init__.py @@ -10,10 +10,15 @@ from ..utils import (  def get_suitable_downloader(info_dict, params={}, default=NO_DEFAULT, protocol=None, to_stdout=False):      info_dict['protocol'] = determine_protocol(info_dict)      info_copy = info_dict.copy() -    if protocol: -        info_copy['protocol'] = protocol      info_copy['to_stdout'] = to_stdout -    return _get_suitable_downloader(info_copy, params, default) + +    downloaders = [_get_suitable_downloader(info_copy, proto, params, default) +                   for proto in (protocol or info_copy['protocol']).split('+')] +    if set(downloaders) == {FFmpegFD} and FFmpegFD.can_merge_formats(info_copy, params): +        return FFmpegFD +    elif len(downloaders) == 1: +        return downloaders[0] +    return None  # Some of these require get_suitable_downloader @@ -72,7 +77,7 @@ def shorten_protocol_name(proto, simplify=False):      return short_protocol_names.get(proto, proto) -def _get_suitable_downloader(info_dict, params, default): +def _get_suitable_downloader(info_dict, protocol, params, default):      """Get the downloader class that can handle the info dict."""      if default is NO_DEFAULT:          default = HttpFD @@ -80,7 +85,7 @@ def _get_suitable_downloader(info_dict, params, default):      # if (info_dict.get('start_time') or info_dict.get('end_time')) and not info_dict.get('requested_formats') and FFmpegFD.can_download(info_dict):      #     return FFmpegFD -    protocol = info_dict['protocol'] +    info_dict['protocol'] = protocol      downloaders = params.get('external_downloader')      external_downloader = (          downloaders if isinstance(downloaders, compat_str) or downloaders is None diff --git a/yt_dlp/downloader/external.py b/yt_dlp/downloader/external.py index 9c1229cf6..3c0202f22 100644 --- a/yt_dlp/downloader/external.py +++ b/yt_dlp/downloader/external.py @@ -327,6 +327,10 @@ class FFmpegFD(ExternalFD):          # Fixme: This may be wrong when --ffmpeg-location is used          return FFmpegPostProcessor().available +    @classmethod +    def supports(cls, info_dict): +        return all(proto in cls.SUPPORTED_PROTOCOLS for proto in info_dict['protocol'].split('+')) +      def on_process_started(self, proc, stdin):          """ Override this in subclasses  """          pass | 
