yt-dlp/yt_dlp/extractor/extractors.py

36 lines
939 B
Python
Raw Normal View History

2023-01-07 08:19:13 +01:00
import inspect
import os
2024-10-19 05:25:36 +02:00
from .._globals import LAZY_EXTRACTORS
from .._globals import extractors as _extractors_context
2023-01-07 08:19:13 +01:00
_CLASS_LOOKUP = None
if not os.environ.get('YTDLP_NO_LAZY_EXTRACTORS'):
2023-01-07 08:19:13 +01:00
try:
from .lazy_extractors import _CLASS_LOOKUP
LAZY_EXTRACTORS.set(True)
except ImportError:
LAZY_EXTRACTORS.set(None)
2023-01-07 08:19:13 +01:00
if not _CLASS_LOOKUP:
from . import _extractors
2023-01-07 08:19:13 +01:00
_CLASS_LOOKUP = {
name: value
for name, value in inspect.getmembers(_extractors)
if name.endswith('IE') and name != 'GenericIE'
}
_CLASS_LOOKUP['GenericIE'] = _extractors.GenericIE
2023-01-16 04:53:41 +01:00
# We want to append to the main lookup
_current = _extractors_context.get()
for name, ie in _CLASS_LOOKUP.items():
_current.setdefault(name, ie)
def __getattr__(name):
value = _CLASS_LOOKUP.get(name)
if not value:
raise AttributeError(f'module {__name__} has no attribute {name}')
return value