Bugfix for 822d66e591341f8bf082be371b4beb66d72ba080

Closes #4760
This commit is contained in:
pukkandan 2022-08-26 06:07:47 +05:30
parent 164b03c486
commit ca7f8b8f31
No known key found for this signature in database
GPG Key ID: 7EEE9E1E817D0A39

View File

@ -164,6 +164,7 @@ class _YoutubeDLHelpFormatter(optparse.IndentedHelpFormatter):
class _YoutubeDLOptionParser(optparse.OptionParser): class _YoutubeDLOptionParser(optparse.OptionParser):
# optparse is deprecated since python 3.2. So assume a stable interface even for private methods # optparse is deprecated since python 3.2. So assume a stable interface even for private methods
ALIAS_DEST = '_triggered_aliases'
ALIAS_TRIGGER_LIMIT = 100 ALIAS_TRIGGER_LIMIT = 100
def __init__(self): def __init__(self):
@ -175,6 +176,7 @@ class _YoutubeDLOptionParser(optparse.OptionParser):
formatter=_YoutubeDLHelpFormatter(), formatter=_YoutubeDLHelpFormatter(),
conflict_handler='resolve', conflict_handler='resolve',
) )
self.set_default(self.ALIAS_DEST, collections.defaultdict(int))
_UNKNOWN_OPTION = (optparse.BadOptionError, optparse.AmbiguousOptionError) _UNKNOWN_OPTION = (optparse.BadOptionError, optparse.AmbiguousOptionError)
_BAD_OPTION = optparse.OptionValueError _BAD_OPTION = optparse.OptionValueError
@ -290,11 +292,9 @@ def create_parser():
parser.add_option_group(alias_group) parser.add_option_group(alias_group)
aliases = (x if x.startswith('-') else f'--{x}' for x in map(str.strip, aliases.split(','))) aliases = (x if x.startswith('-') else f'--{x}' for x in map(str.strip, aliases.split(',')))
DEST = '_triggered_aliases'
setattr(parser.values, DEST, collections.defaultdict(int))
try: try:
alias_group.add_option( alias_group.add_option(
*aliases, help=opts, nargs=nargs, dest=DEST, type='str' if nargs else None, *aliases, help=opts, nargs=nargs, dest=parser.ALIAS_DEST, type='str' if nargs else None,
metavar=' '.join(f'ARG{i}' for i in range(nargs)), action='callback', metavar=' '.join(f'ARG{i}' for i in range(nargs)), action='callback',
callback=_alias_callback, callback_kwargs={'opts': opts, 'nargs': nargs}) callback=_alias_callback, callback_kwargs={'opts': opts, 'nargs': nargs})
except Exception as err: except Exception as err: