Browse Source

[tasks] Keep retrying before gracefully exiting.

pull/2152/head
Rapptz 6 years ago
parent
commit
49a7e58d17
  1. 12
      discord/ext/tasks/__init__.py

12
discord/ext/tasks/__init__.py

@ -74,8 +74,6 @@ class Loop:
except self._valid_exception as exc:
if not self.reconnect:
raise
if self._stop_next_iteration:
return
await asyncio.sleep(backoff.delay())
else:
if self._stop_next_iteration:
@ -141,6 +139,16 @@ class Loop:
Unlike :meth:`cancel`\, this allows the task to finish its
current iteration before gracefully exiting.
.. note::
If the internal function raises an error that can be
handled before finishing then it will retry until
it succeeds.
If this is undesirable, either remove the error handling
before stopping via :meth:`clear_exception_types` or
use :meth:`cancel` instead.
.. versionadded:: 1.2
"""
if self._task and not self._task.done():

Loading…
Cancel
Save