[commands] Do not take up 'command' keyword-argument in Context.invoke.

It was annoying when commands would have a keyword-only argument
named 'command', such as a help command or a disable command.
This commit is contained in:
Rapptz
2017-06-27 04:58:20 -04:00
parent ad20e3066e
commit ce34713c45

View File

@@ -87,7 +87,7 @@ class Context(discord.abc.Messageable):
self._state = self.message._state
@asyncio.coroutine
def invoke(self, command, *args, **kwargs):
def invoke(self, *args, **kwargs):
"""|coro|
Calls a command with the arguments given.
@@ -99,6 +99,10 @@ class Context(discord.abc.Messageable):
------
You do not pass in the context as it is done for you.
Warning
---------
The first parameter passed **must** be the command being invoked.
Parameters
-----------
command: :class:`.Command`
@@ -109,6 +113,11 @@ class Context(discord.abc.Messageable):
The keyword arguments to use.
"""
try:
command = args[0]
except IndexError:
raise TypeError('Missing command to invoke.') from None
arguments = []
if command.instance is not None:
arguments.append(command.instance)
@@ -116,7 +125,7 @@ class Context(discord.abc.Messageable):
if command.pass_context:
arguments.append(self)
arguments.extend(args)
arguments.extend(args[1:])
ret = yield from command.callback(*arguments, **kwargs)
return ret