e5cab5525e
The last Tier-2 battery, plugging into run.Ports.Critic (executor call site is a P2 follow-up). Clean split of concerns: - executus owns the deterministic MECHANICS: System.Monitor returns a run.CriticHandle that tracks activity (RecordStep/RecordToolStart), and a watcher goroutine fires once per idle period a run crosses its soft timeout, applies the decision (queue Steer nudges / extend the Deadline / collapse it to now on Kill), and enforces a hard-kill backstop (softTimeout * mul). - the POLICY is the Escalator seam (nudge/extend/kill/escalate). Mort plugs its LLM critic-agent in here; ExtendOnce is the zero-dependency default (extend once, then let the backstop kill a truly hung run). Race-tested: escalate-once-per-idle-period with re-arm on fresh activity, Kill collapses the deadline, ExtendOnce fires once, zero soft-timeout => nil handle. Core imports ZERO from critic. This completes the P4 battery set: audit, budget, persona, skill, checkpoint, schedule, critic — each nil-safe, each with a default, each core-import-clean. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>