oh-my-codex 0.13.2 → 0.14.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Cargo.lock +5 -5
- package/Cargo.toml +1 -1
- package/README.md +14 -8
- package/crates/omx-explore/src/main.rs +94 -1
- package/crates/omx-sparkshell/src/codex_bridge.rs +59 -12
- package/crates/omx-sparkshell/tests/execution.rs +48 -0
- package/dist/autoresearch/__tests__/skill-validation.test.d.ts +2 -0
- package/dist/autoresearch/__tests__/skill-validation.test.d.ts.map +1 -0
- package/dist/autoresearch/__tests__/skill-validation.test.js +91 -0
- package/dist/autoresearch/__tests__/skill-validation.test.js.map +1 -0
- package/dist/autoresearch/skill-validation.d.ts +13 -0
- package/dist/autoresearch/skill-validation.d.ts.map +1 -0
- package/dist/autoresearch/skill-validation.js +165 -0
- package/dist/autoresearch/skill-validation.js.map +1 -0
- package/dist/catalog/__tests__/schema.test.js +6 -0
- package/dist/catalog/__tests__/schema.test.js.map +1 -1
- package/dist/cli/__tests__/autoresearch-guided.test.js +236 -273
- package/dist/cli/__tests__/autoresearch-guided.test.js.map +1 -1
- package/dist/cli/__tests__/autoresearch.test.js +64 -653
- package/dist/cli/__tests__/autoresearch.test.js.map +1 -1
- package/dist/cli/__tests__/explore.test.js +33 -1
- package/dist/cli/__tests__/explore.test.js.map +1 -1
- package/dist/cli/__tests__/index.test.js +18 -2
- package/dist/cli/__tests__/index.test.js.map +1 -1
- package/dist/cli/__tests__/nested-help-routing.test.js +2 -1
- package/dist/cli/__tests__/nested-help-routing.test.js.map +1 -1
- package/dist/cli/__tests__/package-bin-contract.test.js +5 -0
- package/dist/cli/__tests__/package-bin-contract.test.js.map +1 -1
- package/dist/cli/__tests__/question.test.d.ts +2 -0
- package/dist/cli/__tests__/question.test.d.ts.map +1 -0
- package/dist/cli/__tests__/question.test.js +166 -0
- package/dist/cli/__tests__/question.test.js.map +1 -0
- package/dist/cli/__tests__/session-search-help.test.js +1 -1
- package/dist/cli/__tests__/session-search-help.test.js.map +1 -1
- package/dist/cli/__tests__/setup-agents-overwrite.test.js +32 -7
- package/dist/cli/__tests__/setup-agents-overwrite.test.js.map +1 -1
- package/dist/cli/__tests__/setup-refresh.test.js +8 -6
- package/dist/cli/__tests__/setup-refresh.test.js.map +1 -1
- package/dist/cli/__tests__/setup-skills-overwrite.test.js +2 -0
- package/dist/cli/__tests__/setup-skills-overwrite.test.js.map +1 -1
- package/dist/cli/__tests__/sparkshell-cli.test.js +23 -0
- package/dist/cli/__tests__/sparkshell-cli.test.js.map +1 -1
- package/dist/cli/__tests__/uninstall.test.js +65 -5
- package/dist/cli/__tests__/uninstall.test.js.map +1 -1
- package/dist/cli/__tests__/update.test.js +360 -26
- package/dist/cli/__tests__/update.test.js.map +1 -1
- package/dist/cli/autoresearch-guided.d.ts +24 -7
- package/dist/cli/autoresearch-guided.d.ts.map +1 -1
- package/dist/cli/autoresearch-guided.js +189 -130
- package/dist/cli/autoresearch-guided.js.map +1 -1
- package/dist/cli/autoresearch.d.ts +3 -2
- package/dist/cli/autoresearch.d.ts.map +1 -1
- package/dist/cli/autoresearch.js +29 -305
- package/dist/cli/autoresearch.js.map +1 -1
- package/dist/cli/doctor.d.ts.map +1 -1
- package/dist/cli/doctor.js +43 -0
- package/dist/cli/doctor.js.map +1 -1
- package/dist/cli/explore.d.ts.map +1 -1
- package/dist/cli/explore.js +18 -3
- package/dist/cli/explore.js.map +1 -1
- package/dist/cli/index.d.ts +2 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +15 -3
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/question.d.ts +3 -0
- package/dist/cli/question.d.ts.map +1 -0
- package/dist/cli/question.js +182 -0
- package/dist/cli/question.js.map +1 -0
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +25 -3
- package/dist/cli/setup.js.map +1 -1
- package/dist/cli/sparkshell.d.ts.map +1 -1
- package/dist/cli/sparkshell.js +11 -1
- package/dist/cli/sparkshell.js.map +1 -1
- package/dist/cli/team.d.ts.map +1 -1
- package/dist/cli/team.js +159 -394
- package/dist/cli/team.js.map +1 -1
- package/dist/cli/uninstall.d.ts.map +1 -1
- package/dist/cli/uninstall.js +3 -1
- package/dist/cli/uninstall.js.map +1 -1
- package/dist/cli/update.d.ts +37 -9
- package/dist/cli/update.d.ts.map +1 -1
- package/dist/cli/update.js +204 -26
- package/dist/cli/update.js.map +1 -1
- package/dist/config/__tests__/generator-idempotent.test.js +51 -14
- package/dist/config/__tests__/generator-idempotent.test.js.map +1 -1
- package/dist/config/__tests__/generator-notify.test.js +35 -10
- package/dist/config/__tests__/generator-notify.test.js.map +1 -1
- package/dist/config/generator.d.ts +1 -0
- package/dist/config/generator.d.ts.map +1 -1
- package/dist/config/generator.js +61 -7
- package/dist/config/generator.js.map +1 -1
- package/dist/hooks/__tests__/analyze-routing-contract.test.js +22 -13
- package/dist/hooks/__tests__/analyze-routing-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/anti-slop-workflow.test.js +3 -3
- package/dist/hooks/__tests__/anti-slop-workflow.test.js.map +1 -1
- package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts +2 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.js +56 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.js.map +1 -0
- package/dist/hooks/__tests__/debugger-log-recency-contract.test.js +2 -2
- package/dist/hooks/__tests__/debugger-log-recency-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/deep-interview-contract.test.js +51 -5
- package/dist/hooks/__tests__/deep-interview-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts +2 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js +43 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js.map +1 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts +2 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js +38 -0
- package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js.map +1 -0
- package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js +2 -2
- package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/keyword-detector.test.js +308 -17
- package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-fallback-watcher.test.js +570 -2
- package/dist/hooks/__tests__/notify-fallback-watcher.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +717 -16
- package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js +25 -0
- package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js +894 -1
- package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js +34 -0
- package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +132 -0
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-contract.test.js +22 -4
- package/dist/hooks/__tests__/prompt-guidance-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-fragments.test.js +4 -2
- package/dist/hooks/__tests__/prompt-guidance-fragments.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts +1 -0
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.js +19 -1
- package/dist/hooks/__tests__/prompt-guidance-test-helpers.js.map +1 -1
- package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js +28 -0
- package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js +5 -4
- package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js.map +1 -1
- package/dist/hooks/__tests__/prompt-team-routing.test.js +2 -2
- package/dist/hooks/__tests__/prompt-team-routing.test.js.map +1 -1
- package/dist/hooks/__tests__/triage-config.test.d.ts +2 -0
- package/dist/hooks/__tests__/triage-config.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/triage-config.test.js +211 -0
- package/dist/hooks/__tests__/triage-config.test.js.map +1 -0
- package/dist/hooks/__tests__/triage-heuristic.test.d.ts +2 -0
- package/dist/hooks/__tests__/triage-heuristic.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/triage-heuristic.test.js +230 -0
- package/dist/hooks/__tests__/triage-heuristic.test.js.map +1 -0
- package/dist/hooks/__tests__/triage-state.test.d.ts +2 -0
- package/dist/hooks/__tests__/triage-state.test.d.ts.map +1 -0
- package/dist/hooks/__tests__/triage-state.test.js +426 -0
- package/dist/hooks/__tests__/triage-state.test.js.map +1 -0
- package/dist/hooks/keyword-detector.d.ts +26 -7
- package/dist/hooks/keyword-detector.d.ts.map +1 -1
- package/dist/hooks/keyword-detector.js +97 -26
- package/dist/hooks/keyword-detector.js.map +1 -1
- package/dist/hooks/keyword-registry.d.ts.map +1 -1
- package/dist/hooks/keyword-registry.js +16 -9
- package/dist/hooks/keyword-registry.js.map +1 -1
- package/dist/hooks/prompt-guidance-contract.d.ts.map +1 -1
- package/dist/hooks/prompt-guidance-contract.js +28 -1
- package/dist/hooks/prompt-guidance-contract.js.map +1 -1
- package/dist/hooks/triage-config.d.ts +33 -0
- package/dist/hooks/triage-config.d.ts.map +1 -0
- package/dist/hooks/triage-config.js +87 -0
- package/dist/hooks/triage-config.js.map +1 -0
- package/dist/hooks/triage-heuristic.d.ts +20 -0
- package/dist/hooks/triage-heuristic.d.ts.map +1 -0
- package/dist/hooks/triage-heuristic.js +210 -0
- package/dist/hooks/triage-heuristic.js.map +1 -0
- package/dist/hooks/triage-state.d.ts +63 -0
- package/dist/hooks/triage-state.d.ts.map +1 -0
- package/dist/hooks/triage-state.js +138 -0
- package/dist/hooks/triage-state.js.map +1 -0
- package/dist/hud/__tests__/reconcile.test.js +20 -0
- package/dist/hud/__tests__/reconcile.test.js.map +1 -1
- package/dist/hud/reconcile.d.ts +1 -0
- package/dist/hud/reconcile.d.ts.map +1 -1
- package/dist/hud/reconcile.js +2 -1
- package/dist/hud/reconcile.js.map +1 -1
- package/dist/mcp/__tests__/bootstrap.test.js +5 -24
- package/dist/mcp/__tests__/bootstrap.test.js.map +1 -1
- package/dist/mcp/__tests__/state-server.test.js +127 -0
- package/dist/mcp/__tests__/state-server.test.js.map +1 -1
- package/dist/mcp/bootstrap.d.ts +1 -1
- package/dist/mcp/bootstrap.d.ts.map +1 -1
- package/dist/mcp/bootstrap.js +3 -11
- package/dist/mcp/bootstrap.js.map +1 -1
- package/dist/mcp/state-server.d.ts +25 -0
- package/dist/mcp/state-server.d.ts.map +1 -1
- package/dist/mcp/state-server.js +41 -0
- package/dist/mcp/state-server.js.map +1 -1
- package/dist/modes/__tests__/base-ralph-contract.test.js +15 -0
- package/dist/modes/__tests__/base-ralph-contract.test.js.map +1 -1
- package/dist/modes/base.d.ts +1 -0
- package/dist/modes/base.d.ts.map +1 -1
- package/dist/modes/base.js +22 -6
- package/dist/modes/base.js.map +1 -1
- package/dist/notifications/__tests__/index.test.js +75 -0
- package/dist/notifications/__tests__/index.test.js.map +1 -1
- package/dist/notifications/__tests__/session-status.test.js +90 -0
- package/dist/notifications/__tests__/session-status.test.js.map +1 -1
- package/dist/notifications/index.d.ts.map +1 -1
- package/dist/notifications/index.js +39 -22
- package/dist/notifications/index.js.map +1 -1
- package/dist/notifications/session-status.d.ts +2 -0
- package/dist/notifications/session-status.d.ts.map +1 -1
- package/dist/notifications/session-status.js +19 -4
- package/dist/notifications/session-status.js.map +1 -1
- package/dist/openclaw/index.d.ts +5 -3
- package/dist/openclaw/index.d.ts.map +1 -1
- package/dist/openclaw/index.js +5 -3
- package/dist/openclaw/index.js.map +1 -1
- package/dist/question/__tests__/client.test.d.ts +2 -0
- package/dist/question/__tests__/client.test.d.ts.map +1 -0
- package/dist/question/__tests__/client.test.js +70 -0
- package/dist/question/__tests__/client.test.js.map +1 -0
- package/dist/question/__tests__/deep-interview.test.d.ts +2 -0
- package/dist/question/__tests__/deep-interview.test.d.ts.map +1 -0
- package/dist/question/__tests__/deep-interview.test.js +118 -0
- package/dist/question/__tests__/deep-interview.test.js.map +1 -0
- package/dist/question/__tests__/policy.test.d.ts +2 -0
- package/dist/question/__tests__/policy.test.d.ts.map +1 -0
- package/dist/question/__tests__/policy.test.js +107 -0
- package/dist/question/__tests__/policy.test.js.map +1 -0
- package/dist/question/__tests__/renderer.test.d.ts +2 -0
- package/dist/question/__tests__/renderer.test.d.ts.map +1 -0
- package/dist/question/__tests__/renderer.test.js +238 -0
- package/dist/question/__tests__/renderer.test.js.map +1 -0
- package/dist/question/__tests__/state.test.d.ts +2 -0
- package/dist/question/__tests__/state.test.d.ts.map +1 -0
- package/dist/question/__tests__/state.test.js +75 -0
- package/dist/question/__tests__/state.test.js.map +1 -0
- package/dist/question/__tests__/types.test.d.ts +2 -0
- package/dist/question/__tests__/types.test.d.ts.map +1 -0
- package/dist/question/__tests__/types.test.js +44 -0
- package/dist/question/__tests__/types.test.js.map +1 -0
- package/dist/question/__tests__/ui.test.d.ts +2 -0
- package/dist/question/__tests__/ui.test.d.ts.map +1 -0
- package/dist/question/__tests__/ui.test.js +169 -0
- package/dist/question/__tests__/ui.test.js.map +1 -0
- package/dist/question/client.d.ts +54 -0
- package/dist/question/client.d.ts.map +1 -0
- package/dist/question/client.js +77 -0
- package/dist/question/client.js.map +1 -0
- package/dist/question/deep-interview.d.ts +30 -0
- package/dist/question/deep-interview.d.ts.map +1 -0
- package/dist/question/deep-interview.js +118 -0
- package/dist/question/deep-interview.js.map +1 -0
- package/dist/question/policy.d.ts +18 -0
- package/dist/question/policy.d.ts.map +1 -0
- package/dist/question/policy.js +77 -0
- package/dist/question/policy.js.map +1 -0
- package/dist/question/renderer.d.ts +20 -0
- package/dist/question/renderer.d.ts.map +1 -0
- package/dist/question/renderer.js +190 -0
- package/dist/question/renderer.js.map +1 -0
- package/dist/question/state.d.ts +19 -0
- package/dist/question/state.d.ts.map +1 -0
- package/dist/question/state.js +108 -0
- package/dist/question/state.js.map +1 -0
- package/dist/question/types.d.ts +66 -0
- package/dist/question/types.d.ts.map +1 -0
- package/dist/question/types.js +82 -0
- package/dist/question/types.js.map +1 -0
- package/dist/question/ui.d.ts +38 -0
- package/dist/question/ui.d.ts.map +1 -0
- package/dist/question/ui.js +321 -0
- package/dist/question/ui.js.map +1 -0
- package/dist/ralph/contract.d.ts +1 -1
- package/dist/ralph/contract.d.ts.map +1 -1
- package/dist/ralph/contract.js +4 -1
- package/dist/ralph/contract.js.map +1 -1
- package/dist/ralplan/runtime.js +1 -1
- package/dist/ralplan/runtime.js.map +1 -1
- package/dist/runtime/__tests__/run-loop.test.d.ts +2 -0
- package/dist/runtime/__tests__/run-loop.test.d.ts.map +1 -0
- package/dist/runtime/__tests__/run-loop.test.js +35 -0
- package/dist/runtime/__tests__/run-loop.test.js.map +1 -0
- package/dist/runtime/__tests__/run-outcome.test.d.ts +2 -0
- package/dist/runtime/__tests__/run-outcome.test.d.ts.map +1 -0
- package/dist/runtime/__tests__/run-outcome.test.js +102 -0
- package/dist/runtime/__tests__/run-outcome.test.js.map +1 -0
- package/dist/runtime/__tests__/run-state.test.d.ts +2 -0
- package/dist/runtime/__tests__/run-state.test.d.ts.map +1 -0
- package/dist/runtime/__tests__/run-state.test.js +37 -0
- package/dist/runtime/__tests__/run-state.test.js.map +1 -0
- package/dist/runtime/run-loop.d.ts +45 -0
- package/dist/runtime/run-loop.d.ts.map +1 -0
- package/dist/runtime/run-loop.js +51 -0
- package/dist/runtime/run-loop.js.map +1 -0
- package/dist/runtime/run-outcome.d.ts +46 -0
- package/dist/runtime/run-outcome.d.ts.map +1 -0
- package/dist/runtime/run-outcome.js +285 -0
- package/dist/runtime/run-outcome.js.map +1 -0
- package/dist/runtime/run-state.d.ts +40 -0
- package/dist/runtime/run-state.d.ts.map +1 -0
- package/dist/runtime/run-state.js +120 -0
- package/dist/runtime/run-state.js.map +1 -0
- package/dist/runtime/terminal-lifecycle.d.ts +11 -0
- package/dist/runtime/terminal-lifecycle.d.ts.map +1 -0
- package/dist/runtime/terminal-lifecycle.js +52 -0
- package/dist/runtime/terminal-lifecycle.js.map +1 -0
- package/dist/scripts/__tests__/codex-native-hook.test.js +1459 -126
- package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -1
- package/dist/scripts/__tests__/postinstall.test.d.ts +2 -0
- package/dist/scripts/__tests__/postinstall.test.d.ts.map +1 -0
- package/dist/scripts/__tests__/postinstall.test.js +178 -0
- package/dist/scripts/__tests__/postinstall.test.js.map +1 -0
- package/dist/scripts/codex-native-hook.d.ts +3 -0
- package/dist/scripts/codex-native-hook.d.ts.map +1 -1
- package/dist/scripts/codex-native-hook.js +308 -61
- package/dist/scripts/codex-native-hook.js.map +1 -1
- package/dist/scripts/notify-fallback-watcher.js +81 -2
- package/dist/scripts/notify-fallback-watcher.js.map +1 -1
- package/dist/scripts/notify-hook/auto-nudge.d.ts +27 -0
- package/dist/scripts/notify-hook/auto-nudge.d.ts.map +1 -1
- package/dist/scripts/notify-hook/auto-nudge.js +83 -20
- package/dist/scripts/notify-hook/auto-nudge.js.map +1 -1
- package/dist/scripts/notify-hook/managed-tmux.d.ts.map +1 -1
- package/dist/scripts/notify-hook/managed-tmux.js +64 -38
- package/dist/scripts/notify-hook/managed-tmux.js.map +1 -1
- package/dist/scripts/notify-hook/ralph-session-resume.js +1 -1
- package/dist/scripts/notify-hook/ralph-session-resume.js.map +1 -1
- package/dist/scripts/notify-hook.js +15 -5
- package/dist/scripts/notify-hook.js.map +1 -1
- package/dist/scripts/postinstall.d.ts +22 -0
- package/dist/scripts/postinstall.d.ts.map +1 -0
- package/dist/scripts/postinstall.js +105 -0
- package/dist/scripts/postinstall.js.map +1 -0
- package/dist/scripts/sync-prompt-guidance-fragments.js +5 -0
- package/dist/scripts/sync-prompt-guidance-fragments.js.map +1 -1
- package/dist/state/__tests__/operations-ralph-phase.test.js +21 -0
- package/dist/state/__tests__/operations-ralph-phase.test.js.map +1 -1
- package/dist/state/__tests__/operations.test.js +18 -0
- package/dist/state/__tests__/operations.test.js.map +1 -1
- package/dist/state/__tests__/workflow-transition.test.js +11 -0
- package/dist/state/__tests__/workflow-transition.test.js.map +1 -1
- package/dist/state/operations.d.ts.map +1 -1
- package/dist/state/operations.js +15 -0
- package/dist/state/operations.js.map +1 -1
- package/dist/state/workflow-transition-reconcile.d.ts.map +1 -1
- package/dist/state/workflow-transition-reconcile.js +14 -1
- package/dist/state/workflow-transition-reconcile.js.map +1 -1
- package/dist/state/workflow-transition.d.ts.map +1 -1
- package/dist/state/workflow-transition.js +3 -1
- package/dist/state/workflow-transition.js.map +1 -1
- package/dist/team/__tests__/followup-planner.test.js +15 -0
- package/dist/team/__tests__/followup-planner.test.js.map +1 -1
- package/dist/team/__tests__/role-router.test.js +47 -0
- package/dist/team/__tests__/role-router.test.js.map +1 -1
- package/dist/team/__tests__/runtime.test.js +108 -2
- package/dist/team/__tests__/runtime.test.js.map +1 -1
- package/dist/team/followup-planner.d.ts.map +1 -1
- package/dist/team/followup-planner.js +31 -9
- package/dist/team/followup-planner.js.map +1 -1
- package/dist/team/role-router.d.ts.map +1 -1
- package/dist/team/role-router.js +73 -0
- package/dist/team/role-router.js.map +1 -1
- package/dist/team/runtime.d.ts.map +1 -1
- package/dist/team/runtime.js +18 -4
- package/dist/team/runtime.js.map +1 -1
- package/dist/utils/__tests__/dep-versions.test.js +25 -8
- package/dist/utils/__tests__/dep-versions.test.js.map +1 -1
- package/dist/utils/__tests__/paths.test.js +45 -0
- package/dist/utils/__tests__/paths.test.js.map +1 -1
- package/dist/utils/paths.d.ts +2 -0
- package/dist/utils/paths.d.ts.map +1 -1
- package/dist/utils/paths.js +22 -7
- package/dist/utils/paths.js.map +1 -1
- package/dist/verification/__tests__/ci-rust-gates.test.js +1 -1
- package/dist/verification/__tests__/ci-rust-gates.test.js.map +1 -1
- package/package.json +4 -2
- package/prompts/architect.md +4 -0
- package/prompts/code-reviewer.md +3 -0
- package/prompts/dependency-expert.md +3 -0
- package/prompts/executor.md +5 -0
- package/prompts/explore.md +2 -0
- package/prompts/planner.md +5 -0
- package/prompts/product-analyst.md +8 -8
- package/prompts/researcher.md +78 -30
- package/prompts/verifier.md +4 -0
- package/skills/autoresearch/SKILL.md +68 -0
- package/skills/code-review/SKILL.md +94 -28
- package/skills/deep-interview/SKILL.md +100 -9
- package/skills/help/SKILL.md +3 -1
- package/skills/ralplan/SKILL.md +1 -0
- package/skills/team/SKILL.md +1 -0
- package/skills/ultrawork/SKILL.md +1 -0
- package/src/scripts/__tests__/codex-native-hook.test.ts +2373 -692
- package/src/scripts/__tests__/postinstall.test.ts +210 -0
- package/src/scripts/codex-native-hook.ts +365 -66
- package/src/scripts/notify-fallback-watcher.ts +92 -2
- package/src/scripts/notify-hook/auto-nudge.ts +89 -20
- package/src/scripts/notify-hook/managed-tmux.ts +70 -31
- package/src/scripts/notify-hook/ralph-session-resume.ts +1 -1
- package/src/scripts/notify-hook.ts +23 -5
- package/src/scripts/postinstall-bootstrap.js +23 -0
- package/src/scripts/postinstall.ts +161 -0
- package/src/scripts/sync-prompt-guidance-fragments.ts +4 -0
- package/templates/AGENTS.md +48 -37
- package/templates/catalog-manifest.json +7 -0
- package/templates/model-instructions/explore-lightweight-AGENTS.md +11 -0
- package/templates/model-instructions/sparkshell-lightweight-AGENTS.md +10 -0
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import assert from 'node:assert/strict';
|
|
2
|
+
import { mkdtemp, readFile, rm } from 'node:fs/promises';
|
|
3
|
+
import { tmpdir } from 'node:os';
|
|
4
|
+
import { join } from 'node:path';
|
|
5
|
+
import { describe, it } from 'node:test';
|
|
6
|
+
import { buildRunState, syncRunStateFromModeState } from '../run-state.js';
|
|
7
|
+
describe('run state sync', () => {
|
|
8
|
+
it('preserves canonical askuserQuestion lifecycle while keeping legacy blocked_on_user outcome', () => {
|
|
9
|
+
const state = buildRunState({
|
|
10
|
+
mode: 'deep-interview',
|
|
11
|
+
active: false,
|
|
12
|
+
run_outcome: 'blocked_on_user',
|
|
13
|
+
lifecycle_outcome: 'askuserQuestion',
|
|
14
|
+
}, null, '2026-04-19T00:00:00.000Z');
|
|
15
|
+
assert.equal(state.outcome, 'blocked_on_user');
|
|
16
|
+
assert.equal(state.lifecycle_outcome, 'askuserQuestion');
|
|
17
|
+
});
|
|
18
|
+
it('writes canonical askuserQuestion lifecycle to run-state.json during sync', async () => {
|
|
19
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-run-state-'));
|
|
20
|
+
try {
|
|
21
|
+
const synced = await syncRunStateFromModeState({
|
|
22
|
+
mode: 'deep-interview',
|
|
23
|
+
active: false,
|
|
24
|
+
run_outcome: 'blocked_on_user',
|
|
25
|
+
lifecycle_outcome: 'askuserQuestion',
|
|
26
|
+
}, wd);
|
|
27
|
+
const persisted = JSON.parse(await readFile(join(wd, '.omx', 'state', 'run-state.json'), 'utf-8'));
|
|
28
|
+
assert.equal(synced.outcome, 'blocked_on_user');
|
|
29
|
+
assert.equal(synced.lifecycle_outcome, 'askuserQuestion');
|
|
30
|
+
assert.equal(persisted.lifecycle_outcome, 'askuserQuestion');
|
|
31
|
+
}
|
|
32
|
+
finally {
|
|
33
|
+
await rm(wd, { recursive: true, force: true });
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
//# sourceMappingURL=run-state.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-state.test.js","sourceRoot":"","sources":["../../../src/runtime/__tests__/run-state.test.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,WAAW,CAAC;AAEzC,OAAO,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,iBAAiB,CAAC;AAE3E,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,4FAA4F,EAAE,GAAG,EAAE;QACpG,MAAM,KAAK,GAAG,aAAa,CACzB;YACE,IAAI,EAAE,gBAAgB;YACtB,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,iBAAiB;YAC9B,iBAAiB,EAAE,iBAAiB;SACrC,EACD,IAAI,EACJ,0BAA0B,CAC3B,CAAC;QAEF,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAC/C,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0EAA0E,EAAE,KAAK,IAAI,EAAE;QACxF,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,gBAAgB,CAAC,CAAC,CAAC;QAC3D,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,yBAAyB,CAC5C;gBACE,IAAI,EAAE,gBAAgB;gBACtB,MAAM,EAAE,KAAK;gBACb,WAAW,EAAE,iBAAiB;gBAC9B,iBAAiB,EAAE,iBAAiB;aACrC,EACD,EAAE,CACH,CAAC;YAEF,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAC1B,MAAM,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,CAAC,EAAE,OAAO,CAAC,CACpD,CAAC;YAEnB,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;YAChD,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,CAAC;YAC1D,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,CAAC;QAC/D,CAAC;gBAAS,CAAC;YACT,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACjD,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { type RunOutcome, type TerminalLifecycleOutcome, type TerminalRunOutcome } from './run-outcome.js';
|
|
2
|
+
export interface RunLoopIteration<TState> {
|
|
3
|
+
outcome: unknown;
|
|
4
|
+
state: TState;
|
|
5
|
+
}
|
|
6
|
+
export interface NormalizedRunLoopIteration<TState> {
|
|
7
|
+
iteration: number;
|
|
8
|
+
outcome: RunOutcome;
|
|
9
|
+
terminal: boolean;
|
|
10
|
+
state: TState;
|
|
11
|
+
}
|
|
12
|
+
export interface RunLoopTerminalResult<TState> {
|
|
13
|
+
iteration: number;
|
|
14
|
+
outcome: TerminalRunOutcome;
|
|
15
|
+
state: TState;
|
|
16
|
+
history: RunOutcome[];
|
|
17
|
+
}
|
|
18
|
+
export interface RunUntilTerminalOptions<TState> {
|
|
19
|
+
maxIterations?: number;
|
|
20
|
+
onIteration?: (result: NormalizedRunLoopIteration<TState>) => Promise<void> | void;
|
|
21
|
+
}
|
|
22
|
+
export interface RunContinuationStateLike {
|
|
23
|
+
current_phase?: unknown;
|
|
24
|
+
run_outcome?: unknown;
|
|
25
|
+
lifecycle_outcome?: unknown;
|
|
26
|
+
terminal_outcome?: unknown;
|
|
27
|
+
question_enforcement?: unknown;
|
|
28
|
+
active?: unknown;
|
|
29
|
+
completed_at?: unknown;
|
|
30
|
+
[key: string]: unknown;
|
|
31
|
+
}
|
|
32
|
+
export interface RunContinuationSnapshot {
|
|
33
|
+
outcome: RunOutcome;
|
|
34
|
+
lifecycleOutcome?: TerminalLifecycleOutcome;
|
|
35
|
+
terminal: boolean;
|
|
36
|
+
phase: string;
|
|
37
|
+
}
|
|
38
|
+
export declare function runUntilTerminal<TState>(step: (iteration: number) => Promise<RunLoopIteration<TState>>, options?: RunUntilTerminalOptions<TState>): Promise<RunLoopTerminalResult<TState>>;
|
|
39
|
+
export declare function getRunContinuationSnapshot(candidate: RunContinuationStateLike | null | undefined, options?: {
|
|
40
|
+
phaseFallback?: string;
|
|
41
|
+
}): RunContinuationSnapshot | null;
|
|
42
|
+
export declare function shouldContinueRun(candidate: RunContinuationStateLike | null | undefined, options?: {
|
|
43
|
+
phaseFallback?: string;
|
|
44
|
+
}): boolean;
|
|
45
|
+
//# sourceMappingURL=run-loop.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-loop.d.ts","sourceRoot":"","sources":["../../src/runtime/run-loop.ts"],"names":[],"mappings":"AAAA,OAAO,EAKL,KAAK,UAAU,EACf,KAAK,wBAAwB,EAC7B,KAAK,kBAAkB,EACxB,MAAM,kBAAkB,CAAC;AAE1B,MAAM,WAAW,gBAAgB,CAAC,MAAM;IACtC,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,0BAA0B,CAAC,MAAM;IAChD,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,UAAU,CAAC;IACpB,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,qBAAqB,CAAC,MAAM;IAC3C,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,kBAAkB,CAAC;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,UAAU,EAAE,CAAC;CACvB;AAED,MAAM,WAAW,uBAAuB,CAAC,MAAM;IAC7C,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,0BAA0B,CAAC,MAAM,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CACpF;AAED,MAAM,WAAW,wBAAwB;IACvC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,uBAAuB;IACtC,OAAO,EAAE,UAAU,CAAC;IACpB,gBAAgB,CAAC,EAAE,wBAAwB,CAAC;IAC5C,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;CACf;AAMD,wBAAsB,gBAAgB,CAAC,MAAM,EAC3C,IAAI,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,EAC9D,OAAO,GAAE,uBAAuB,CAAC,MAAM,CAAM,GAC5C,OAAO,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,CA8BxC;AAED,wBAAgB,0BAA0B,CACxC,SAAS,EAAE,wBAAwB,GAAG,IAAI,GAAG,SAAS,EACtD,OAAO,GAAE;IAAE,aAAa,CAAC,EAAE,MAAM,CAAA;CAAO,GACvC,uBAAuB,GAAG,IAAI,CAchC;AAED,wBAAgB,iBAAiB,CAC/B,SAAS,EAAE,wBAAwB,GAAG,IAAI,GAAG,SAAS,EACtD,OAAO,GAAE;IAAE,aAAa,CAAC,EAAE,MAAM,CAAA;CAAO,GACvC,OAAO,CAGT"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { classifyRunOutcome, inferRunOutcome, inferTerminalLifecycleOutcome, isTerminalRunOutcome, } from './run-outcome.js';
|
|
2
|
+
function safeString(value) {
|
|
3
|
+
return typeof value === 'string' ? value.trim() : '';
|
|
4
|
+
}
|
|
5
|
+
export async function runUntilTerminal(step, options = {}) {
|
|
6
|
+
const history = [];
|
|
7
|
+
const maxIterations = options.maxIterations ?? Number.POSITIVE_INFINITY;
|
|
8
|
+
for (let iteration = 1; iteration <= maxIterations; iteration += 1) {
|
|
9
|
+
const raw = await step(iteration);
|
|
10
|
+
const outcome = classifyRunOutcome(raw.outcome);
|
|
11
|
+
const terminal = isTerminalRunOutcome(outcome);
|
|
12
|
+
history.push(outcome);
|
|
13
|
+
const normalized = {
|
|
14
|
+
iteration,
|
|
15
|
+
outcome,
|
|
16
|
+
terminal,
|
|
17
|
+
state: raw.state,
|
|
18
|
+
};
|
|
19
|
+
await options.onIteration?.(normalized);
|
|
20
|
+
if (terminal) {
|
|
21
|
+
return {
|
|
22
|
+
iteration,
|
|
23
|
+
outcome,
|
|
24
|
+
state: raw.state,
|
|
25
|
+
history,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
throw new Error(`run loop exceeded maxIterations=${maxIterations} without reaching a terminal outcome`);
|
|
30
|
+
}
|
|
31
|
+
export function getRunContinuationSnapshot(candidate, options = {}) {
|
|
32
|
+
if (!candidate || typeof candidate !== 'object')
|
|
33
|
+
return null;
|
|
34
|
+
const record = candidate;
|
|
35
|
+
const outcome = inferRunOutcome(record);
|
|
36
|
+
const lifecycleOutcome = inferTerminalLifecycleOutcome(record, {
|
|
37
|
+
includeQuestionEnforcement: true,
|
|
38
|
+
});
|
|
39
|
+
const phase = safeString(candidate.current_phase) || options.phaseFallback || 'active';
|
|
40
|
+
return {
|
|
41
|
+
outcome,
|
|
42
|
+
lifecycleOutcome,
|
|
43
|
+
terminal: lifecycleOutcome !== undefined || isTerminalRunOutcome(outcome),
|
|
44
|
+
phase,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
export function shouldContinueRun(candidate, options = {}) {
|
|
48
|
+
const snapshot = getRunContinuationSnapshot(candidate, options);
|
|
49
|
+
return snapshot !== null && !snapshot.terminal;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=run-loop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-loop.js","sourceRoot":"","sources":["../../src/runtime/run-loop.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,eAAe,EACf,6BAA6B,EAC7B,oBAAoB,GAIrB,MAAM,kBAAkB,CAAC;AA4C1B,SAAS,UAAU,CAAC,KAAc;IAChC,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AACvD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,IAA8D,EAC9D,UAA2C,EAAE;IAE7C,MAAM,OAAO,GAAiB,EAAE,CAAC;IACjC,MAAM,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,MAAM,CAAC,iBAAiB,CAAC;IAExE,KAAK,IAAI,SAAS,GAAG,CAAC,EAAE,SAAS,IAAI,aAAa,EAAE,SAAS,IAAI,CAAC,EAAE,CAAC;QACnE,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC;QAClC,MAAM,OAAO,GAAG,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAChD,MAAM,QAAQ,GAAG,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAC/C,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEtB,MAAM,UAAU,GAAuC;YACrD,SAAS;YACT,OAAO;YACP,QAAQ;YACR,KAAK,EAAE,GAAG,CAAC,KAAK;SACjB,CAAC;QAEF,MAAM,OAAO,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,CAAC;QAExC,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO;gBACL,SAAS;gBACT,OAAO;gBACP,KAAK,EAAE,GAAG,CAAC,KAAK;gBAChB,OAAO;aACR,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,mCAAmC,aAAa,sCAAsC,CAAC,CAAC;AAC1G,CAAC;AAED,MAAM,UAAU,0BAA0B,CACxC,SAAsD,EACtD,UAAsC,EAAE;IAExC,IAAI,CAAC,SAAS,IAAI,OAAO,SAAS,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAC7D,MAAM,MAAM,GAAG,SAAoC,CAAC;IACpD,MAAM,OAAO,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;IACxC,MAAM,gBAAgB,GAAG,6BAA6B,CAAC,MAAM,EAAE;QAC7D,0BAA0B,EAAE,IAAI;KACjC,CAAC,CAAC;IACH,MAAM,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,OAAO,CAAC,aAAa,IAAI,QAAQ,CAAC;IACvF,OAAO;QACL,OAAO;QACP,gBAAgB;QAChB,QAAQ,EAAE,gBAAgB,KAAK,SAAS,IAAI,oBAAoB,CAAC,OAAO,CAAC;QACzE,KAAK;KACN,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,SAAsD,EACtD,UAAsC,EAAE;IAExC,MAAM,QAAQ,GAAG,0BAA0B,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAChE,OAAO,QAAQ,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;AACjD,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
export declare const TERMINAL_RUN_OUTCOMES: readonly ["finish", "blocked_on_user", "failed", "cancelled"];
|
|
2
|
+
export declare const NON_TERMINAL_RUN_OUTCOMES: readonly ["progress", "continue"];
|
|
3
|
+
export declare const RUN_OUTCOMES: readonly ["progress", "continue", "finish", "blocked_on_user", "failed", "cancelled"];
|
|
4
|
+
export declare const TERMINAL_LIFECYCLE_OUTCOMES: readonly ["finished", "blocked", "failed", "userinterlude", "askuserQuestion"];
|
|
5
|
+
export type TerminalRunOutcome = (typeof TERMINAL_RUN_OUTCOMES)[number];
|
|
6
|
+
export type NonTerminalRunOutcome = (typeof NON_TERMINAL_RUN_OUTCOMES)[number];
|
|
7
|
+
export type RunOutcome = (typeof RUN_OUTCOMES)[number];
|
|
8
|
+
export type TerminalLifecycleOutcome = (typeof TERMINAL_LIFECYCLE_OUTCOMES)[number];
|
|
9
|
+
export interface RunOutcomeNormalizationResult {
|
|
10
|
+
outcome?: RunOutcome;
|
|
11
|
+
warning?: string;
|
|
12
|
+
error?: string;
|
|
13
|
+
}
|
|
14
|
+
export interface TerminalLifecycleOutcomeNormalizationOptions {
|
|
15
|
+
blockedOnUserStrategy?: 'blocked' | 'askuserQuestion' | 'userinterlude';
|
|
16
|
+
}
|
|
17
|
+
export interface TerminalLifecycleOutcomeNormalizationResult {
|
|
18
|
+
outcome?: TerminalLifecycleOutcome;
|
|
19
|
+
warning?: string;
|
|
20
|
+
error?: string;
|
|
21
|
+
}
|
|
22
|
+
export interface RunOutcomeValidationResult {
|
|
23
|
+
ok: boolean;
|
|
24
|
+
state?: Record<string, unknown>;
|
|
25
|
+
warning?: string;
|
|
26
|
+
error?: string;
|
|
27
|
+
}
|
|
28
|
+
export declare function compatibilityRunOutcomeFromTerminalLifecycleOutcome(outcome: TerminalLifecycleOutcome): TerminalRunOutcome;
|
|
29
|
+
export declare function terminalLifecycleOutcomeFromRunOutcome(outcome: TerminalRunOutcome, options?: TerminalLifecycleOutcomeNormalizationOptions): TerminalLifecycleOutcome;
|
|
30
|
+
export declare function normalizeRunOutcome(value: unknown): RunOutcomeNormalizationResult;
|
|
31
|
+
export declare function normalizeTerminalLifecycleOutcome(value: unknown, options?: TerminalLifecycleOutcomeNormalizationOptions): TerminalLifecycleOutcomeNormalizationResult;
|
|
32
|
+
export declare function classifyRunOutcome(value: unknown): RunOutcome;
|
|
33
|
+
export declare function isTerminalRunOutcome(value: unknown): value is TerminalRunOutcome;
|
|
34
|
+
export declare function isTerminalLifecycleOutcome(value: unknown, options?: TerminalLifecycleOutcomeNormalizationOptions): value is TerminalLifecycleOutcome;
|
|
35
|
+
export declare function isNonTerminalRunOutcome(value: unknown): value is NonTerminalRunOutcome;
|
|
36
|
+
export declare function isNonTerminalRunState(value: unknown): boolean;
|
|
37
|
+
export declare function isTerminalRunState(value: unknown): boolean;
|
|
38
|
+
export declare function inferTerminalLifecycleOutcome(candidate: Record<string, unknown>, options?: {
|
|
39
|
+
includeQuestionEnforcement?: boolean;
|
|
40
|
+
blockedOnUserStrategy?: 'blocked' | 'askuserQuestion' | 'userinterlude';
|
|
41
|
+
}): TerminalLifecycleOutcome | undefined;
|
|
42
|
+
export declare function inferRunOutcome(candidate: Record<string, unknown>): RunOutcome;
|
|
43
|
+
export declare function applyRunOutcomeContract(candidate: Record<string, unknown>, options?: {
|
|
44
|
+
nowIso?: string;
|
|
45
|
+
}): RunOutcomeValidationResult;
|
|
46
|
+
//# sourceMappingURL=run-outcome.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-outcome.d.ts","sourceRoot":"","sources":["../../src/runtime/run-outcome.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
export const TERMINAL_RUN_OUTCOMES = [
|
|
2
|
+
'finish',
|
|
3
|
+
'blocked_on_user',
|
|
4
|
+
'failed',
|
|
5
|
+
'cancelled',
|
|
6
|
+
];
|
|
7
|
+
export const NON_TERMINAL_RUN_OUTCOMES = [
|
|
8
|
+
'progress',
|
|
9
|
+
'continue',
|
|
10
|
+
];
|
|
11
|
+
export const RUN_OUTCOMES = [
|
|
12
|
+
...NON_TERMINAL_RUN_OUTCOMES,
|
|
13
|
+
...TERMINAL_RUN_OUTCOMES,
|
|
14
|
+
];
|
|
15
|
+
export const TERMINAL_LIFECYCLE_OUTCOMES = [
|
|
16
|
+
'finished',
|
|
17
|
+
'blocked',
|
|
18
|
+
'failed',
|
|
19
|
+
'userinterlude',
|
|
20
|
+
'askuserQuestion',
|
|
21
|
+
];
|
|
22
|
+
const TERMINAL_RUN_OUTCOME_SET = new Set(TERMINAL_RUN_OUTCOMES);
|
|
23
|
+
const NON_TERMINAL_RUN_OUTCOME_SET = new Set(NON_TERMINAL_RUN_OUTCOMES);
|
|
24
|
+
const RUN_OUTCOME_SET = new Set(RUN_OUTCOMES);
|
|
25
|
+
const TERMINAL_LIFECYCLE_OUTCOME_SET = new Set(TERMINAL_LIFECYCLE_OUTCOMES);
|
|
26
|
+
const RUN_OUTCOME_ALIASES = {
|
|
27
|
+
finish: 'finish',
|
|
28
|
+
finished: 'finish',
|
|
29
|
+
complete: 'finish',
|
|
30
|
+
completed: 'finish',
|
|
31
|
+
done: 'finish',
|
|
32
|
+
blocked: 'blocked_on_user',
|
|
33
|
+
'blocked-on-user': 'blocked_on_user',
|
|
34
|
+
blocked_on_user: 'blocked_on_user',
|
|
35
|
+
failed: 'failed',
|
|
36
|
+
fail: 'failed',
|
|
37
|
+
error: 'failed',
|
|
38
|
+
cancelled: 'cancelled',
|
|
39
|
+
canceled: 'cancelled',
|
|
40
|
+
cancel: 'cancelled',
|
|
41
|
+
aborted: 'cancelled',
|
|
42
|
+
abort: 'cancelled',
|
|
43
|
+
progress: 'progress',
|
|
44
|
+
continue: 'continue',
|
|
45
|
+
continued: 'continue',
|
|
46
|
+
};
|
|
47
|
+
const TERMINAL_LIFECYCLE_OUTCOME_ALIASES = {
|
|
48
|
+
finished: 'finished',
|
|
49
|
+
finish: 'finished',
|
|
50
|
+
complete: 'finished',
|
|
51
|
+
completed: 'finished',
|
|
52
|
+
done: 'finished',
|
|
53
|
+
blocked: 'blocked',
|
|
54
|
+
failed: 'failed',
|
|
55
|
+
fail: 'failed',
|
|
56
|
+
error: 'failed',
|
|
57
|
+
userinterlude: 'userinterlude',
|
|
58
|
+
'user-interlude': 'userinterlude',
|
|
59
|
+
interrupted: 'userinterlude',
|
|
60
|
+
interrupt: 'userinterlude',
|
|
61
|
+
cancelled: 'userinterlude',
|
|
62
|
+
canceled: 'userinterlude',
|
|
63
|
+
cancel: 'userinterlude',
|
|
64
|
+
aborted: 'userinterlude',
|
|
65
|
+
abort: 'userinterlude',
|
|
66
|
+
askuserquestion: 'askuserQuestion',
|
|
67
|
+
'ask-user-question': 'askuserQuestion',
|
|
68
|
+
askuser: 'askuserQuestion',
|
|
69
|
+
question: 'askuserQuestion',
|
|
70
|
+
};
|
|
71
|
+
const TERMINAL_PHASE_TO_RUN_OUTCOME = {
|
|
72
|
+
complete: 'finish',
|
|
73
|
+
completed: 'finish',
|
|
74
|
+
blocked: 'blocked_on_user',
|
|
75
|
+
blocked_on_user: 'blocked_on_user',
|
|
76
|
+
'blocked-on-user': 'blocked_on_user',
|
|
77
|
+
failed: 'failed',
|
|
78
|
+
cancelled: 'cancelled',
|
|
79
|
+
cancel: 'cancelled',
|
|
80
|
+
};
|
|
81
|
+
const RUN_OUTCOME_FROM_LIFECYCLE = {
|
|
82
|
+
finished: 'finish',
|
|
83
|
+
blocked: 'blocked_on_user',
|
|
84
|
+
failed: 'failed',
|
|
85
|
+
userinterlude: 'cancelled',
|
|
86
|
+
askuserQuestion: 'blocked_on_user',
|
|
87
|
+
};
|
|
88
|
+
function normalizeRunOutcomeValue(value) {
|
|
89
|
+
return typeof value === 'string' ? value.trim().toLowerCase() : '';
|
|
90
|
+
}
|
|
91
|
+
function safeString(value) {
|
|
92
|
+
return typeof value === 'string' ? value.trim() : '';
|
|
93
|
+
}
|
|
94
|
+
function resolveBlockedOnUserLifecycleOutcome(options = {}) {
|
|
95
|
+
return options.blockedOnUserStrategy ?? 'blocked';
|
|
96
|
+
}
|
|
97
|
+
function hasPendingQuestionEnforcement(candidate) {
|
|
98
|
+
const enforcement = candidate.question_enforcement;
|
|
99
|
+
if (!enforcement || typeof enforcement !== 'object')
|
|
100
|
+
return false;
|
|
101
|
+
const record = enforcement;
|
|
102
|
+
const obligationId = safeString(record.obligation_id);
|
|
103
|
+
const status = safeString(record.status).toLowerCase();
|
|
104
|
+
return obligationId !== '' && status === 'pending';
|
|
105
|
+
}
|
|
106
|
+
export function compatibilityRunOutcomeFromTerminalLifecycleOutcome(outcome) {
|
|
107
|
+
return RUN_OUTCOME_FROM_LIFECYCLE[outcome];
|
|
108
|
+
}
|
|
109
|
+
export function terminalLifecycleOutcomeFromRunOutcome(outcome, options = {}) {
|
|
110
|
+
switch (outcome) {
|
|
111
|
+
case 'finish':
|
|
112
|
+
return 'finished';
|
|
113
|
+
case 'blocked_on_user':
|
|
114
|
+
return resolveBlockedOnUserLifecycleOutcome(options);
|
|
115
|
+
case 'failed':
|
|
116
|
+
return 'failed';
|
|
117
|
+
case 'cancelled':
|
|
118
|
+
return 'userinterlude';
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
export function normalizeRunOutcome(value) {
|
|
122
|
+
const normalized = normalizeRunOutcomeValue(value);
|
|
123
|
+
if (!normalized)
|
|
124
|
+
return {};
|
|
125
|
+
if (RUN_OUTCOME_SET.has(normalized)) {
|
|
126
|
+
return { outcome: normalized };
|
|
127
|
+
}
|
|
128
|
+
const alias = RUN_OUTCOME_ALIASES[normalized];
|
|
129
|
+
if (alias) {
|
|
130
|
+
return {
|
|
131
|
+
outcome: alias,
|
|
132
|
+
warning: `normalized legacy run outcome "${value}" -> "${alias}"`,
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
return { error: `run_outcome must be one of: ${RUN_OUTCOMES.join(', ')}` };
|
|
136
|
+
}
|
|
137
|
+
export function normalizeTerminalLifecycleOutcome(value, options = {}) {
|
|
138
|
+
const normalized = normalizeRunOutcomeValue(value);
|
|
139
|
+
if (!normalized)
|
|
140
|
+
return {};
|
|
141
|
+
if (TERMINAL_LIFECYCLE_OUTCOME_SET.has(normalized)) {
|
|
142
|
+
return { outcome: normalized };
|
|
143
|
+
}
|
|
144
|
+
if (normalized === 'blocked_on_user' || normalized === 'blocked-on-user') {
|
|
145
|
+
const outcome = resolveBlockedOnUserLifecycleOutcome(options);
|
|
146
|
+
return {
|
|
147
|
+
outcome,
|
|
148
|
+
warning: `normalized legacy terminal lifecycle outcome "${value}" -> "${outcome}"`,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
const alias = TERMINAL_LIFECYCLE_OUTCOME_ALIASES[normalized];
|
|
152
|
+
if (alias) {
|
|
153
|
+
return {
|
|
154
|
+
outcome: alias,
|
|
155
|
+
warning: `normalized legacy terminal lifecycle outcome "${value}" -> "${alias}"`,
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
return {
|
|
159
|
+
error: `lifecycle_outcome must be one of: ${TERMINAL_LIFECYCLE_OUTCOMES.join(', ')}`,
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
export function classifyRunOutcome(value) {
|
|
163
|
+
return normalizeRunOutcome(value).outcome ?? 'progress';
|
|
164
|
+
}
|
|
165
|
+
export function isTerminalRunOutcome(value) {
|
|
166
|
+
const normalized = normalizeRunOutcome(value).outcome;
|
|
167
|
+
return normalized !== undefined && TERMINAL_RUN_OUTCOME_SET.has(normalized);
|
|
168
|
+
}
|
|
169
|
+
export function isTerminalLifecycleOutcome(value, options = {}) {
|
|
170
|
+
const normalized = normalizeTerminalLifecycleOutcome(value, options).outcome;
|
|
171
|
+
return normalized !== undefined && TERMINAL_LIFECYCLE_OUTCOME_SET.has(normalized);
|
|
172
|
+
}
|
|
173
|
+
export function isNonTerminalRunOutcome(value) {
|
|
174
|
+
const normalized = normalizeRunOutcome(value).outcome;
|
|
175
|
+
return normalized !== undefined && NON_TERMINAL_RUN_OUTCOME_SET.has(normalized);
|
|
176
|
+
}
|
|
177
|
+
export function isNonTerminalRunState(value) {
|
|
178
|
+
return isNonTerminalRunOutcome(classifyRunOutcome(value));
|
|
179
|
+
}
|
|
180
|
+
export function isTerminalRunState(value) {
|
|
181
|
+
return isTerminalRunOutcome(classifyRunOutcome(value));
|
|
182
|
+
}
|
|
183
|
+
export function inferTerminalLifecycleOutcome(candidate, options = {}) {
|
|
184
|
+
const blockedOnUserStrategy = options.blockedOnUserStrategy
|
|
185
|
+
?? (options.includeQuestionEnforcement && hasPendingQuestionEnforcement(candidate)
|
|
186
|
+
? 'askuserQuestion'
|
|
187
|
+
: 'blocked');
|
|
188
|
+
const explicit = normalizeTerminalLifecycleOutcome(candidate.lifecycle_outcome ?? candidate.terminal_outcome, { blockedOnUserStrategy });
|
|
189
|
+
if (explicit.outcome)
|
|
190
|
+
return explicit.outcome;
|
|
191
|
+
const runOutcome = normalizeRunOutcome(candidate.run_outcome).outcome;
|
|
192
|
+
if (runOutcome && isTerminalRunOutcome(runOutcome)) {
|
|
193
|
+
return terminalLifecycleOutcomeFromRunOutcome(runOutcome, { blockedOnUserStrategy });
|
|
194
|
+
}
|
|
195
|
+
const phase = safeString(candidate.current_phase).toLowerCase();
|
|
196
|
+
if (phase) {
|
|
197
|
+
const normalizedPhase = normalizeTerminalLifecycleOutcome(phase, { blockedOnUserStrategy });
|
|
198
|
+
if (normalizedPhase.outcome)
|
|
199
|
+
return normalizedPhase.outcome;
|
|
200
|
+
}
|
|
201
|
+
if (options.includeQuestionEnforcement && hasPendingQuestionEnforcement(candidate)) {
|
|
202
|
+
return 'askuserQuestion';
|
|
203
|
+
}
|
|
204
|
+
if (candidate.active === true)
|
|
205
|
+
return undefined;
|
|
206
|
+
if (safeString(candidate.completed_at))
|
|
207
|
+
return 'finished';
|
|
208
|
+
if (candidate.active === false)
|
|
209
|
+
return 'finished';
|
|
210
|
+
return undefined;
|
|
211
|
+
}
|
|
212
|
+
export function inferRunOutcome(candidate) {
|
|
213
|
+
const explicit = normalizeRunOutcome(candidate.run_outcome);
|
|
214
|
+
if (explicit.outcome)
|
|
215
|
+
return explicit.outcome;
|
|
216
|
+
const lifecycleOutcome = inferTerminalLifecycleOutcome(candidate, {
|
|
217
|
+
includeQuestionEnforcement: false,
|
|
218
|
+
});
|
|
219
|
+
if (lifecycleOutcome) {
|
|
220
|
+
return compatibilityRunOutcomeFromTerminalLifecycleOutcome(lifecycleOutcome);
|
|
221
|
+
}
|
|
222
|
+
const phase = safeString(candidate.current_phase).toLowerCase();
|
|
223
|
+
if (phase && TERMINAL_PHASE_TO_RUN_OUTCOME[phase]) {
|
|
224
|
+
return TERMINAL_PHASE_TO_RUN_OUTCOME[phase];
|
|
225
|
+
}
|
|
226
|
+
if (candidate.active === true)
|
|
227
|
+
return 'continue';
|
|
228
|
+
if (safeString(candidate.completed_at))
|
|
229
|
+
return 'finish';
|
|
230
|
+
if (candidate.active === false)
|
|
231
|
+
return 'finish';
|
|
232
|
+
return 'continue';
|
|
233
|
+
}
|
|
234
|
+
export function applyRunOutcomeContract(candidate, options) {
|
|
235
|
+
const nowIso = options?.nowIso ?? new Date().toISOString();
|
|
236
|
+
const next = { ...candidate };
|
|
237
|
+
const normalizedLifecycle = normalizeTerminalLifecycleOutcome(next.lifecycle_outcome ?? next.terminal_outcome);
|
|
238
|
+
if (normalizedLifecycle.error)
|
|
239
|
+
return { ok: false, error: normalizedLifecycle.error };
|
|
240
|
+
const normalizedRunOutcome = normalizeRunOutcome(next.run_outcome);
|
|
241
|
+
if (normalizedRunOutcome.error)
|
|
242
|
+
return { ok: false, error: normalizedRunOutcome.error };
|
|
243
|
+
const lifecycleOutcome = normalizedLifecycle.outcome ?? inferTerminalLifecycleOutcome(next, {
|
|
244
|
+
includeQuestionEnforcement: false,
|
|
245
|
+
});
|
|
246
|
+
const outcome = normalizedLifecycle.outcome
|
|
247
|
+
? compatibilityRunOutcomeFromTerminalLifecycleOutcome(normalizedLifecycle.outcome)
|
|
248
|
+
: normalizedRunOutcome.outcome ?? inferRunOutcome(next);
|
|
249
|
+
delete next.terminal_outcome;
|
|
250
|
+
next.run_outcome = outcome;
|
|
251
|
+
if (lifecycleOutcome) {
|
|
252
|
+
next.lifecycle_outcome = lifecycleOutcome;
|
|
253
|
+
}
|
|
254
|
+
else {
|
|
255
|
+
delete next.lifecycle_outcome;
|
|
256
|
+
}
|
|
257
|
+
const terminal = lifecycleOutcome !== undefined || isTerminalRunOutcome(outcome);
|
|
258
|
+
if (terminal) {
|
|
259
|
+
if (next.active === true) {
|
|
260
|
+
return {
|
|
261
|
+
ok: false,
|
|
262
|
+
error: `terminal run outcome "${lifecycleOutcome ?? outcome}" requires active=false`,
|
|
263
|
+
};
|
|
264
|
+
}
|
|
265
|
+
next.active = false;
|
|
266
|
+
if (!safeString(next.completed_at)) {
|
|
267
|
+
next.completed_at = nowIso;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
if (next.active === false) {
|
|
272
|
+
return { ok: false, error: `non-terminal run outcome "${outcome}" requires active=true` };
|
|
273
|
+
}
|
|
274
|
+
next.active = true;
|
|
275
|
+
if (safeString(next.completed_at)) {
|
|
276
|
+
delete next.completed_at;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
return {
|
|
280
|
+
ok: true,
|
|
281
|
+
state: next,
|
|
282
|
+
warning: normalizedLifecycle.warning ?? normalizedRunOutcome.warning,
|
|
283
|
+
};
|
|
284
|
+
}
|
|
285
|
+
//# sourceMappingURL=run-outcome.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-outcome.js","sourceRoot":"","sources":["../../src/runtime/run-outcome.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,QAAQ;IACR,iBAAiB;IACjB,QAAQ;IACR,WAAW;CACH,CAAC;AAEX,MAAM,CAAC,MAAM,yBAAyB,GAAG;IACvC,UAAU;IACV,UAAU;CACF,CAAC;AAEX,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,GAAG,yBAAyB;IAC5B,GAAG,qBAAqB;CAChB,CAAC;AAEX,MAAM,CAAC,MAAM,2BAA2B,GAAG;IACzC,UAAU;IACV,SAAS;IACT,QAAQ;IACR,eAAe;IACf,iBAAiB;CACT,CAAC;AAOX,MAAM,wBAAwB,GAAG,IAAI,GAAG,CAAS,qBAAqB,CAAC,CAAC;AACxE,MAAM,4BAA4B,GAAG,IAAI,GAAG,CAAS,yBAAyB,CAAC,CAAC;AAChF,MAAM,eAAe,GAAG,IAAI,GAAG,CAAS,YAAY,CAAC,CAAC;AACtD,MAAM,8BAA8B,GAAG,IAAI,GAAG,CAAS,2BAA2B,CAAC,CAAC;AAEpF,MAAM,mBAAmB,GAAyC;IAChE,MAAM,EAAE,QAAQ;IAChB,QAAQ,EAAE,QAAQ;IAClB,QAAQ,EAAE,QAAQ;IAClB,SAAS,EAAE,QAAQ;IACnB,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE,iBAAiB;IAC1B,iBAAiB,EAAE,iBAAiB;IACpC,eAAe,EAAE,iBAAiB;IAClC,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,QAAQ;IACf,SAAS,EAAE,WAAW;IACtB,QAAQ,EAAE,WAAW;IACrB,MAAM,EAAE,WAAW;IACnB,OAAO,EAAE,WAAW;IACpB,KAAK,EAAE,WAAW;IAClB,QAAQ,EAAE,UAAU;IACpB,QAAQ,EAAE,UAAU;IACpB,SAAS,EAAE,UAAU;CACb,CAAC;AAEX,MAAM,kCAAkC,GAAuD;IAC7F,QAAQ,EAAE,UAAU;IACpB,MAAM,EAAE,UAAU;IAClB,QAAQ,EAAE,UAAU;IACpB,SAAS,EAAE,UAAU;IACrB,IAAI,EAAE,UAAU;IAChB,OAAO,EAAE,SAAS;IAClB,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,QAAQ;IACf,aAAa,EAAE,eAAe;IAC9B,gBAAgB,EAAE,eAAe;IACjC,WAAW,EAAE,eAAe;IAC5B,SAAS,EAAE,eAAe;IAC1B,SAAS,EAAE,eAAe;IAC1B,QAAQ,EAAE,eAAe;IACzB,MAAM,EAAE,eAAe;IACvB,OAAO,EAAE,eAAe;IACxB,KAAK,EAAE,eAAe;IACtB,eAAe,EAAE,iBAAiB;IAClC,mBAAmB,EAAE,iBAAiB;IACtC,OAAO,EAAE,iBAAiB;IAC1B,QAAQ,EAAE,iBAAiB;CACnB,CAAC;AAEX,MAAM,6BAA6B,GAAiD;IAClF,QAAQ,EAAE,QAAQ;IAClB,SAAS,EAAE,QAAQ;IACnB,OAAO,EAAE,iBAAiB;IAC1B,eAAe,EAAE,iBAAiB;IAClC,iBAAiB,EAAE,iBAAiB;IACpC,MAAM,EAAE,QAAQ;IAChB,SAAS,EAAE,WAAW;IACtB,MAAM,EAAE,WAAW;CACpB,CAAC;AAEF,MAAM,0BAA0B,GAAmE;IACjG,QAAQ,EAAE,QAAQ;IAClB,OAAO,EAAE,iBAAiB;IAC1B,MAAM,EAAE,QAAQ;IAChB,aAAa,EAAE,WAAW;IAC1B,eAAe,EAAE,iBAAiB;CACnC,CAAC;AAyBF,SAAS,wBAAwB,CAAC,KAAc;IAC9C,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AACrE,CAAC;AAED,SAAS,UAAU,CAAC,KAAc;IAChC,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AACvD,CAAC;AAED,SAAS,oCAAoC,CAC3C,UAAwD,EAAE;IAE1D,OAAO,OAAO,CAAC,qBAAqB,IAAI,SAAS,CAAC;AACpD,CAAC;AAED,SAAS,6BAA6B,CAAC,SAAkC;IACvE,MAAM,WAAW,GAAG,SAAS,CAAC,oBAAoB,CAAC;IACnD,IAAI,CAAC,WAAW,IAAI,OAAO,WAAW,KAAK,QAAQ;QAAE,OAAO,KAAK,CAAC;IAClE,MAAM,MAAM,GAAG,WAAsC,CAAC;IACtD,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IACtD,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;IACvD,OAAO,YAAY,KAAK,EAAE,IAAI,MAAM,KAAK,SAAS,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,mDAAmD,CACjE,OAAiC;IAEjC,OAAO,0BAA0B,CAAC,OAAO,CAAC,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,sCAAsC,CACpD,OAA2B,EAC3B,UAAwD,EAAE;IAE1D,QAAQ,OAAO,EAAE,CAAC;QAChB,KAAK,QAAQ;YACX,OAAO,UAAU,CAAC;QACpB,KAAK,iBAAiB;YACpB,OAAO,oCAAoC,CAAC,OAAO,CAAC,CAAC;QACvD,KAAK,QAAQ;YACX,OAAO,QAAQ,CAAC;QAClB,KAAK,WAAW;YACd,OAAO,eAAe,CAAC;IAC3B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,KAAc;IAChD,MAAM,UAAU,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;IACnD,IAAI,CAAC,UAAU;QAAE,OAAO,EAAE,CAAC;IAC3B,IAAI,eAAe,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;QACpC,OAAO,EAAE,OAAO,EAAE,UAAwB,EAAE,CAAC;IAC/C,CAAC;IACD,MAAM,KAAK,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC;IAC9C,IAAI,KAAK,EAAE,CAAC;QACV,OAAO;YACL,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,kCAAkC,KAAK,SAAS,KAAK,GAAG;SAClE,CAAC;IACJ,CAAC;IACD,OAAO,EAAE,KAAK,EAAE,+BAA+B,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;AAC7E,CAAC;AAED,MAAM,UAAU,iCAAiC,CAC/C,KAAc,EACd,UAAwD,EAAE;IAE1D,MAAM,UAAU,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;IACnD,IAAI,CAAC,UAAU;QAAE,OAAO,EAAE,CAAC;IAC3B,IAAI,8BAA8B,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;QACnD,OAAO,EAAE,OAAO,EAAE,UAAsC,EAAE,CAAC;IAC7D,CAAC;IACD,IAAI,UAAU,KAAK,iBAAiB,IAAI,UAAU,KAAK,iBAAiB,EAAE,CAAC;QACzE,MAAM,OAAO,GAAG,oCAAoC,CAAC,OAAO,CAAC,CAAC;QAC9D,OAAO;YACL,OAAO;YACP,OAAO,EAAE,iDAAiD,KAAK,SAAS,OAAO,GAAG;SACnF,CAAC;IACJ,CAAC;IACD,MAAM,KAAK,GAAG,kCAAkC,CAAC,UAAU,CAAC,CAAC;IAC7D,IAAI,KAAK,EAAE,CAAC;QACV,OAAO;YACL,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,iDAAiD,KAAK,SAAS,KAAK,GAAG;SACjF,CAAC;IACJ,CAAC;IACD,OAAO;QACL,KAAK,EAAE,qCAAqC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;KACrF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAc;IAC/C,OAAO,mBAAmB,CAAC,KAAK,CAAC,CAAC,OAAO,IAAI,UAAU,CAAC;AAC1D,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,KAAc;IACjD,MAAM,UAAU,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;IACtD,OAAO,UAAU,KAAK,SAAS,IAAI,wBAAwB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AAC9E,CAAC;AAED,MAAM,UAAU,0BAA0B,CACxC,KAAc,EACd,UAAwD,EAAE;IAE1D,MAAM,UAAU,GAAG,iCAAiC,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC;IAC7E,OAAO,UAAU,KAAK,SAAS,IAAI,8BAA8B,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AACpF,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,KAAc;IACpD,MAAM,UAAU,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;IACtD,OAAO,UAAU,KAAK,SAAS,IAAI,4BAA4B,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AAClF,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,KAAc;IAClD,OAAO,uBAAuB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAc;IAC/C,OAAO,oBAAoB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,6BAA6B,CAC3C,SAAkC,EAClC,UAGI,EAAE;IAEN,MAAM,qBAAqB,GAAG,OAAO,CAAC,qBAAqB;WACtD,CACD,OAAO,CAAC,0BAA0B,IAAI,6BAA6B,CAAC,SAAS,CAAC;YAC5E,CAAC,CAAC,iBAAiB;YACnB,CAAC,CAAC,SAAS,CACd,CAAC;IAEJ,MAAM,QAAQ,GAAG,iCAAiC,CAChD,SAAS,CAAC,iBAAiB,IAAI,SAAS,CAAC,gBAAgB,EACzD,EAAE,qBAAqB,EAAE,CAC1B,CAAC;IACF,IAAI,QAAQ,CAAC,OAAO;QAAE,OAAO,QAAQ,CAAC,OAAO,CAAC;IAE9C,MAAM,UAAU,GAAG,mBAAmB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC;IACtE,IAAI,UAAU,IAAI,oBAAoB,CAAC,UAAU,CAAC,EAAE,CAAC;QACnD,OAAO,sCAAsC,CAAC,UAAU,EAAE,EAAE,qBAAqB,EAAE,CAAC,CAAC;IACvF,CAAC;IAED,MAAM,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;IAChE,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,eAAe,GAAG,iCAAiC,CAAC,KAAK,EAAE,EAAE,qBAAqB,EAAE,CAAC,CAAC;QAC5F,IAAI,eAAe,CAAC,OAAO;YAAE,OAAO,eAAe,CAAC,OAAO,CAAC;IAC9D,CAAC;IAED,IAAI,OAAO,CAAC,0BAA0B,IAAI,6BAA6B,CAAC,SAAS,CAAC,EAAE,CAAC;QACnF,OAAO,iBAAiB,CAAC;IAC3B,CAAC;IAED,IAAI,SAAS,CAAC,MAAM,KAAK,IAAI;QAAE,OAAO,SAAS,CAAC;IAChD,IAAI,UAAU,CAAC,SAAS,CAAC,YAAY,CAAC;QAAE,OAAO,UAAU,CAAC;IAC1D,IAAI,SAAS,CAAC,MAAM,KAAK,KAAK;QAAE,OAAO,UAAU,CAAC;IAClD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,SAAkC;IAChE,MAAM,QAAQ,GAAG,mBAAmB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IAC5D,IAAI,QAAQ,CAAC,OAAO;QAAE,OAAO,QAAQ,CAAC,OAAO,CAAC;IAE9C,MAAM,gBAAgB,GAAG,6BAA6B,CAAC,SAAS,EAAE;QAChE,0BAA0B,EAAE,KAAK;KAClC,CAAC,CAAC;IACH,IAAI,gBAAgB,EAAE,CAAC;QACrB,OAAO,mDAAmD,CAAC,gBAAgB,CAAC,CAAC;IAC/E,CAAC;IAED,MAAM,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;IAChE,IAAI,KAAK,IAAI,6BAA6B,CAAC,KAAK,CAAC,EAAE,CAAC;QAClD,OAAO,6BAA6B,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED,IAAI,SAAS,CAAC,MAAM,KAAK,IAAI;QAAE,OAAO,UAAU,CAAC;IACjD,IAAI,UAAU,CAAC,SAAS,CAAC,YAAY,CAAC;QAAE,OAAO,QAAQ,CAAC;IACxD,IAAI,SAAS,CAAC,MAAM,KAAK,KAAK;QAAE,OAAO,QAAQ,CAAC;IAChD,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAM,UAAU,uBAAuB,CACrC,SAAkC,EAClC,OAA6B;IAE7B,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3D,MAAM,IAAI,GAA4B,EAAE,GAAG,SAAS,EAAE,CAAC;IACvD,MAAM,mBAAmB,GAAG,iCAAiC,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC/G,IAAI,mBAAmB,CAAC,KAAK;QAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,mBAAmB,CAAC,KAAK,EAAE,CAAC;IAEtF,MAAM,oBAAoB,GAAG,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACnE,IAAI,oBAAoB,CAAC,KAAK;QAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,oBAAoB,CAAC,KAAK,EAAE,CAAC;IAExF,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,OAAO,IAAI,6BAA6B,CAAC,IAAI,EAAE;QAC1F,0BAA0B,EAAE,KAAK;KAClC,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,mBAAmB,CAAC,OAAO;QACzC,CAAC,CAAC,mDAAmD,CAAC,mBAAmB,CAAC,OAAO,CAAC;QAClF,CAAC,CAAC,oBAAoB,CAAC,OAAO,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;IAE1D,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC7B,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC;IAC3B,IAAI,gBAAgB,EAAE,CAAC;QACrB,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;IAC5C,CAAC;SAAM,CAAC;QACN,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,MAAM,QAAQ,GAAG,gBAAgB,KAAK,SAAS,IAAI,oBAAoB,CAAC,OAAO,CAAC,CAAC;IACjF,IAAI,QAAQ,EAAE,CAAC;QACb,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;YACzB,OAAO;gBACL,EAAE,EAAE,KAAK;gBACT,KAAK,EAAE,yBAAyB,gBAAgB,IAAI,OAAO,yBAAyB;aACrF,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;QAC7B,CAAC;IACH,CAAC;SAAM,CAAC;QACN,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;YAC1B,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,6BAA6B,OAAO,wBAAwB,EAAE,CAAC;QAC5F,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC,YAAY,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,OAAO;QACL,EAAE,EAAE,IAAI;QACR,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,mBAAmB,CAAC,OAAO,IAAI,oBAAoB,CAAC,OAAO;KACrE,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { type RunOutcome, type TerminalLifecycleOutcome } from './run-outcome.js';
|
|
2
|
+
export interface RunStateLike {
|
|
3
|
+
active?: unknown;
|
|
4
|
+
mode?: unknown;
|
|
5
|
+
current_phase?: unknown;
|
|
6
|
+
task_description?: unknown;
|
|
7
|
+
started_at?: unknown;
|
|
8
|
+
completed_at?: unknown;
|
|
9
|
+
iteration?: unknown;
|
|
10
|
+
max_iterations?: unknown;
|
|
11
|
+
error?: unknown;
|
|
12
|
+
outcome?: unknown;
|
|
13
|
+
run_outcome?: unknown;
|
|
14
|
+
lifecycle_outcome?: unknown;
|
|
15
|
+
terminal_outcome?: unknown;
|
|
16
|
+
question_enforcement?: unknown;
|
|
17
|
+
owner_omx_session_id?: unknown;
|
|
18
|
+
[key: string]: unknown;
|
|
19
|
+
}
|
|
20
|
+
export interface RunState {
|
|
21
|
+
version: 1;
|
|
22
|
+
mode: string;
|
|
23
|
+
active: boolean;
|
|
24
|
+
outcome: RunOutcome;
|
|
25
|
+
lifecycle_outcome?: TerminalLifecycleOutcome;
|
|
26
|
+
updated_at: string;
|
|
27
|
+
current_phase?: string;
|
|
28
|
+
task_description?: string;
|
|
29
|
+
started_at?: string;
|
|
30
|
+
completed_at?: string;
|
|
31
|
+
iteration?: number;
|
|
32
|
+
max_iterations?: number;
|
|
33
|
+
error?: string;
|
|
34
|
+
owner_omx_session_id?: string;
|
|
35
|
+
}
|
|
36
|
+
export declare function deriveRunOutcomeFromModeState(state: RunStateLike): RunOutcome;
|
|
37
|
+
export declare function buildRunState(state: RunStateLike, existing?: Partial<RunState> | null, nowIso?: string): RunState;
|
|
38
|
+
export declare function readRunState(workingDirectory?: string, explicitSessionId?: string): Promise<RunState | null>;
|
|
39
|
+
export declare function syncRunStateFromModeState(state: RunStateLike, workingDirectory?: string, explicitSessionId?: string): Promise<RunState>;
|
|
40
|
+
//# sourceMappingURL=run-state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-state.d.ts","sourceRoot":"","sources":["../../src/runtime/run-state.ts"],"names":[],"mappings":"AAIA,OAAO,EAOL,KAAK,UAAU,EACf,KAAK,wBAAwB,EAC9B,MAAM,kBAAkB,CAAC;AAI1B,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,CAAC,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,UAAU,CAAC;IACpB,iBAAiB,CAAC,EAAE,wBAAwB,CAAC;IAC7C,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,oBAAoB,CAAC,EAAE,MAAM,CAAC;CAC/B;AAkBD,wBAAgB,6BAA6B,CAAC,KAAK,EAAE,YAAY,GAAG,UAAU,CAkB7E;AAED,wBAAgB,aAAa,CAC3B,KAAK,EAAE,YAAY,EACnB,QAAQ,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI,EACnC,MAAM,GAAE,MAAiC,GACxC,QAAQ,CA8CV;AAiBD,wBAAsB,YAAY,CAChC,gBAAgB,CAAC,EAAE,MAAM,EACzB,iBAAiB,CAAC,EAAE,MAAM,GACzB,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CAU1B;AAED,wBAAsB,yBAAyB,CAC7C,KAAK,EAAE,YAAY,EACnB,gBAAgB,CAAC,EAAE,MAAM,EACzB,iBAAiB,CAAC,EAAE,MAAM,GACzB,OAAO,CAAC,QAAQ,CAAC,CASnB"}
|