mirror of
https://github.com/Rapptz/discord.py.git
synced 2025-10-24 10:02:56 +00:00
Add delay kwarg to message.delete()
Refactor delete_after kwargs to use new delay kwarg
This commit is contained in:
@@ -784,13 +784,7 @@ class Messageable(metaclass=abc.ABCMeta):
|
|||||||
|
|
||||||
ret = state.create_message(channel=channel, data=data)
|
ret = state.create_message(channel=channel, data=data)
|
||||||
if delete_after is not None:
|
if delete_after is not None:
|
||||||
async def delete():
|
await ret.delete(delay=delete_after)
|
||||||
await asyncio.sleep(delete_after, loop=state.loop)
|
|
||||||
try:
|
|
||||||
await ret.delete()
|
|
||||||
except HTTPException:
|
|
||||||
pass
|
|
||||||
asyncio.ensure_future(delete(), loop=state.loop)
|
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
async def trigger_typing(self):
|
async def trigger_typing(self):
|
||||||
|
@@ -563,7 +563,7 @@ class Message:
|
|||||||
else:
|
else:
|
||||||
return '{0.author.name} started a call \N{EM DASH} Join the call.'.format(self)
|
return '{0.author.name} started a call \N{EM DASH} Join the call.'.format(self)
|
||||||
|
|
||||||
async def delete(self):
|
async def delete(self, *, delay=None):
|
||||||
"""|coro|
|
"""|coro|
|
||||||
|
|
||||||
Deletes the message.
|
Deletes the message.
|
||||||
@@ -572,6 +572,12 @@ class Message:
|
|||||||
delete other people's messages, you need the :attr:`~Permissions.manage_messages`
|
delete other people's messages, you need the :attr:`~Permissions.manage_messages`
|
||||||
permission.
|
permission.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
-----------
|
||||||
|
delay: Optional[:class:`float`]
|
||||||
|
If provided, the number of seconds to wait in the background
|
||||||
|
before deleting the message.
|
||||||
|
|
||||||
Raises
|
Raises
|
||||||
------
|
------
|
||||||
Forbidden
|
Forbidden
|
||||||
@@ -579,7 +585,17 @@ class Message:
|
|||||||
HTTPException
|
HTTPException
|
||||||
Deleting the message failed.
|
Deleting the message failed.
|
||||||
"""
|
"""
|
||||||
await self._state.http.delete_message(self.channel.id, self.id)
|
if delay is not None:
|
||||||
|
async def delete():
|
||||||
|
await asyncio.sleep(delay, loop=self._state.loop)
|
||||||
|
try:
|
||||||
|
await self._state.http.delete_message(self.channel.id, self.id)
|
||||||
|
except HTTPException:
|
||||||
|
pass
|
||||||
|
|
||||||
|
asyncio.ensure_future(delete(), loop=self._state.loop)
|
||||||
|
else:
|
||||||
|
await self._state.http.delete_message(self.channel.id, self.id)
|
||||||
|
|
||||||
async def edit(self, **fields):
|
async def edit(self, **fields):
|
||||||
"""|coro|
|
"""|coro|
|
||||||
@@ -632,14 +648,7 @@ class Message:
|
|||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
if delete_after is not None:
|
if delete_after is not None:
|
||||||
async def delete():
|
await self.delete(delay=delete_after)
|
||||||
await asyncio.sleep(delete_after, loop=self._state.loop)
|
|
||||||
try:
|
|
||||||
await self._state.http.delete_message(self.channel.id, self.id)
|
|
||||||
except HTTPException:
|
|
||||||
pass
|
|
||||||
|
|
||||||
asyncio.ensure_future(delete(), loop=self._state.loop)
|
|
||||||
|
|
||||||
async def pin(self):
|
async def pin(self):
|
||||||
"""|coro|
|
"""|coro|
|
||||||
|
Reference in New Issue
Block a user