mirror of
				https://github.com/Rapptz/discord.py.git
				synced 2025-10-25 02:23:04 +00:00 
			
		
		
		
	[tasks] Add Loop.exception for more reliable exception retrieval.
This commit is contained in:
		| @@ -40,6 +40,7 @@ class Loop: | |||||||
|         self._is_being_cancelled = False |         self._is_being_cancelled = False | ||||||
|         self._has_failed = False |         self._has_failed = False | ||||||
|         self._stop_next_iteration = False |         self._stop_next_iteration = False | ||||||
|  |         self._exception = None | ||||||
|  |  | ||||||
|         if self.count is not None and self.count <= 0: |         if self.count is not None and self.count <= 0: | ||||||
|             raise ValueError('count must be greater than 0 or None.') |             raise ValueError('count must be greater than 0 or None.') | ||||||
| @@ -81,8 +82,9 @@ class Loop: | |||||||
|         except asyncio.CancelledError: |         except asyncio.CancelledError: | ||||||
|             self._is_being_cancelled = True |             self._is_being_cancelled = True | ||||||
|             raise |             raise | ||||||
|         except Exception: |         except Exception as e: | ||||||
|             self._has_failed = True |             self._has_failed = True | ||||||
|  |             self._exception = e | ||||||
|             log.exception('Internal background task failed.') |             log.exception('Internal background task failed.') | ||||||
|             raise |             raise | ||||||
|         finally: |         finally: | ||||||
| @@ -91,6 +93,7 @@ class Loop: | |||||||
|             self._current_loop = 0 |             self._current_loop = 0 | ||||||
|             self._stop_next_iteration = False |             self._stop_next_iteration = False | ||||||
|             self._has_failed = False |             self._has_failed = False | ||||||
|  |             self._exception = None | ||||||
|  |  | ||||||
|     def __get__(self, obj, objtype): |     def __get__(self, obj, objtype): | ||||||
|         if obj is None: |         if obj is None: | ||||||
| @@ -255,6 +258,16 @@ class Loop: | |||||||
|         """ |         """ | ||||||
|         return self._has_failed |         return self._has_failed | ||||||
|  |  | ||||||
|  |     def exception(self): | ||||||
|  |         """Optional[:class:`Exception`]: The exception that the internal task failed with. | ||||||
|  |  | ||||||
|  |         .. versionadded:: 1.3.0 | ||||||
|  |         """ | ||||||
|  |         if self._exception is not None: | ||||||
|  |             return self._exception | ||||||
|  |         if self._task is not None: | ||||||
|  |             return self._task.exception() | ||||||
|  |  | ||||||
|     def before_loop(self, coro): |     def before_loop(self, coro): | ||||||
|         """A decorator that registers a coroutine to be called before the loop starts running. |         """A decorator that registers a coroutine to be called before the loop starts running. | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user