Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: auto-generate overloads for Client.wait_for #1017

Open
wants to merge 27 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
fe583fc
feat(codemod): autogen `Client.wait_for` overloads
shiftinv Apr 26, 2023
a7da890
feat: restrict ext.commands-specific overloads to bot classes
shiftinv Apr 26, 2023
2058a74
feat: add `wait_for` fallback for `event: str`
shiftinv Apr 27, 2023
0b19feb
test: add typing tests
shiftinv Apr 27, 2023
2e5d765
refactor: move thingy to a separate method
shiftinv Apr 27, 2023
8c29ed5
refactor: make codemod more extensible
shiftinv Apr 28, 2023
d896193
feat: add better error message for missing events
shiftinv Apr 28, 2023
cf276c7
chore: stuff
shiftinv Apr 28, 2023
f22006c
refactor: move event data to separate module
shiftinv Apr 30, 2023
624fc36
chore: make `EventData` kwarg-only
shiftinv Apr 30, 2023
0b5f68b
style: put EventData args on separate lines
shiftinv Apr 30, 2023
5875706
chore: move annotations into `EventData.__init__`
shiftinv Apr 30, 2023
61f85fb
docs: add changelog entry
shiftinv Jun 13, 2023
602b315
chore: rename `type_args` field to `arg_types`
shiftinv Jun 13, 2023
c5e4d33
Merge remote-tracking branch 'upstream/master' into feature/codemod-w…
shiftinv Aug 1, 2023
f80d199
fix: remove duplicate key from pyproject
shiftinv Aug 1, 2023
f92a984
fix: add codemod to new combined module
shiftinv Aug 1, 2023
fd56f51
Merge remote-tracking branch 'upstream/master' into feature/codemod-w…
shiftinv Sep 20, 2023
600af60
fix(typing): add generic bot parameter to interaction types
shiftinv Sep 20, 2023
496902a
feat(typing): add generic bot parameter to `Context` events
shiftinv Sep 20, 2023
2f04e8d
Merge remote-tracking branch 'upstream/master' into feature/codemod-w…
shiftinv Jan 2, 2024
5bba9e3
chore: remove unnecessary type-ignore
shiftinv Jan 2, 2024
625964b
Merge remote-tracking branch 'upstream/master' into feature/codemod-w…
shiftinv Feb 24, 2024
f0f44e9
feat: add new entitlement/presence events
shiftinv Feb 24, 2024
251f8ec
perf(codemod): use `CHECK_MARKER` instead of `tree.code`
shiftinv Feb 24, 2024
79b2e87
Merge remote-tracking branch 'upstream/master' into feature/codemod-w…
shiftinv Dec 11, 2024
f248d30
feat: add overloads for new events
shiftinv Dec 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions changelog/1017.feature.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add typing overloads to :meth:`Client.wait_for` for every :class:`Event` value, allowing for correct typing of the ``check`` parameter and the return value.
381 changes: 381 additions & 0 deletions disnake/_event_data.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,381 @@
# SPDX-License-Identifier: MIT

from __future__ import annotations

from typing import Dict, List, Optional, Tuple

from .enums import Event


class EventData:
def __init__(
self,
*,
arg_types: List[str],
self_type: Optional[str] = None,
event_only: bool = False,
) -> None:
self.arg_types: Tuple[str, ...] = tuple(arg_types)
"""Type names of event arguments, e.g. `("Guild", "User")`."""

self.self_type: Optional[str] = self_type
"""The annotation for the `self` parameter, used for bot-only events."""

self.event_only: bool = event_only
"""Whether the event can only be used through `@event`, and not with listeners."""


