mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-15 22:23:22 +00:00
222516d97d
This comes with a very simply implementation for wget; the real work is in setting up the infrastructure.
44 lines
1014 B
Python
44 lines
1014 B
Python
from __future__ import unicode_literals
|
|
|
|
from .common import FileDownloader
|
|
from .external import get_external_downloader
|
|
from .f4m import F4mFD
|
|
from .hls import HlsFD
|
|
from .hls import NativeHlsFD
|
|
from .http import HttpFD
|
|
from .mplayer import MplayerFD
|
|
from .rtmp import RtmpFD
|
|
|
|
from ..utils import (
|
|
determine_protocol,
|
|
)
|
|
|
|
PROTOCOL_MAP = {
|
|
'rtmp': RtmpFD,
|
|
'm3u8_native': NativeHlsFD,
|
|
'm3u8': HlsFD,
|
|
'mms': MplayerFD,
|
|
'rtsp': MplayerFD,
|
|
'f4m': F4mFD,
|
|
}
|
|
|
|
|
|
def get_suitable_downloader(info_dict, params={}):
|
|
"""Get the downloader class that can handle the info dict."""
|
|
protocol = determine_protocol(info_dict)
|
|
info_dict['protocol'] = protocol
|
|
|
|
external_downloader = params.get('external_downloader')
|
|
if external_downloader is not None:
|
|
ed = get_external_downloader(external_downloader)
|
|
if ed.supports(info_dict):
|
|
return ed
|
|
|
|
return PROTOCOL_MAP.get(protocol, HttpFD)
|
|
|
|
|
|
__all__ = [
|
|
'get_suitable_downloader',
|
|
'FileDownloader',
|
|
]
|