diff --git a/discord/ext/commands/cog.py b/discord/ext/commands/cog.py index 4ccc1f4ec..1ffe25c70 100644 --- a/discord/ext/commands/cog.py +++ b/discord/ext/commands/cog.py @@ -362,6 +362,8 @@ class Cog(metaclass=CogMeta): if isinstance(app_command, app_commands.Group): for child in app_command.walk_commands(): app_command_refs[child.qualified_name] = child + if hasattr(child, '__commands_is_hybrid_app_command__') and child.qualified_name in lookup: + child.wrapped = lookup[child.qualified_name] # type: ignore if self.__cog_app_commands_group__: children.append(app_command) # type: ignore # Somehow it thinks it can be None here diff --git a/discord/ext/commands/hybrid.py b/discord/ext/commands/hybrid.py index 3b588ef64..a8775474d 100644 --- a/discord/ext/commands/hybrid.py +++ b/discord/ext/commands/hybrid.py @@ -297,6 +297,8 @@ def replace_parameters( class HybridAppCommand(discord.app_commands.Command[CogT, P, T]): + __commands_is_hybrid_app_command__: ClassVar[bool] = True + def __init__( self, wrapped: Union[HybridCommand[CogT, ..., T], HybridGroup[CogT, ..., T]], diff --git a/tests/test_app_commands_group.py b/tests/test_app_commands_group.py index 228debde6..4445cfa98 100644 --- a/tests/test_app_commands_group.py +++ b/tests/test_app_commands_group.py @@ -479,3 +479,31 @@ def test_cog_hybrid_group_manual_nested_command(): assert isinstance(third, app_commands.Command) assert third.parent is second assert third.binding is cog + + +def test_cog_hybrid_group_wrapped_instance(): + class MyCog(commands.Cog): + @commands.hybrid_group(fallback='fallback') + async def first(self, ctx: commands.Context) -> None: + pass + + @first.command() + async def second(self, ctx: commands.Context) -> None: + pass + + @first.group() + async def nested(self, ctx: commands.Context) -> None: + pass + + @nested.app_command.command() + async def child(self, interaction: discord.Interaction) -> None: + pass + + cog = MyCog() + + fallback = cog.first.app_command.get_command('fallback') + assert fallback is not None + assert getattr(fallback, 'wrapped', None) is cog.first + assert fallback.parent is cog.first.app_command + assert cog.second.app_command is not None + assert cog.second.app_command.wrapped is cog.second