2017-12-11 07:36:12 +08:00
|
|
|
__all__ = ()
|
2016-10-29 00:52:37 +08:00
|
|
|
|
|
|
|
import reprlib
|
|
|
|
|
2017-12-15 13:04:38 +08:00
|
|
|
from . import format_helpers
|
2016-10-29 00:52:37 +08:00
|
|
|
|
|
|
|
# States for Future.
|
|
|
|
_PENDING = 'PENDING'
|
|
|
|
_CANCELLED = 'CANCELLED'
|
|
|
|
_FINISHED = 'FINISHED'
|
|
|
|
|
|
|
|
|
|
|
|
def isfuture(obj):
|
|
|
|
"""Check for a Future.
|
|
|
|
|
|
|
|
This returns True when obj is a Future instance or is advertising
|
|
|
|
itself as duck-type compatible by setting _asyncio_future_blocking.
|
|
|
|
See comment in Future for more details.
|
|
|
|
"""
|
2016-11-08 05:07:30 +08:00
|
|
|
return (hasattr(obj.__class__, '_asyncio_future_blocking') and
|
|
|
|
obj._asyncio_future_blocking is not None)
|
2016-10-29 00:52:37 +08:00
|
|
|
|
|
|
|
|
|
|
|
def _format_callbacks(cb):
|
|
|
|
"""helper function for Future.__repr__"""
|
|
|
|
size = len(cb)
|
|
|
|
if not size:
|
|
|
|
cb = ''
|
|
|
|
|
|
|
|
def format_cb(callback):
|
2017-12-15 13:04:38 +08:00
|
|
|
return format_helpers._format_callback_source(callback, ())
|
2016-10-29 00:52:37 +08:00
|
|
|
|
|
|
|
if size == 1:
|
2018-01-23 08:11:18 +08:00
|
|
|
cb = format_cb(cb[0][0])
|
2016-10-29 00:52:37 +08:00
|
|
|
elif size == 2:
|
2018-01-23 08:11:18 +08:00
|
|
|
cb = '{}, {}'.format(format_cb(cb[0][0]), format_cb(cb[1][0]))
|
2016-10-29 00:52:37 +08:00
|
|
|
elif size > 2:
|
2018-01-23 08:11:18 +08:00
|
|
|
cb = '{}, <{} more>, {}'.format(format_cb(cb[0][0]),
|
2016-10-29 00:52:37 +08:00
|
|
|
size - 2,
|
2018-01-23 08:11:18 +08:00
|
|
|
format_cb(cb[-1][0]))
|
2017-12-11 07:36:12 +08:00
|
|
|
return f'cb=[{cb}]'
|
2016-10-29 00:52:37 +08:00
|
|
|
|
|
|
|
|
|
|
|
def _future_repr_info(future):
|
|
|
|
# (Future) -> str
|
|
|
|
"""helper function for Future.__repr__"""
|
|
|
|
info = [future._state.lower()]
|
|
|
|
if future._state == _FINISHED:
|
|
|
|
if future._exception is not None:
|
2017-12-11 07:36:12 +08:00
|
|
|
info.append(f'exception={future._exception!r}')
|
2016-10-29 00:52:37 +08:00
|
|
|
else:
|
2022-03-17 09:03:09 +08:00
|
|
|
# use reprlib to limit the length of the output, especially
|
|
|
|
# for very long strings
|
|
|
|
result = reprlib.repr(future._result)
|
2017-12-11 07:36:12 +08:00
|
|
|
info.append(f'result={result}')
|
2016-10-29 00:52:37 +08:00
|
|
|
if future._callbacks:
|
|
|
|
info.append(_format_callbacks(future._callbacks))
|
|
|
|
if future._source_traceback:
|
|
|
|
frame = future._source_traceback[-1]
|
2017-12-11 07:36:12 +08:00
|
|
|
info.append(f'created at {frame[0]}:{frame[1]}')
|
2016-10-29 00:52:37 +08:00
|
|
|
return info
|
2022-03-17 09:03:09 +08:00
|
|
|
|
|
|
|
|
|
|
|
@reprlib.recursive_repr()
|
|
|
|
def _future_repr(future):
|
|
|
|
info = ' '.join(_future_repr_info(future))
|
|
|
|
return f'<{future.__class__.__name__} {info}>'
|