Yury Selivanov | 6370f34 | 2017-12-10 18:36:12 -0500 | [diff] [blame] | 1 | __all__ = () |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 2 | |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 3 | import reprlib |
| 4 | |
Andrew Svetlov | f74ef45 | 2017-12-15 07:04:38 +0200 | [diff] [blame] | 5 | from . import format_helpers |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 6 | |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 7 | # States for Future. |
| 8 | _PENDING = 'PENDING' |
| 9 | _CANCELLED = 'CANCELLED' |
| 10 | _FINISHED = 'FINISHED' |
| 11 | |
| 12 | |
| 13 | def isfuture(obj): |
| 14 | """Check for a Future. |
| 15 | |
| 16 | This returns True when obj is a Future instance or is advertising |
| 17 | itself as duck-type compatible by setting _asyncio_future_blocking. |
| 18 | See comment in Future for more details. |
| 19 | """ |
Yury Selivanov | 6130c02 | 2016-11-07 16:07:30 -0500 | [diff] [blame] | 20 | return (hasattr(obj.__class__, '_asyncio_future_blocking') and |
| 21 | obj._asyncio_future_blocking is not None) |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 22 | |
| 23 | |
| 24 | def _format_callbacks(cb): |
| 25 | """helper function for Future.__repr__""" |
| 26 | size = len(cb) |
| 27 | if not size: |
| 28 | cb = '' |
| 29 | |
| 30 | def format_cb(callback): |
Andrew Svetlov | f74ef45 | 2017-12-15 07:04:38 +0200 | [diff] [blame] | 31 | return format_helpers._format_callback_source(callback, ()) |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 32 | |
| 33 | if size == 1: |
Yury Selivanov | f23746a | 2018-01-22 19:11:18 -0500 | [diff] [blame] | 34 | cb = format_cb(cb[0][0]) |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 35 | elif size == 2: |
Yury Selivanov | f23746a | 2018-01-22 19:11:18 -0500 | [diff] [blame] | 36 | cb = '{}, {}'.format(format_cb(cb[0][0]), format_cb(cb[1][0])) |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 37 | elif size > 2: |
Yury Selivanov | f23746a | 2018-01-22 19:11:18 -0500 | [diff] [blame] | 38 | cb = '{}, <{} more>, {}'.format(format_cb(cb[0][0]), |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 39 | size - 2, |
Yury Selivanov | f23746a | 2018-01-22 19:11:18 -0500 | [diff] [blame] | 40 | format_cb(cb[-1][0])) |
Yury Selivanov | 6370f34 | 2017-12-10 18:36:12 -0500 | [diff] [blame] | 41 | return f'cb=[{cb}]' |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 42 | |
| 43 | |
| 44 | def _future_repr_info(future): |
| 45 | # (Future) -> str |
| 46 | """helper function for Future.__repr__""" |
| 47 | info = [future._state.lower()] |
| 48 | if future._state == _FINISHED: |
| 49 | if future._exception is not None: |
Yury Selivanov | 6370f34 | 2017-12-10 18:36:12 -0500 | [diff] [blame] | 50 | info.append(f'exception={future._exception!r}') |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 51 | else: |
| 52 | # use reprlib to limit the length of the output, especially |
| 53 | # for very long strings |
| 54 | result = reprlib.repr(future._result) |
Yury Selivanov | 6370f34 | 2017-12-10 18:36:12 -0500 | [diff] [blame] | 55 | info.append(f'result={result}') |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 56 | if future._callbacks: |
| 57 | info.append(_format_callbacks(future._callbacks)) |
| 58 | if future._source_traceback: |
| 59 | frame = future._source_traceback[-1] |
Yury Selivanov | 6370f34 | 2017-12-10 18:36:12 -0500 | [diff] [blame] | 60 | info.append(f'created at {frame[0]}:{frame[1]}') |
Yury Selivanov | a0c1ba6 | 2016-10-28 12:52:37 -0400 | [diff] [blame] | 61 | return info |