EVENT_DATA: Dict[Event, EventData] = {
Event.connect: EventData(
arg_types=[],
),
Event.disconnect: EventData(
arg_types=[],
),
# FIXME: figure out how to specify varargs for these two if we ever add overloads for @event
Event.error: EventData(
arg_types=[],
event_only=True,
),
Event.gateway_error: EventData(
arg_types=[],
event_only=True,
),
Event.ready: EventData(
arg_types=[],
),
Event.resumed: EventData(
arg_types=[],
),
Event.shard_connect: EventData(
arg_types=["int"],
),
Event.shard_disconnect: EventData(
arg_types=["int"],
),
Event.shard_ready: EventData(
arg_types=["int"],
),
Event.shard_resumed: EventData(
arg_types=["int"],
),
Event.socket_event_type: EventData(
arg_types=["str"],
),
Event.socket_raw_receive: EventData(
arg_types=["str"],
),
Event.socket_raw_send: EventData(
arg_types=["Union[str, bytes]"],
),
Event.guild_channel_create: EventData(
arg_types=["GuildChannel"],
),
Event.guild_channel_update: EventData(
arg_types=["GuildChannel", "GuildChannel"],
),
Event.guild_channel_delete: EventData(
arg_types=["GuildChannel"],
),
Event.guild_channel_pins_update: EventData(
arg_types=["Union[GuildChannel, Thread]", "Optional[datetime]"],
),
Event.invite_create: EventData(
arg_types=["Invite"],
),
Event.invite_delete: EventData(
arg_types=["Invite"],
),
Event.private_channel_update: EventData(
arg_types=["GroupChannel", "GroupChannel"],
),
Event.private_channel_pins_update: EventData(
arg_types=["PrivateChannel", "Optional[datetime]"],
),
Event.webhooks_update: EventData(
arg_types=["GuildChannel"],
),
Event.thread_create: EventData(
arg_types=["Thread"],
),
Event.thread_update: EventData(
arg_types=["Thread", "Thread"],
),
Event.thread_delete: EventData(
arg_types=["Thread"],
),
Event.thread_join: EventData(
arg_types=["Thread"],
),
Event.thread_remove: EventData(
arg_types=["Thread"],
),
Event.thread_member_join: EventData(
arg_types=["ThreadMember"],
),
Event.thread_member_remove: EventData(
arg_types=["ThreadMember"],
),
Event.raw_thread_member_remove: EventData(
arg_types=["RawThreadMemberRemoveEvent"],
),
Event.raw_thread_update: EventData(
arg_types=["Thread"],
),
Event.raw_thread_delete: EventData(
arg_types=["RawThreadDeleteEvent"],
),
Event.guild_join: EventData(
arg_types=["Guild"],
),
Event.guild_remove: EventData(
arg_types=["Guild"],
),
Event.guild_update: EventData(
arg_types=["Guild", "Guild"],
),
Event.guild_available: EventData(
arg_types=["Guild"],
),
Event.guild_unavailable: EventData(
arg_types=["Guild"],
),
Event.guild_role_create: EventData(
arg_types=["Role"],
),
Event.guild_role_delete: EventData(
arg_types=["Role"],
),
Event.guild_role_update: EventData(
arg_types=["Role", "Role"],
),
Event.guild_emojis_update: EventData(
arg_types=["Guild", "Sequence[Emoji]", "Sequence[Emoji]"],
),
Event.guild_stickers_update: EventData(
arg_types=["Guild", "Sequence[GuildSticker]", "Sequence[GuildSticker]"],
),
Event.guild_integrations_update: EventData(
arg_types=["Guild"],
),
Event.guild_scheduled_event_create: EventData(
arg_types=["GuildScheduledEvent"],
),
Event.guild_scheduled_event_update: EventData(
arg_types=["GuildScheduledEvent", "GuildScheduledEvent"],
),
Event.guild_scheduled_event_delete: EventData(
arg_types=["GuildScheduledEvent"],
),
Event.guild_scheduled_event_subscribe: EventData(
arg_types=["GuildScheduledEvent", "Union[Member, User]"],
),
Event.guild_scheduled_event_unsubscribe: EventData(
arg_types=["GuildScheduledEvent", "Union[Member, User]"],
),
Event.raw_guild_scheduled_event_subscribe: EventData(
arg_types=["RawGuildScheduledEventUserActionEvent"],
),
Event.raw_guild_scheduled_event_unsubscribe: EventData(
arg_types=["RawGuildScheduledEventUserActionEvent"],
),
Event.application_command_permissions_update: EventData(
arg_types=["GuildApplicationCommandPermissions"],
),
Event.automod_action_execution: EventData(
arg_types=["AutoModActionExecution"],
),
Event.automod_rule_create: EventData(
arg_types=["AutoModRule"],
),
Event.automod_rule_update: EventData(
arg_types=["AutoModRule"],
),
Event.automod_rule_delete: EventData(
arg_types=["AutoModRule"],
),
Event.audit_log_entry_create: EventData(
arg_types=["AuditLogEntry"],
),
Event.integration_create: EventData(
arg_types=["Integration"],
),
Event.integration_update: EventData(
arg_types=["Integration"],
),
Event.raw_integration_delete: EventData(
arg_types=["RawIntegrationDeleteEvent"],
),
Event.member_join: EventData(
arg_types=["Member"],
),
Event.member_remove: EventData(
arg_types=["Member"],
),
Event.member_update: EventData(
arg_types=["Member", "Member"],
),
Event.raw_member_remove: EventData(
arg_types=["RawGuildMemberRemoveEvent"],
),
Event.raw_member_update: EventData(
arg_types=["Member"],
),
Event.member_ban: EventData(
arg_types=["Guild", "Union[User, Member]"],
),
Event.member_unban: EventData(
arg_types=["Guild", "User"],
),
Event.presence_update: EventData(
arg_types=["Member", "Member"],
),
Event.user_update: EventData(
arg_types=["User", "User"],
),
Event.voice_state_update: EventData(
arg_types=["Member", "VoiceState", "VoiceState"],
),
Event.stage_instance_create: EventData(
arg_types=["StageInstance"],
),
Event.stage_instance_delete: EventData(
arg_types=["StageInstance", "StageInstance"],
),
Event.stage_instance_update: EventData(
arg_types=["StageInstance"],
),
Event.application_command: EventData(
arg_types=["ApplicationCommandInteraction[Self]"],
),
Event.application_command_autocomplete: EventData(
arg_types=["ApplicationCommandInteraction[Self]"],
),
Event.button_click: EventData(
arg_types=["MessageInteraction[Self]"],
),
Event.dropdown: EventData(
arg_types=["MessageInteraction[Self]"],
),
Event.interaction: EventData(
arg_types=["Interaction[Self]"],
),
Event.message_interaction: EventData(
arg_types=["MessageInteraction[Self]"],
),
Event.modal_submit: EventData(
arg_types=["ModalInteraction[Self]"],
),
Event.message: EventData(
arg_types=["Message"],
),
Event.message_edit: EventData(
arg_types=["Message", "Message"],
),
Event.message_delete: EventData(
arg_types=["Message"],
),
Event.bulk_message_delete: EventData(
arg_types=["List[Message]"],
),
Event.raw_message_edit: EventData(
arg_types=["RawMessageUpdateEvent"],
),
Event.raw_message_delete: EventData(
arg_types=["RawMessageDeleteEvent"],
),
Event.raw_bulk_message_delete: EventData(
arg_types=["RawBulkMessageDeleteEvent"],
),
Event.reaction_add: EventData(
arg_types=["Reaction", "Union[Member, User]"],
),
Event.reaction_remove: EventData(
arg_types=["Reaction", "Union[Member, User]"],
),
Event.reaction_clear: EventData(
arg_types=["Message", "List[Reaction]"],
),
Event.reaction_clear_emoji: EventData(
arg_types=["Reaction"],
),
Event.raw_presence_update: EventData(
arg_types=["RawPresenceUpdateEvent"],
),
Event.raw_reaction_add: EventData(
arg_types=["RawReactionActionEvent"],
),
Event.raw_reaction_remove: EventData(
arg_types=["RawReactionActionEvent"],
),
Event.raw_reaction_clear: EventData(
arg_types=["RawReactionClearEvent"],
),
Event.raw_reaction_clear_emoji: EventData(
arg_types=["RawReactionClearEmojiEvent"],
),
Event.typing: EventData(
arg_types=["Union[Messageable, ForumChannel]", "Union[User, Member]", "datetime"],
),
Event.raw_typing: EventData(
arg_types=["RawTypingEvent"],
),
Event.entitlement_create: EventData(
arg_types=["Entitlement"],
),
Event.entitlement_update: EventData(
arg_types=["Entitlement"],
),
Event.entitlement_delete: EventData(
arg_types=["Entitlement"],
),
# bot-only:
Event.command: EventData(
arg_types=["commands.Context[AnyPrefixBotT]"],
self_type="AnyPrefixBotT",
),
Event.command_completion: EventData(
arg_types=["commands.Context[AnyPrefixBotT]"],
self_type="AnyPrefixBotT",
),
Event.command_error: EventData(
arg_types=["commands.Context[AnyPrefixBotT]", "commands.CommandError"],
self_type="AnyPrefixBotT",
),
Event.slash_command: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]"],
self_type="AnyBotT",
),
Event.slash_command_completion: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]"],
self_type="AnyBotT",
),
Event.slash_command_error: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]", "commands.CommandError"],
self_type="AnyBotT",
),
Event.user_command: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]"],
self_type="AnyBotT",
),
Event.user_command_completion: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]"],
self_type="AnyBotT",
),
Event.user_command_error: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]", "commands.CommandError"],
self_type="AnyBotT",
),
Event.message_command: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]"],
self_type="AnyBotT",
),
Event.message_command_completion: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]"],
self_type="AnyBotT",
),
Event.message_command_error: EventData(
arg_types=["ApplicationCommandInteraction[AnyBotT]", "commands.CommandError"],
self_type="AnyBotT",
),
}
Loading
Loading