mirror of
				https://github.com/Rapptz/discord.py.git
				synced 2025-10-25 18:43:00 +00:00 
			
		
		
		
	[commands] Context.invoke just invokes a command with no special case.
Previously it would both forward and invoke depending if there were no kwargs given. Now it just passes in the arguments to another command without doing any special casing on the no argument case.
This commit is contained in:
		| @@ -81,8 +81,36 @@ class Context: | |||||||
|         self.subcommand_passed = attrs.pop('subcommand_passed', None) |         self.subcommand_passed = attrs.pop('subcommand_passed', None) | ||||||
|  |  | ||||||
|     @asyncio.coroutine |     @asyncio.coroutine | ||||||
|     def invoke(self, command, **kwargs): |     def invoke(self, command, *args, **kwargs): | ||||||
|         if len(kwargs) == 0: |         """|coro| | ||||||
|             yield from command.invoke(self) |  | ||||||
|         else: |         Calls a command with the arguments given. | ||||||
|             yield from command.callback(**kwargs) |  | ||||||
|  |         This is useful if you want to just call the callback that a | ||||||
|  |         :class:`Command` holds internally. | ||||||
|  |  | ||||||
|  |         Note | ||||||
|  |         ------ | ||||||
|  |         You do not pass in the context as it is done for you. | ||||||
|  |  | ||||||
|  |         Parameters | ||||||
|  |         ----------- | ||||||
|  |         command : :class:`Command` | ||||||
|  |             A command or superclass of a command that is going to be called. | ||||||
|  |         \*args | ||||||
|  |             The arguments to to use. | ||||||
|  |         \*\*kwargs | ||||||
|  |             The keyword arguments to use. | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         arguments = [] | ||||||
|  |         if command.instance is not None: | ||||||
|  |             arguments.append(command.instance) | ||||||
|  |  | ||||||
|  |         if command.pass_context: | ||||||
|  |             arguments.append(self) | ||||||
|  |  | ||||||
|  |         arguments.extend(args) | ||||||
|  |  | ||||||
|  |         yield from command.callback(*arguments, **kwargs) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user