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',
 | 
						|
]
 |