Change default guild IDs attribute to persist on copy

This commit is contained in:
Rapptz
2022-03-09 19:11:30 -05:00
parent 0d126c594c
commit 5741ad9368
2 changed files with 7 additions and 6 deletions

View File

@@ -314,8 +314,6 @@ 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,
*, *,
@@ -332,6 +330,7 @@ class Command(Generic[GroupT, P, T]):
self.binding: Optional[GroupT] = None self.binding: Optional[GroupT] = None
self.on_error: Optional[Error[GroupT]] = None self.on_error: Optional[Error[GroupT]] = None
self._params: Dict[str, CommandParameter] = _extract_parameters_from_callback(callback, callback.__globals__) self._params: Dict[str, CommandParameter] = _extract_parameters_from_callback(callback, callback.__globals__)
self._guild_ids: Optional[List[int]] = getattr(callback, '__discord_app_commands_default_guilds__', None)
def __set_name__(self, owner: Type[Any], name: str) -> None: def __set_name__(self, owner: Type[Any], name: str) -> None:
self._attr = name self._attr = name
@@ -345,6 +344,7 @@ class Command(Generic[GroupT, P, T]):
cls = self.__class__ cls = self.__class__
copy = cls.__new__(cls) copy = cls.__new__(cls)
copy.name = self.name copy.name = self.name
copy._guild_ids = self._guild_ids
copy.description = self.description copy.description = self.description
copy._attr = self._attr copy._attr = self._attr
copy._callback = self._callback copy._callback = self._callback
@@ -628,7 +628,6 @@ class Group:
""" """
__discord_app_commands_group_children__: ClassVar[List[Union[Command, Group]]] = [] __discord_app_commands_group_children__: ClassVar[List[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
@@ -636,7 +635,7 @@ class Group:
if not cls.__discord_app_commands_group_children__: if not cls.__discord_app_commands_group_children__:
cls.__discord_app_commands_group_children__ = children = [ cls.__discord_app_commands_group_children__ = children = [
member member
for name, member in cls.__dict__.items() for member in cls.__dict__.values()
if isinstance(member, (Group, Command)) and member.parent is None if isinstance(member, (Group, Command)) and member.parent is None
] ]
@@ -674,6 +673,7 @@ class Group:
self.name: str = name if name is not MISSING else cls.__discord_app_commands_group_name__ self.name: str = name if name is not MISSING else cls.__discord_app_commands_group_name__
self.description: str = description or cls.__discord_app_commands_group_description__ self.description: str = description or cls.__discord_app_commands_group_description__
self._attr: Optional[str] = None self._attr: Optional[str] = None
self._guild_ids: Optional[List[int]] = None
if not self.description: if not self.description:
raise TypeError('groups must have a description') raise TypeError('groups must have a description')
@@ -699,6 +699,7 @@ class Group:
cls = self.__class__ cls = self.__class__
copy = cls.__new__(cls) copy = cls.__new__(cls)
copy.name = self.name copy.name = self.name
copy._guild_ids = self._guild_ids
copy.description = self.description copy.description = self.description
copy.parent = self.parent copy.parent = self.parent
copy._attr = self._attr copy._attr = self._attr
@@ -1127,7 +1128,7 @@ def guilds(*guild_ids: Union[Snowflake, int]) -> Callable[[T], T]:
def decorator(inner: T) -> T: def decorator(inner: T) -> T:
if isinstance(inner, (Command, Group)): if isinstance(inner, (Command, Group)):
inner.__discord_app_commands_default_guilds__ = defaults inner._guild_ids = 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

@@ -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(command, '__discord_app_commands_default_guilds__', None) return getattr(command, '_guild_ids', None)
# guilds=[] is the same as global # guilds=[] is the same as global
if len(guilds) == 0: if len(guilds) == 0: