tractor/tractor
Tyler Goodlet 4fb34772e7 Mega-refactor on `._invoke()` targeting `@context`s
Since eventually we want to implement all other RPC "func types" as
contexts underneath this starts the rework to move all the other cases
into a separate func not only to simplify the main `._invoke()` body but
also as a reminder of the intention to do it XD

Details of re-factor:
- add a new `._invoke_non_context()` which just moves all the old blocks
  for non-context handling to a single def.
- factor what was basically just the `finally:` block handler (doing all
  the task bookkeeping) into a new `@acm`: `_errors_relayed_via_ipc()`
  with that content packed into the post-`yield` (also with a `hide_tb:
  bool` flag added of course).
  * include a `debug_kbis: bool` for when needed.
- since the `@context` block is the only type left in the main
  `_invoke()` body, de-dent it so it's more grok-able B)

Obviously this patch also includes a few improvements regarding
context-cancellation-semantics (for the `context` RPC case) on the
callee side in order to match previous changes to the `Context` api:
- always setting any ctxc as the `Context._local_error`.
- using the new convenience `.maybe_raise()` topically (for now).
- avoiding any previous reliance on `Context.cancelled_caught` for
  anything public of meaning.

Further included is more logging content updates:
- being pedantic in `.cancel()` msgs about whether termination is caused
  by error or ctxc.
- optional `._invoke()` traceback hiding via a `hide_tb: bool`.
- simpler log headers throughout instead leveraging new `.__repr__()` on
  primitives.
- buncha `<= <actor-uid>` sent some message emissions.
- simplified handshake statuses reporting.

Other subsys api changes we need to match:
- change to `Channel.transport`.
- avoiding any `local_nursery: ActorNursery` waiting when the
  `._implicit_runtime_started` is set.

And yes, lotsa more comments for #TODOs dawg.. since there's always
somethin!
2025-03-16 14:01:48 -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 Deep `Context` refinements 2025-03-15 00:08:13 -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 Avoid `ctx.cancel()` after ctxc rxed in `.open_context()` 2025-03-15 00:08:13 -04:00
_root.py Make stream draining status logs `.debug()` level 2025-03-15 00:08:11 -04:00
_runtime.py Mega-refactor on `._invoke()` targeting `@context`s 2025-03-16 14:01:48 -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 Make stream draining status logs `.debug()` level 2025-03-15 00:08:11 -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