BEHAVE-EXTRACTOR.md Phase A Step 0. Lays the package skeleton (__init__/extract/_parse/_ctx/_thresholds/_features) with empty FEATURES = (), so the worker plumbing in BEHAVE-INTEGRATION Phase 4 has a stable import path before any primitive lands. extract_session() builds a SessionContext once and fans the registered feature functions across it; at Step 0 that fan-out is empty and the function yields nothing. Step 1 (asciinema parser + paste-burst detector) and Step 2 (motor.input_modality) land next. Smoke suite asserts the empty contract: empty stream → no observations, single event → t_start == t_end, multi-event → events routed into input_events / output_events by kind, evidence_ref defaults to "session:<sid>" or honours an explicit override.
19 lines
562 B
Python
19 lines
562 B
Python
"""BEHAVE-SHELL extraction engine — DECNET's official implementation.
|
|
|
|
Per ``development/BEHAVE-EXTRACTOR.md``: this package is a pure
|
|
library. Workers (``BEHAVE-INTEGRATION.md`` Phase 4) own I/O, bus
|
|
emission, and persistence. The engine just turns one PTY session into
|
|
``Iterable[Observation]``.
|
|
|
|
BEHAVE is the spec; DECNET is the engine.
|
|
"""
|
|
from __future__ import annotations
|
|
|
|
from decnet.profiler.behave_shell.extract import (
|
|
DEFAULT_SOURCE,
|
|
build_context,
|
|
extract_session,
|
|
)
|
|
|
|
__all__ = ["DEFAULT_SOURCE", "build_context", "extract_session"]
|