From 6d1069e7896337f5abeabc6a99dd6a997ca57944 Mon Sep 17 00:00:00 2001 From: Stocker <44980366+StockerMC@users.noreply.github.com> Date: Wed, 27 Jul 2022 00:29:53 -0400 Subject: [PATCH] Fix cog_app_command_error for groups --- discord/app_commands/commands.py | 4 ++++ discord/ext/commands/cog.py | 15 ++++++++++----- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/discord/app_commands/commands.py b/discord/app_commands/commands.py index 9e94cc172..9427f8c04 100644 --- a/discord/app_commands/commands.py +++ b/discord/app_commands/commands.py @@ -1269,6 +1269,10 @@ class Group: raise ValueError('groups can only be nested at most one level') parent.add_command(self) + self.__app_commands_error_handler__: Optional[ + Callable[[Interaction, AppCommandError], Coroutine[Any, Any, None]] + ] = None + def __set_name__(self, owner: Type[Any], name: str) -> None: self._attr = name self.module = owner.__module__ diff --git a/discord/ext/commands/cog.py b/discord/ext/commands/cog.py index 19d684a6f..218652260 100644 --- a/discord/ext/commands/cog.py +++ b/discord/ext/commands/cog.py @@ -328,6 +328,13 @@ class Cog(metaclass=CogMeta): if self.__cog_app_commands_group__: children.append(app_command) + if Cog._get_overridden_method(self.cog_app_command_error) is not None: + error_handler = self.cog_app_command_error + else: + error_handler = None + + self.__app_commands_error_handler__ = error_handler + for command in cls.__cog_app_commands__: copy = command._copy_with(parent=self.__cog_app_commands_group__, binding=self) @@ -335,6 +342,9 @@ class Cog(metaclass=CogMeta): if copy._attr: setattr(self, copy._attr, copy) + if isinstance(copy, app_commands.Group): + copy.__app_commands_error_handler__ = error_handler + children.append(copy) self.__cog_app_commands__ = children @@ -346,11 +356,6 @@ class Cog(metaclass=CogMeta): self.__cog_app_commands_group__._children = mapping # type: ignore # Variance issue - if Cog._get_overridden_method(self.cog_app_command_error) is not None: - self.__app_commands_error_handler__ = self.cog_app_command_error - else: - self.__app_commands_error_handler__ = None - return self def get_commands(self) -> List[Command[Self, ..., Any]]: