tractor/tractor
Tyler Goodlet 32e760284f Hm, `asyncio.Task._fut_waiter.set_exception()`?
Since we can't use it to `Task.set_exception()` (since that task method never
seems to work.. XD) and setting the private/internal always seems to do
the desired raising in the task? I realize it's an internal `asyncio`
runtime field but i'd rather take the risk of it breaking then having to
rely on our own equivalent hack..

Also, it seems like the case where the task's associated (and internal)
future-waiter field is null, we won't run into the (same?) prior hanging
issues (maybe since there's nothing for `asyncio` internals to use to
wait XD ??) when `Task.cancel()` is used..??

Main deats,
- add and `Future.set_exception()` a new signal-exception
  `class TrioTaskExited(AsyncioCancelled):` whenever the trio-task exits
  gracefully and the asyncio-side task is still doing blocking work (of
  some sort) which *seem to* be predicated by a check that
  `._fut_waiter is not None`.
- always call `asyncio.Queue.shutdown()` for the same^ as well as
  whenever we decide to call `Task.cancel()`; in that case the shutdown
  relays correctly?

Some further refinements,
- only warn about `Task.cancel()` usage when actually used ;)
- more local scope vars setting in the exit phase of
  `translate_aio_errors()`.
- also in ^ use explicit caught-exc var names for each error-type.
2025-03-22 14:24:53 -04:00
..
_testing Move `mk_cmd()` to `._testing` 2025-03-22 14:23:58 -04:00
devx Drop extra nl from boxed error fmt 2025-03-22 14:24:53 -04:00
experimental Drop now-deprecated deps on modern `trio`/Python 2025-03-16 16:06:24 -04:00
msg Draft a (pretty)`Struct.fields_diff()` 2025-03-22 14:24:53 -04:00
trionics Change masked `.pause()` line 2025-03-22 14:24:53 -04:00
__init__.py Finally implement peer-lookup optimization.. 2025-03-21 15:25:55 -04:00
_child.py Hide `._entry`/`._child` frames, tweak some more type annots 2025-03-20 23:22:45 -04:00
_clustering.py Passthrough runtime kwargs from `open_actor_cluster()` 2022-12-11 19:56:08 -05:00
_context.py Change masked `.pause()` line 2025-03-22 14:24:53 -04:00
_discovery.py Finally implement peer-lookup optimization.. 2025-03-21 15:25:55 -04:00
_entry.py Pass `infect_asyncio` setting via runtime-vars 2025-03-22 14:24:53 -04:00
_exceptions.py Accept err-type override in `is_multi_cancelled()` 2025-03-22 14:24:53 -04:00
_forkserver_override.py Re-license code base for distribution under AGPL 2021-12-14 23:33:27 -05:00
_ipc.py More formal `TransportClosed` reporting/raising 2025-03-21 15:25:55 -04:00
_mp_fixup_main.py Avoid importing mp for as long as possible 2022-02-17 11:55:26 -05:00
_multiaddr.py Fix doc string "its" typo.. 2025-03-20 19:50:31 -04:00
_portal.py More-n-more scops annots in logging 2025-03-21 15:25:55 -04:00
_root.py Expose `debug_filter` from `open_root_actor()` also 2025-03-22 14:24:53 -04:00
_rpc.py More formal `TransportClosed` reporting/raising 2025-03-21 15:25:55 -04:00
_runtime.py Pass `infect_asyncio` setting via runtime-vars 2025-03-22 14:24:53 -04:00
_spawn.py Use `._entry` proto-ed "lifetime ops" in logging 2025-03-21 15:25:55 -04:00
_state.py Pass `infect_asyncio` setting via runtime-vars 2025-03-22 14:24:53 -04:00
_streaming.py Reraise RAEs in `MsgStream.receive()`; truncate tbs 2025-03-21 15:25:55 -04:00
_supervise.py Pass `infect_asyncio` setting via runtime-vars 2025-03-22 14:24:53 -04:00
log.py Support passing pre-conf-ed `Logger` 2025-03-22 14:24:53 -04:00
to_asyncio.py Hm, `asyncio.Task._fut_waiter.set_exception()`? 2025-03-22 14:24:53 -04:00