Support Group with app_commands.guilds decorator

This commit is contained in:
Rapptz
2022-03-09 00:51:59 -05:00
parent 9d27855755
commit 303d33bb08
2 changed files with 8 additions and 5 deletions

View File

@@ -313,6 +313,8 @@ class Command(Generic[GroupT, P, T]):
The parent application command. ``None`` if there isn't one. The parent application command. ``None`` if there isn't one.
""" """
__discord_app_commands_default_guilds__: List[int]
def __init__( def __init__(
self, self,
*, *,
@@ -620,6 +622,7 @@ class Group:
""" """
__discord_app_commands_group_children__: ClassVar[Dict[str, Union[Command, Group]]] = {} __discord_app_commands_group_children__: ClassVar[Dict[str, Union[Command, Group]]] = {}
__discord_app_commands_default_guilds__: List[int]
__discord_app_commands_group_name__: str = MISSING __discord_app_commands_group_name__: str = MISSING
__discord_app_commands_group_description__: str = MISSING __discord_app_commands_group_description__: str = MISSING
@@ -1109,8 +1112,8 @@ def guilds(*guild_ids: Union[Snowflake, int]) -> Callable[[T], T]:
defaults: List[int] = [g if isinstance(g, int) else g.id for g in guild_ids] defaults: List[int] = [g if isinstance(g, int) else g.id for g in guild_ids]
def decorator(inner: T) -> T: def decorator(inner: T) -> T:
if isinstance(inner, Command): if isinstance(inner, (Command, Group)):
inner._callback.__discord_app_commands_default_guilds__ = defaults inner.__discord_app_commands_default_guilds__ = defaults
else: else:
# Runtime attribute assignment # Runtime attribute assignment
inner.__discord_app_commands_default_guilds__ = defaults # type: ignore inner.__discord_app_commands_default_guilds__ = defaults # type: ignore

View File

@@ -55,7 +55,7 @@ ClientT = TypeVar('ClientT', bound='Client')
def _retrieve_guild_ids( def _retrieve_guild_ids(
callback: Any, guild: Optional[Snowflake] = MISSING, guilds: List[Snowflake] = MISSING command: Any, guild: Optional[Snowflake] = MISSING, guilds: List[Snowflake] = MISSING
) -> Optional[Set[int]]: ) -> Optional[Set[int]]:
if guild is not MISSING and guilds is not MISSING: if guild is not MISSING and guilds is not MISSING:
raise TypeError('cannot mix guild and guilds keyword arguments') raise TypeError('cannot mix guild and guilds keyword arguments')
@@ -65,7 +65,7 @@ def _retrieve_guild_ids(
# If no arguments are given then it should default to the ones # If no arguments are given then it should default to the ones
# given to the guilds(...) decorator or None for global. # given to the guilds(...) decorator or None for global.
if guild is MISSING: if guild is MISSING:
return getattr(callback, '__discord_app_commands_default_guilds__', None) return getattr(command, '__discord_app_commands_default_guilds__', None)
# guilds=[] is the same as global # guilds=[] is the same as global
if len(guilds) == 0: if len(guilds) == 0:
@@ -185,7 +185,7 @@ class CommandTree(Generic[ClientT]):
This is currently 100 for slash commands and 5 for context menu commands. This is currently 100 for slash commands and 5 for context menu commands.
""" """
guild_ids = _retrieve_guild_ids(getattr(command, '_callback', None), guild, guilds) guild_ids = _retrieve_guild_ids(command, guild, guilds)
if isinstance(command, ContextMenu): if isinstance(command, ContextMenu):
type = command.type.value type = command.type.value
name = command.name name = command.name