mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-25 03:31:03 +00:00 
			
		
		
		
	 7a5c1cfe93
			
		
	
	
		7a5c1cfe93
		
			
		
	
	
	
	
		
			
			* All modules and binary names are changed * All documentation references changed * yt-dlp no longer loads youtube-dlc config files * All URLs changed to point to organization account Co-authored-by: Pccode66 Co-authored-by: pukkandan
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from __future__ import unicode_literals
 | |
| 
 | |
| from ..utils import load_plugins
 | |
| 
 | |
| try:
 | |
|     from .lazy_extractors import *
 | |
|     from .lazy_extractors import _ALL_CLASSES
 | |
|     _LAZY_LOADER = True
 | |
|     _PLUGIN_CLASSES = []
 | |
| except ImportError:
 | |
|     _LAZY_LOADER = False
 | |
| 
 | |
| if not _LAZY_LOADER:
 | |
|     from .extractors import *
 | |
| 
 | |
|     _PLUGIN_CLASSES = load_plugins('extractor', 'IE', globals())
 | |
| 
 | |
|     _ALL_CLASSES = [
 | |
|         klass
 | |
|         for name, klass in globals().items()
 | |
|         if name.endswith('IE') and name != 'GenericIE'
 | |
|     ]
 | |
|     _ALL_CLASSES.append(GenericIE)
 | |
| 
 | |
| 
 | |
| def gen_extractor_classes():
 | |
|     """ Return a list of supported extractors.
 | |
|     The order does matter; the first extractor matched is the one handling the URL.
 | |
|     """
 | |
|     return _ALL_CLASSES
 | |
| 
 | |
| 
 | |
| def gen_extractors():
 | |
|     """ Return a list of an instance of every supported extractor.
 | |
|     The order does matter; the first extractor matched is the one handling the URL.
 | |
|     """
 | |
|     return [klass() for klass in gen_extractor_classes()]
 | |
| 
 | |
| 
 | |
| def list_extractors(age_limit):
 | |
|     """
 | |
|     Return a list of extractors that are suitable for the given age,
 | |
|     sorted by extractor ID.
 | |
|     """
 | |
| 
 | |
|     return sorted(
 | |
|         filter(lambda ie: ie.is_suitable(age_limit), gen_extractors()),
 | |
|         key=lambda ie: ie.IE_NAME.lower())
 | |
| 
 | |
| 
 | |
| def get_info_extractor(ie_name):
 | |
|     """Returns the info extractor class with the given ie_name"""
 | |
|     return globals()[ie_name + 'IE']
 |