2017-12-10 19:36:12 -04:00
|
|
|
__all__ = ()
|
2016-10-28 13:52:37 -03:00
|
|
|
|
|
|
|
import concurrent.futures._base
|
|
|
|
import reprlib
|
|
|
|
|
2017-12-15 01:04:38 -04:00
|
|
|
from . import format_helpers
|
2016-10-28 13:52:37 -03:00
|
|
|
|
|
|
|
Error = concurrent.futures._base.Error
|
|
|
|
CancelledError = concurrent.futures.CancelledError
|
|
|
|
TimeoutError = concurrent.futures.TimeoutError
|
|
|
|
|
|
|
|
|
|
|
|
class InvalidStateError(Error):
|
|
|
|
"""The operation is not allowed in this state."""
|
|
|
|
|
|
|
|
|
|
|
|
# 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-07 17:07:30 -04:00
|
|
|
return (hasattr(obj.__class__, '_asyncio_future_blocking') and
|
|
|
|
obj._asyncio_future_blocking is not None)
|
2016-10-28 13:52:37 -03:00
|
|
|
|
|
|
|
|
|
|
|
def _format_callbacks(cb):
|
|
|
|
"""helper function for Future.__repr__"""
|
|
|
|
size = len(cb)
|
|
|
|
if not size:
|
|
|
|
cb = ''
|
|
|
|
|
|
|
|
def format_cb(callback):
|
2017-12-15 01:04:38 -04:00
|
|
|
return format_helpers._format_callback_source(callback, ())
|
2016-10-28 13:52:37 -03:00
|
|
|
|
|
|
|
if size == 1:
|
2018-01-22 20:11:18 -04:00
|
|
|
cb = format_cb(cb[0][0])
|
2016-10-28 13:52:37 -03:00
|
|
|
elif size == 2:
|
2018-01-22 20:11:18 -04:00
|
|
|
cb = '{}, {}'.format(format_cb(cb[0][0]), format_cb(cb[1][0]))
|
2016-10-28 13:52:37 -03:00
|
|
|
elif size > 2:
|
2018-01-22 20:11:18 -04:00
|
|
|
cb = '{}, <{} more>, {}'.format(format_cb(cb[0][0]),
|
2016-10-28 13:52:37 -03:00
|
|
|
size - 2,
|
2018-01-22 20:11:18 -04:00
|
|
|
format_cb(cb[-1][0]))
|
2017-12-10 19:36:12 -04:00
|
|
|
return f'cb=[{cb}]'
|
2016-10-28 13:52:37 -03: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-10 19:36:12 -04:00
|
|
|
info.append(f'exception={future._exception!r}')
|
2016-10-28 13:52:37 -03:00
|
|
|
else:
|
|
|
|
# use reprlib to limit the length of the output, especially
|
|
|
|
# for very long strings
|
|
|
|
result = reprlib.repr(future._result)
|
2017-12-10 19:36:12 -04:00
|
|
|
info.append(f'result={result}')
|
2016-10-28 13:52:37 -03:00
|
|
|
if future._callbacks:
|
|
|
|
info.append(_format_callbacks(future._callbacks))
|
|
|
|
if future._source_traceback:
|
|
|
|
frame = future._source_traceback[-1]
|
2017-12-10 19:36:12 -04:00
|
|
|
info.append(f'created at {frame[0]}:{frame[1]}')
|
2016-10-28 13:52:37 -03:00
|
|
|
return info
|