mirror of
https://github.com/Rapptz/discord.py.git
synced 2025-10-24 18:13:00 +00:00
Fix Signature for Greedy/Optional converters
Change Greedy to `[a]...` | `[a=1]...`
This commit is contained in:
committed by
Rapptz
parent
c960465366
commit
63c5892b43
@@ -795,11 +795,23 @@ class Command(_BaseCommand):
|
||||
return self.help.split('\n', 1)[0]
|
||||
return ''
|
||||
|
||||
def _is_typing_optional(self, annotation):
|
||||
try:
|
||||
origin = annotation.__origin__
|
||||
except AttributeError:
|
||||
return False
|
||||
|
||||
if origin is not typing.Union:
|
||||
return False
|
||||
|
||||
return annotation.__args__[-1] is type(None)
|
||||
|
||||
@property
|
||||
def signature(self):
|
||||
"""Returns a POSIX-like signature useful for help command output."""
|
||||
result = []
|
||||
parent = self.full_parent_name
|
||||
|
||||
if len(self.aliases) > 0:
|
||||
aliases = '|'.join(self.aliases)
|
||||
fmt = '[%s|%s]' % (self.name, aliases)
|
||||
@@ -819,16 +831,25 @@ class Command(_BaseCommand):
|
||||
return ' '.join(result)
|
||||
|
||||
for name, param in params.items():
|
||||
greedy = isinstance(param.annotation, converters._Greedy)
|
||||
|
||||
if param.default is not param.empty:
|
||||
# We don't want None or '' to trigger the [name=value] case and instead it should
|
||||
# do [name] since [name=None] or [name=] are not exactly useful for the user.
|
||||
should_print = param.default if isinstance(param.default, str) else param.default is not None
|
||||
if should_print:
|
||||
result.append('[%s=%s]' % (name, param.default))
|
||||
result.append('[%s=%s]' % (name, param.default) if not greedy else
|
||||
'[%s=%s]...' % (name, param.default))
|
||||
continue
|
||||
else:
|
||||
result.append('[%s]' % name)
|
||||
|
||||
elif param.kind == param.VAR_POSITIONAL:
|
||||
result.append('[%s...]' % name)
|
||||
elif greedy:
|
||||
result.append('[%s]...' % name)
|
||||
elif self._is_typing_optional(param.annotation):
|
||||
result.append('[%s]' % name)
|
||||
else:
|
||||
result.append('<%s>' % name)
|
||||
|
||||
|
Reference in New Issue
Block a user