tractor/tractor
Tyler Goodlet fb55784798 Add `._implicit_runtime_started` mark, better logs
After some deep logging improvements to many parts of `._runtime`,
I realized a silly detail where we are always waiting on any opened
`local_nursery: ActorNursery` to signal exit from
`Actor._stream_handler()` even in the case of being an implicitly opened
root actor (`open_root_actor()` wasn't called by user/app code) via
`._supervise.open_nursery()`..

So, to address this add a `ActorNursery._implicit_runtime_started: bool`
that can be set and then checked to avoid doing the unnecessary
`.exited.wait()` (and any subsequent warn logging on an exit timeout) in
that special but most common case XD

Matching with other subsys log format refinements, improve readability
and simplicity of the actor-nursery supervisory log msgs, including:
- simplify and/or remove any content that more or less duplicates msg
  content found in emissions from lower-level primitives and sub-systems
  (like `._runtime`, `_context`, `_portal` etc.).
- add a specific `._open_and_supervise_one_cancels_all_nursery()`
  handler block for `ContextCancelled` to log with `.cancel()` level
  noting that the case is a "remote cancellation".
- put the nursery-exit and actor-tree shutdown status into a single msg
  in the `implicit_runtime` case.
2025-03-15 00:06:15 -04:00
..
experimental Move move context code into new `._context` mod 2023-05-15 10:00:45 -04:00
msg Make `NamespacePath` kinda support methods.. 2025-03-15 00:05:31 -04:00
trionics Try allowing multi-pops of `_Cache.locks` for now? 2025-03-14 14:14:53 -04:00
__init__.py Add comments around diff between `C/context` refs 2025-03-14 13:36:16 -04:00
_child.py ._child: remove some unused imports.. 2025-03-14 13:56:25 -04:00
_clustering.py Passthrough runtime kwargs from `open_actor_cluster()` 2022-12-11 19:56:08 -05:00
_context.py WIP final impl of ctx-cancellation-semantics 2025-03-14 22:18:31 -04:00
_debug.py Drop commented `pdbpp` import logic 2023-05-15 09:01:55 -04:00
_discovery.py More single doc-strs in discovery mod 2023-05-15 10:00:45 -04:00
_entry.py Add field-first subproca `.info()` to `._entry` 2025-03-15 00:06:13 -04:00
_exceptions.py Add "fancier" remote-error `.__repr__()`-ing 2025-03-15 00:05:31 -04:00
_forkserver_override.py Re-license code base for distribution under AGPL 2021-12-14 23:33:27 -05:00
_ipc.py Fix `Channel.__repr__()` safety, renames to `._transport` 2025-03-15 00:05:31 -04:00
_mp_fixup_main.py Avoid importing mp for as long as possible 2022-02-17 11:55:26 -05:00
_portal.py WIP final impl of ctx-cancellation-semantics 2025-03-14 22:18:31 -04:00
_root.py Call `actor.cancel(None)` from root to avoid mismatch with (any future) meth sig changes 2025-03-14 22:18:31 -04:00
_runtime.py Few more log msg tweaks in runtime 2025-03-14 22:18:31 -04:00
_spawn.py Spawn naming and log format tweaks 2025-03-15 00:06:15 -04:00
_state.py Move `NoRuntime` import inside `current_actor()` to avoid cycle 2023-05-15 10:00:45 -04:00
_streaming.py WIP final impl of ctx-cancellation-semantics 2025-03-14 22:18:31 -04:00
_supervise.py Add `._implicit_runtime_started` mark, better logs 2025-03-15 00:06:15 -04:00
log.py .log: more multi-line styling 2025-03-14 16:41:08 -04:00
to_asyncio.py Move `trio` scope outside first inter-task-chan receive 2022-10-11 20:00:05 -04:00