diff options
| author | Vexs <[email protected]> | 2019-03-23 21:46:05 -0500 |
|---|---|---|
| committer | Rapptz <[email protected]> | 2019-04-06 19:18:06 -0400 |
| commit | 9591b00dcfb79a18288211473006fe562518b307 (patch) | |
| tree | 96074f457784f0cf0b5d03d287b34bcbd91d72ce /docs | |
| parent | Redesign asset retrieval in the library. (diff) | |
| download | discord.py-9591b00dcfb79a18288211473006fe562518b307.tar.xz discord.py-9591b00dcfb79a18288211473006fe562518b307.zip | |
Redesign bulk delete events
Change `parse_message_delete_bulk` to not dispatch individual
`message_delete` events, and instead `bulk_message_delete`. Also make
`raw_bulk_message` delete and `raw_message_delete` have message
objects attached.
Fixes #1807
Diffstat (limited to 'docs')
| -rw-r--r-- | docs/api.rst | 40 |
1 files changed, 31 insertions, 9 deletions
diff --git a/docs/api.rst b/docs/api.rst index 0c36ffe2..7ba1a996 100644 --- a/docs/api.rst +++ b/docs/api.rst @@ -227,25 +227,45 @@ to handle it, which defaults to print a traceback and ignoring the exception. .. function:: on_message_delete(message) Called when a message is deleted. If the message is not found in the - internal message cache, then these events will not be called. This - happens if the message is too old or the client is participating in high - traffic guilds. To fix this, increase the ``max_messages`` option of - :class:`Client`. + internal message cache, then this event will not be called. + Messages might not be in cache if the message is too old + or the client is participating in high traffic guilds. + + If this occurs increase the :attr:`Client.max_messages` attribute. :param message: A :class:`Message` of the deleted message. +.. function:: on_bulk_message_delete(messages) + + Called when messages are bulk deleted. If none of the messages deleted + are found in the internal message cache, then this event will not be called. + If individual messages were not found in the internal message cache, + this event will still be called, but the messages not found will not be included in + the messages list. Messages might not be in cache if the message is too old + or the client is participating in high traffic guilds. + + If this occurs increase the :attr:`Client.max_messages` attribute. + + :param messages: A :class:`list` of :class:`Message` that have been deleted. + .. function:: on_raw_message_delete(payload) Called when a message is deleted. Unlike :func:`on_message_delete`, this is called regardless of the message being in the internal message cache or not. + If the message is found in the message cache, + it can be accessed via:attr:`RawMessageDeleteEvent.cached_message` + :param payload: The raw event payload data. :type payload: :class:`RawMessageDeleteEvent` .. function:: on_raw_bulk_message_delete(payload) - Called when a bulk delete is triggered. This event is called regardless - of the message IDs being in the internal message cache or not. + Called when a bulk delete is triggered. Unlike :func:`on_bulk_message_delete`, this is + called regardless of the messages being in the internal message cache or not. + + If the messages are found in the message cache, + they can be accessed via :attr:`RawBulkMessageDeleteEvent.cached_messages` :param payload: The raw event payload data. :type payload: :class:`RawBulkMessageDeleteEvent` @@ -254,8 +274,10 @@ to handle it, which defaults to print a traceback and ignoring the exception. Called when a :class:`Message` receives an update event. If the message is not found in the internal message cache, then these events will not be called. - This happens if the message is too old or the client is participating in high - traffic guilds. To fix this, increase the ``max_messages`` option of :class:`Client`. + Messages might not be in cache if the message is too old + or the client is participating in high traffic guilds. + + If this occurs increase the :attr:`Client.max_messages` attribute. The following non-exhaustive cases trigger this event: @@ -288,7 +310,7 @@ to handle it, which defaults to print a traceback and ignoring the exception. .. function:: on_reaction_add(reaction, user) - Called when a message has a reaction added to it. Similar to on_message_edit, + Called when a message has a reaction added to it. Similar to :func:`on_message_edit`, if the message is not found in the internal message cache, then this event will not be called. |