tractor/tractor
Tyler Goodlet 5f5e9bad27 Mv over `ServiceMngr` from `piker` with mods
Namely distinguishing service "IPC contexts" (opened in a
subactor via a `Portal`) from just local `trio.Task`s started
and managed under the `.service_n` (more or less wrapping in the
interface of a "task-manager" style nursery - aka a one-cancels-one
supervision start).

API changes from original (`piker`) impl,
- mk `.start_service_task()` do ONLY that, start a task with a wrapping
  cancel-scope and completion event.
  |_ ideally this gets factored-out/re-implemented using the
    task-manager/OCO-style-nursery from GH #363.
- change what was the impl of `.start_service_task()` to `.start_service_ctx()`
  since it more explicitly defines the functionality of entering
  `Portal.open_context()` with a wrapping cs and completion event inside
  a bg task (which syncs the ctx's lifetime with termination of the
  remote actor runtime).
- factor out what was a `.start_service_ctx()` closure to a new
  `_open_and_supervise_service_ctx()` mod-func holding the meat of
  the supervision logic.

`ServiceMngr` API brief,
- use `open_service_mngr()` and `get_service_mngr()` to acquire the
  actor-global singleton.
- `ServiceMngr.start_service()` and `.cancel_service()` which allow for
  straight forward mgmt of "service subactor daemons".
2025-03-25 16:04:43 -04:00
..
_testing Deliver a `MaybeBoxedError` from `.expect_ctxc()` 2025-03-25 12:59:08 -04:00
devx Match `maybe_open_crash_handler()` to non-maybe version 2025-03-25 12:54:03 -04:00
experimental Drop now-deprecated deps on modern `trio`/Python 2025-03-16 16:06:24 -04:00
hilevel Mv over `ServiceMngr` from `piker` with mods 2025-03-25 16:04:43 -04:00
msg Slight `PldRx` rework to simplify 2025-03-25 12:59:08 -04:00
trionics Use `collapse_eg()` in broadcaster suite 2025-03-25 12:54:03 -04:00
__init__.py Mask top level import of `.hilevel` 2025-03-25 12:59:08 -04:00
_child.py Hide `._entry`/`._child` frames, tweak some more type annots 2025-03-20 23:22:45 -04:00
_clustering.py Clean up some imports in `._clustering` 2025-03-25 12:54:03 -04:00
_context.py Add `Context._outcome_msg` use new `PldRx` API 2025-03-25 12:59:08 -04:00
_discovery.py Finally implement peer-lookup optimization.. 2025-03-24 14:04:52 -04:00
_entry.py Log format tweaks for sclang reprs 2025-03-25 12:54:03 -04:00
_exceptions.py Avoid attr-err when `._ipc_msg==None` 2025-03-25 12:59:08 -04:00
_forkserver_override.py Re-license code base for distribution under AGPL 2021-12-14 23:33:27 -05:00
_ipc.py Moar sclang log fmting tweaks 2025-03-25 12:54:03 -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 Add `Context._outcome_msg` use new `PldRx` API 2025-03-25 12:59:08 -04:00
_root.py Expose `hide_tb: bool` from `.open_nursery()` 2025-03-25 12:54:03 -04:00
_rpc.py Add `.runtime()`-emit to `._invoke()` to report final result msg in the child 2025-03-25 12:59:08 -04:00
_runtime.py Add `.runtime()`-emit to `._invoke()` to report final result msg in the child 2025-03-25 12:59:08 -04:00
_spawn.py Log format tweaks for sclang reprs 2025-03-25 12:54:03 -04:00
_state.py Moar sclang log fmting tweaks 2025-03-25 12:54:03 -04:00
_streaming.py Add `MsgStream._stop_msg` use new `PldRx` API 2025-03-25 12:59:08 -04:00
_supervise.py Hide `open_nursery()` frame by def 2025-03-25 12:54:03 -04:00
log.py Support passing pre-conf-ed `Logger` 2025-03-24 15:37:12 -04:00
to_asyncio.py Continue supporting py3.11+ 2025-03-24 21:44:46 -04:00