aiwcli 0.15.5 → 0.17.0
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/README.md +108 -1124
- package/bin/run.js +0 -4
- package/dist/capabilities/branch/adapters.d.ts +2 -0
- package/dist/capabilities/branch/adapters.js +21 -0
- package/dist/capabilities/branch/contracts.d.ts +57 -0
- package/dist/capabilities/branch/contracts.js +1 -0
- package/dist/capabilities/branch/control-plane.d.ts +2 -0
- package/dist/capabilities/branch/control-plane.js +343 -0
- package/dist/capabilities/branch/runtime-core.d.ts +5 -0
- package/dist/capabilities/branch/runtime-core.js +36 -0
- package/dist/capabilities/installation/control-plane/clean-command.d.ts +41 -0
- package/dist/capabilities/installation/control-plane/clean-command.js +196 -0
- package/dist/capabilities/installation/control-plane/clear-command.d.ts +162 -0
- package/dist/capabilities/installation/control-plane/clear-command.js +1249 -0
- package/dist/capabilities/installation/control-plane/init-command.d.ts +81 -0
- package/dist/capabilities/installation/control-plane/init-command.js +449 -0
- package/dist/capabilities/launch/contracts.d.ts +86 -0
- package/dist/capabilities/launch/contracts.js +1 -0
- package/dist/capabilities/launch/control-plane/execute-launch.d.ts +2 -0
- package/dist/capabilities/launch/control-plane/execute-launch.js +261 -0
- package/dist/capabilities/launch/runtime-core/launch-decisions.d.ts +82 -0
- package/dist/capabilities/launch/runtime-core/launch-decisions.js +202 -0
- package/dist/capabilities/launch/runtime-core/launch-options.d.ts +14 -0
- package/dist/capabilities/launch/runtime-core/launch-options.js +69 -0
- package/dist/cli/base-command.d.ts +18 -0
- package/dist/cli/base-command.js +55 -0
- package/dist/commands/branch.d.ts +1 -21
- package/dist/commands/branch.js +25 -417
- package/dist/commands/clean.d.ts +1 -41
- package/dist/commands/clean.js +1 -196
- package/dist/commands/clear.d.ts +1 -161
- package/dist/commands/clear.js +1 -1121
- package/dist/commands/init/index.d.ts +1 -98
- package/dist/commands/init/index.js +4 -478
- package/dist/commands/launch.d.ts +32 -12
- package/dist/commands/launch.js +107 -166
- package/dist/lib/claude-settings-types.d.ts +31 -19
- package/dist/lib/config.js +1 -2
- package/dist/lib/context/context-formatter.d.ts +74 -0
- package/dist/lib/context/context-formatter.js +493 -0
- package/dist/lib/context/context-selector.d.ts +42 -0
- package/dist/lib/context/context-selector.js +451 -0
- package/dist/lib/context/context-store.d.ts +100 -0
- package/dist/lib/context/context-store.js +644 -0
- package/dist/lib/context/plan-manager.d.ts +54 -0
- package/dist/lib/context/plan-manager.js +282 -0
- package/dist/lib/context/task-tracker.d.ts +44 -0
- package/dist/lib/context/task-tracker.js +146 -0
- package/dist/lib/core-ide-base.d.ts +4 -0
- package/dist/lib/core-ide-base.js +77 -0
- package/dist/lib/core-installer.d.ts +5 -0
- package/dist/lib/core-installer.js +33 -0
- package/dist/lib/debug.d.ts +0 -10
- package/dist/lib/debug.js +0 -10
- package/dist/lib/env-sanitizer.d.ts +25 -0
- package/dist/lib/env-sanitizer.js +46 -0
- package/dist/lib/errors.d.ts +0 -13
- package/dist/lib/errors.js +0 -15
- package/dist/lib/git-exclude-manager.d.ts +2 -2
- package/dist/lib/git-exclude-manager.js +3 -3
- package/dist/lib/hooks/context-monitor-logic.d.ts +6 -0
- package/dist/lib/hooks/context-monitor-logic.js +25 -0
- package/dist/lib/hooks/hook-utils.d.ts +143 -0
- package/dist/lib/hooks/hook-utils.js +620 -0
- package/dist/lib/hooks/prompt-binding-logic.d.ts +7 -0
- package/dist/lib/hooks/prompt-binding-logic.js +50 -0
- package/dist/lib/hooks/session-end-logic.d.ts +5 -0
- package/dist/lib/hooks/session-end-logic.js +51 -0
- package/dist/lib/hooks-merger.js +25 -19
- package/dist/lib/ide-path-resolver.d.ts +19 -7
- package/dist/lib/ide-path-resolver.js +25 -9
- package/dist/lib/install-state.d.ts +34 -0
- package/dist/lib/install-state.js +154 -0
- package/dist/lib/json-io.d.ts +12 -0
- package/dist/lib/json-io.js +30 -0
- package/dist/lib/lsp-patch.d.ts +12 -0
- package/dist/lib/lsp-patch.js +156 -0
- package/dist/lib/multiplexer.d.ts +65 -0
- package/dist/lib/multiplexer.js +38 -0
- package/dist/lib/multiplexers/psmux.d.ts +55 -0
- package/dist/lib/multiplexers/psmux.js +324 -0
- package/dist/lib/multiplexers/tmux.d.ts +36 -0
- package/dist/lib/multiplexers/tmux.js +221 -0
- package/dist/lib/multiplexers/wezterm.d.ts +38 -0
- package/dist/lib/multiplexers/wezterm.js +225 -0
- package/dist/lib/mux-utils.d.ts +6 -0
- package/dist/lib/mux-utils.js +36 -0
- package/dist/lib/paths.d.ts +2 -2
- package/dist/lib/paths.js +2 -2
- package/dist/lib/platform-commands.d.ts +27 -0
- package/dist/lib/platform-commands.js +49 -0
- package/dist/lib/prompt-file-manager.d.ts +23 -0
- package/dist/lib/prompt-file-manager.js +41 -0
- package/dist/lib/runtime/agent-launcher.d.ts +67 -0
- package/dist/lib/runtime/agent-launcher.js +262 -0
- package/dist/lib/runtime/aiw-cli.d.ts +39 -0
- package/dist/lib/runtime/aiw-cli.js +76 -0
- package/dist/lib/runtime/atomic-write.d.ts +19 -0
- package/dist/lib/runtime/atomic-write.js +121 -0
- package/dist/lib/runtime/cli-args.d.ts +58 -0
- package/dist/lib/runtime/cli-args.js +200 -0
- package/dist/lib/runtime/constants.d.ts +56 -0
- package/dist/lib/runtime/constants.js +230 -0
- package/dist/lib/runtime/executable-policy.d.ts +16 -0
- package/dist/lib/runtime/executable-policy.js +57 -0
- package/dist/lib/runtime/git-state.d.ts +9 -0
- package/dist/lib/runtime/git-state.js +59 -0
- package/dist/lib/runtime/inference.d.ts +37 -0
- package/dist/lib/runtime/inference.js +251 -0
- package/dist/lib/runtime/lint-dispatch.d.ts +40 -0
- package/dist/lib/runtime/lint-dispatch.js +285 -0
- package/dist/lib/runtime/logger.d.ts +66 -0
- package/dist/lib/runtime/logger.js +201 -0
- package/dist/lib/runtime/models.d.ts +20 -0
- package/dist/lib/runtime/models.js +20 -0
- package/dist/lib/runtime/platform-adapter.d.ts +7 -0
- package/dist/lib/runtime/platform-adapter.js +21 -0
- package/dist/lib/runtime/preflight.d.ts +24 -0
- package/dist/lib/runtime/preflight.js +65 -0
- package/dist/lib/runtime/sentinel-ipc.d.ts +14 -0
- package/dist/lib/runtime/sentinel-ipc.js +67 -0
- package/dist/lib/runtime/state-io.d.ts +31 -0
- package/dist/lib/runtime/state-io.js +179 -0
- package/dist/lib/runtime/stop-words.d.ts +20 -0
- package/dist/lib/runtime/stop-words.js +150 -0
- package/dist/lib/runtime/subprocess-utils.d.ts +29 -0
- package/dist/lib/runtime/subprocess-utils.js +96 -0
- package/dist/lib/runtime/tmux-preflight.d.ts +13 -0
- package/dist/lib/runtime/tmux-preflight.js +78 -0
- package/dist/lib/runtime/utils.d.ts +62 -0
- package/dist/lib/runtime/utils.js +192 -0
- package/dist/lib/schemas.d.ts +250 -0
- package/dist/lib/schemas.js +216 -0
- package/dist/lib/sentinel-manager.d.ts +32 -0
- package/dist/lib/sentinel-manager.js +62 -0
- package/dist/lib/sentinel-wrapper.d.ts +10 -0
- package/dist/lib/sentinel-wrapper.js +29 -0
- package/dist/lib/settings-hierarchy.js +3 -20
- package/dist/lib/shell-adapters/bash-adapter.d.ts +18 -0
- package/dist/lib/shell-adapters/bash-adapter.js +69 -0
- package/dist/lib/shell-adapters/index.d.ts +5 -0
- package/dist/lib/shell-adapters/index.js +7 -0
- package/dist/lib/shell-adapters/powershell-adapter.d.ts +18 -0
- package/dist/lib/shell-adapters/powershell-adapter.js +62 -0
- package/dist/lib/shell-adapters/shell-adapter.d.ts +45 -0
- package/dist/lib/shell-adapters/shell-adapter.js +5 -0
- package/dist/lib/shell-quoting.d.ts +5 -0
- package/dist/lib/shell-quoting.js +17 -0
- package/dist/lib/spawn-errors.d.ts +9 -0
- package/dist/lib/spawn-errors.js +29 -0
- package/dist/lib/spawn.js +5 -11
- package/dist/lib/spinner.d.ts +0 -5
- package/dist/lib/spinner.js +0 -16
- package/dist/lib/template-installer.d.ts +14 -5
- package/dist/lib/template-installer.js +40 -38
- package/dist/lib/template-resolver.d.ts +6 -7
- package/dist/lib/template-resolver.js +26 -21
- package/dist/lib/template-settings-reconstructor.d.ts +7 -2
- package/dist/lib/template-settings-reconstructor.js +76 -45
- package/dist/lib/terminal-strategy.d.ts +12 -0
- package/dist/lib/terminal-strategy.js +55 -0
- package/dist/lib/terminal.d.ts +34 -4
- package/dist/lib/terminal.js +192 -119
- package/dist/lib/tmux-pane-placement.d.ts +17 -0
- package/dist/lib/tmux-pane-placement.js +58 -0
- package/dist/lib/tmux-primitives.d.ts +3 -0
- package/dist/lib/tmux-primitives.js +11 -0
- package/dist/lib/tmux-session.d.ts +32 -0
- package/dist/lib/tmux-session.js +87 -0
- package/dist/lib/tty-detection.js +1 -1
- package/dist/lib/types.d.ts +168 -0
- package/dist/lib/types.js +6 -0
- package/dist/lib/version.d.ts +1 -1
- package/dist/lib/version.js +1 -1
- package/dist/lib/windsurf-hooks-hierarchy.js +6 -23
- package/dist/platform/launch.d.ts +11 -0
- package/dist/platform/launch.js +11 -0
- package/dist/templates/CLAUDE.md +30 -40
- package/dist/templates/cc-native/.claude/settings.json +26 -36
- package/dist/templates/cc-native/CC-NATIVE-README.md +1 -1
- package/dist/templates/cc-native/TEMPLATE-SCHEMA.md +20 -12
- package/dist/templates/cc-native/_cc-native/cc-native.config.json +2 -6
- package/dist/templates/cc-native/_cc-native/hooks/CLAUDE.md +39 -59
- package/dist/templates/cc-native/_cc-native/hooks/cc-native-plan-review.ts +9 -11
- package/dist/templates/cc-native/_cc-native/hooks/enhance_plan_post_subagent.ts +2 -2
- package/dist/templates/cc-native/_cc-native/hooks/enhance_plan_post_write.ts +4 -5
- package/dist/templates/cc-native/_cc-native/hooks/mark_questions_asked.ts +4 -4
- package/dist/templates/cc-native/_cc-native/hooks/plan_questions_early.ts +2 -27
- package/dist/templates/cc-native/_cc-native/hooks/validate_task_prompt.ts +7 -7
- package/dist/templates/cc-native/_cc-native/lib-ts/.mocharc.json +9 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/aggregate-agents.test.ts +118 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/artifacts.test.ts +234 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/cc-native-state.test.ts +170 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/cli-output-parser.test.ts +73 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/config.test.ts +64 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/constants.test.ts +40 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/debug.test.ts +42 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/exports.test.ts +58 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/helpers.ts +107 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/hooks/add-plan-context.hook.test.ts +97 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/hooks/plan-questions.hook.test.ts +81 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/hooks/plan-review.hook.test.ts +71 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/json-parser.test.ts +99 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/orchestrator-agent.test.ts +288 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/orchestrator.test.ts +48 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/reviewers.test.ts +32 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/state.test.ts +124 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/__tests__/verdict.test.ts +93 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/agent-selection.ts +163 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/aggregate-agents.ts +6 -14
- package/dist/templates/cc-native/_cc-native/{artifacts/lib → lib-ts/artifacts}/format.ts +597 -599
- package/dist/templates/cc-native/_cc-native/{artifacts/lib → lib-ts/artifacts}/index.ts +26 -26
- package/dist/templates/cc-native/_cc-native/{artifacts/lib → lib-ts/artifacts}/tracker.ts +106 -107
- package/dist/templates/cc-native/_cc-native/{artifacts/lib → lib-ts/artifacts}/write.ts +118 -119
- package/dist/templates/cc-native/_cc-native/lib-ts/artifacts.ts +21 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/cc-native-state.ts +17 -16
- package/dist/templates/cc-native/_cc-native/lib-ts/cli-output-parser.ts +132 -10
- package/dist/templates/cc-native/_cc-native/lib-ts/config.ts +1 -1
- package/dist/templates/cc-native/_cc-native/lib-ts/constants.ts +6 -6
- package/dist/templates/cc-native/_cc-native/lib-ts/corroboration.ts +119 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/debug.ts +2 -3
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/graduation.ts +132 -132
- package/dist/templates/cc-native/_cc-native/lib-ts/index.ts +88 -86
- package/dist/templates/cc-native/_cc-native/lib-ts/json-parser.ts +5 -6
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/orchestrator.ts +70 -70
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/output-builder.ts +130 -121
- package/dist/templates/cc-native/_cc-native/lib-ts/package-lock.json +1679 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/package.json +24 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/plan-discovery.ts +5 -5
- package/dist/templates/cc-native/_cc-native/lib-ts/plan-enhancement.ts +1 -6
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/plan-questions.ts +101 -101
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/review-pipeline.ts +511 -543
- package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/__tests__/agent-providers.test.ts +262 -0
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/agent.ts +71 -85
- package/dist/templates/{_shared/lib-ts/agent-exec → cc-native/_cc-native/lib-ts/reviewers/base}/base-agent.ts +138 -150
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/index.ts +12 -12
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/providers/claude-agent.ts +66 -57
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/providers/codex-agent.ts +185 -200
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/providers/gemini-agent.ts +39 -40
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/providers/orchestrator-claude-agent.ts +196 -225
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/schemas.ts +201 -201
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/reviewers/types.ts +21 -23
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/__tests__/hyde.test.ts +365 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/__tests__/ollama-client.test.ts +223 -0
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/embedding-indexer.ts +12 -16
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/hyde.ts +3 -2
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/index.ts +31 -31
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/logger.ts +7 -8
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/ollama-client.ts +7 -9
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/retrieval-pipeline.ts +16 -19
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-indexer.ts +37 -41
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-loader.ts +33 -43
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-searcher.ts +20 -20
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/types.ts +9 -10
- package/dist/templates/cc-native/_cc-native/lib-ts/rlm/vector-store.ts +3 -4
- package/dist/templates/cc-native/_cc-native/lib-ts/settings.ts +50 -126
- package/dist/templates/cc-native/_cc-native/lib-ts/state.ts +20 -22
- package/dist/templates/cc-native/_cc-native/lib-ts/tsconfig.json +2 -2
- package/dist/templates/cc-native/_cc-native/lib-ts/types.ts +14 -89
- package/dist/templates/cc-native/_cc-native/{plan-review/lib → lib-ts}/verdict.ts +72 -72
- package/dist/templates/cc-native/_cc-native/plan-review/CLAUDE.md +38 -1
- package/dist/templates/cc-native/_cc-native/plan-review/lib/__tests__/agent-selection.test.ts +345 -0
- package/dist/templates/cc-native/_cc-native/plan-review/lib/__tests__/preflight.test.ts +344 -0
- package/dist/templates/cc-native/_cc-native/plan-review/lib/agent-selection.ts +38 -16
- package/dist/templates/cc-native/_cc-native/plan-review/lib/preflight.ts +56 -26
- package/dist/templates/cc-native/_cc-native/scripts/council_debate.ts +242 -0
- package/dist/templates/cc-native/_cc-native/scripts/council_debate_simple.ts +294 -0
- package/dist/templates/cc-native/_cc-native/{plan-review/workflows → workflows}/specdev.md +9 -9
- package/dist/templates/core/.claude/skills/codex/SKILL.md +25 -0
- package/dist/templates/core/.claude/skills/devin/SKILL.md +25 -0
- package/dist/templates/core/.claude/skills/handoff/SKILL.md +11 -0
- package/dist/templates/core/.claude/skills/handoff-resume/SKILL.md +11 -0
- package/dist/templates/core/.claude/skills/meta-plan/SKILL.md +13 -0
- package/dist/templates/core/.codex/skills/codex/SKILL.md +13 -0
- package/dist/templates/core/.codex/skills/devin/SKILL.md +19 -0
- package/dist/templates/core/.codex/skills/handoff/SKILL.md +11 -0
- package/dist/templates/core/.codex/skills/handoff-resume/SKILL.md +11 -0
- package/dist/templates/core/.codex/skills/meta-plan/SKILL.md +13 -0
- package/dist/templates/core/.devin/AGENTS.md +5 -0
- package/dist/templates/core/.devin/config.json +12 -0
- package/dist/templates/core/.devin/skills/codex/SKILL.md +19 -0
- package/dist/templates/core/.devin/skills/devin/SKILL.md +13 -0
- package/dist/templates/core/.devin/skills/handoff/SKILL.md +11 -0
- package/dist/templates/core/.devin/skills/handoff-resume/SKILL.md +11 -0
- package/dist/templates/core/.devin/skills/meta-plan/SKILL.md +13 -0
- package/dist/templates/core/.windsurf/workflows/handoff-resume.md +9 -0
- package/dist/templates/{_shared → core}/.windsurf/workflows/handoff.md +1 -1
- package/dist/templates/{_shared → core}/.windsurf/workflows/meta-plan.md +1 -1
- package/dist/templates/core/hooks-ts/_utils/git-state.ts +2 -0
- package/dist/templates/{_shared → core}/hooks-ts/archive_plan.ts +15 -44
- package/dist/templates/core/hooks-ts/codex_explorer.ts +160 -0
- package/dist/templates/{_shared → core}/hooks-ts/context_monitor.ts +23 -55
- package/dist/templates/{_shared → core}/hooks-ts/file-suggestion.ts +5 -22
- package/dist/templates/{_shared → core}/hooks-ts/lint_after_edit.ts +7 -9
- package/dist/templates/core/hooks-ts/pre_compact.ts +36 -0
- package/dist/templates/{_shared → core}/hooks-ts/session_end.ts +38 -78
- package/dist/templates/{_shared → core}/hooks-ts/session_start.ts +5 -5
- package/dist/templates/core/hooks-ts/task_create_capture.ts +32 -0
- package/dist/templates/{_shared → core}/hooks-ts/task_update_capture.ts +9 -24
- package/dist/templates/core/hooks-ts/user_prompt_submit.ts +46 -0
- package/dist/templates/{_shared → core}/lib-ts/CLAUDE.md +27 -16
- package/dist/templates/{_shared → core}/lib-ts/context/CLAUDE.md +9 -6
- package/dist/templates/{_shared → core}/lib-ts/context/context-formatter.ts +16 -21
- package/dist/templates/{_shared → core}/lib-ts/context/context-selector.ts +8 -6
- package/dist/templates/{_shared → core}/lib-ts/context/context-store.ts +59 -20
- package/dist/templates/{_shared → core}/lib-ts/context/plan-manager.ts +19 -15
- package/dist/templates/{_shared → core}/lib-ts/context/task-tracker.ts +3 -3
- package/dist/templates/core/lib-ts/hooks/context-monitor-logic.ts +32 -0
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/hooks}/hook-utils.ts +179 -41
- package/dist/templates/core/lib-ts/hooks/prompt-binding-logic.ts +80 -0
- package/dist/templates/core/lib-ts/hooks/session-end-logic.ts +82 -0
- package/dist/templates/core/lib-ts/package.json +19 -0
- package/dist/templates/core/lib-ts/runtime/agent-launcher.ts +369 -0
- package/dist/templates/core/lib-ts/runtime/aiw-cli.ts +108 -0
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/atomic-write.ts +12 -7
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/cli-args.ts +24 -8
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/constants.ts +326 -324
- package/dist/templates/core/lib-ts/runtime/executable-policy.ts +89 -0
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/git-state.ts +6 -4
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/inference.ts +60 -23
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/lint-dispatch.ts +25 -23
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/logger.ts +32 -29
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/models.ts +9 -2
- package/dist/templates/core/lib-ts/runtime/platform-adapter.ts +33 -0
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/preflight.ts +4 -3
- package/dist/templates/core/lib-ts/runtime/sentinel-ipc.ts +91 -0
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/state-io.ts +20 -11
- package/dist/templates/core/lib-ts/runtime/stop-words.ts +185 -0
- package/dist/templates/core/lib-ts/runtime/subprocess-utils.ts +147 -0
- package/dist/templates/core/lib-ts/runtime/tmux-preflight.ts +93 -0
- package/dist/templates/{_shared/lib-ts/base → core/lib-ts/runtime}/utils.ts +34 -4
- package/dist/templates/core/lib-ts/schemas.ts +233 -0
- package/dist/templates/{_shared → core}/lib-ts/templates/formatters.ts +7 -5
- package/dist/templates/{_shared → core}/lib-ts/templates/plan-context.ts +2 -1
- package/dist/templates/{_shared → core}/lib-ts/tsconfig.json +3 -1
- package/dist/templates/{_shared → core}/lib-ts/types.ts +78 -77
- package/dist/templates/core/scripts/resolve-run.ts +93 -0
- package/dist/templates/{_shared → core}/scripts/resolve_context.ts +3 -3
- package/dist/templates/{_shared → core}/scripts/status_line.ts +26 -21
- package/dist/templates/core/skills/codex/CLAUDE.md +83 -0
- package/dist/templates/{_shared → core}/skills/codex/SKILL.md +27 -18
- package/dist/templates/{_shared → core}/skills/codex/lib/codex-watcher.ts +79 -113
- package/dist/templates/{_shared → core}/skills/codex/scripts/launch-codex.ts +134 -148
- package/dist/templates/{_shared → core}/skills/codex/scripts/watch-codex.ts +6 -4
- package/dist/templates/core/skills/devin/CLAUDE.md +122 -0
- package/dist/templates/core/skills/devin/SKILL.md +73 -0
- package/dist/templates/core/skills/devin/lib/devin-watcher.ts +300 -0
- package/dist/templates/core/skills/devin/scripts/launch-devin.ts +258 -0
- package/dist/templates/{_shared → core}/skills/handoff-system/CLAUDE.md +436 -433
- package/dist/templates/{_shared → core}/skills/handoff-system/lib/document-generator.ts +9 -7
- package/dist/templates/{_shared → core}/skills/handoff-system/lib/handoff-reader.ts +6 -4
- package/dist/templates/{_shared → core}/skills/handoff-system/scripts/resume_handoff.ts +10 -8
- package/dist/templates/{_shared → core}/skills/handoff-system/scripts/save_handoff.ts +12 -10
- package/dist/templates/{_shared → core}/skills/handoff-system/workflows/handoff-resume.md +2 -2
- package/dist/templates/{_shared → core}/skills/handoff-system/workflows/handoff.md +6 -5
- package/dist/templates/{_shared → core}/skills/meta-plan/CLAUDE.md +2 -1
- package/dist/templates/{_shared → core}/skills/meta-plan/workflows/meta-plan.md +8 -7
- package/oclif.manifest.json +89 -13
- package/package.json +13 -12
- package/dist/lib/base-command.d.ts +0 -114
- package/dist/lib/base-command.js +0 -153
- package/dist/lib/env-compat.d.ts +0 -18
- package/dist/lib/env-compat.js +0 -23
- package/dist/lib/stdin.d.ts +0 -48
- package/dist/lib/stdin.js +0 -60
- package/dist/templates/_shared/.claude/settings.json +0 -120
- package/dist/templates/_shared/.claude/skills/codex/SKILL.md +0 -35
- package/dist/templates/_shared/.claude/skills/handoff/SKILL.md +0 -13
- package/dist/templates/_shared/.claude/skills/handoff-resume/SKILL.md +0 -13
- package/dist/templates/_shared/.claude/skills/meta-plan/SKILL.md +0 -43
- package/dist/templates/_shared/.codex/workflows/codex.md +0 -11
- package/dist/templates/_shared/.codex/workflows/handoff.md +0 -226
- package/dist/templates/_shared/.codex/workflows/meta-plan.md +0 -347
- package/dist/templates/_shared/hooks-ts/_utils/git-state.ts +0 -2
- package/dist/templates/_shared/hooks-ts/pre_compact.ts +0 -49
- package/dist/templates/_shared/hooks-ts/task_create_capture.ts +0 -48
- package/dist/templates/_shared/hooks-ts/user_prompt_submit.ts +0 -93
- package/dist/templates/_shared/lib-ts/agent-exec/backends/headless.ts +0 -33
- package/dist/templates/_shared/lib-ts/agent-exec/backends/index.ts +0 -6
- package/dist/templates/_shared/lib-ts/agent-exec/backends/tmux.ts +0 -119
- package/dist/templates/_shared/lib-ts/agent-exec/execution-backend.ts +0 -50
- package/dist/templates/_shared/lib-ts/agent-exec/index.ts +0 -6
- package/dist/templates/_shared/lib-ts/agent-exec/structured-output.ts +0 -166
- package/dist/templates/_shared/lib-ts/base/launchers/tmux-launcher.ts +0 -173
- package/dist/templates/_shared/lib-ts/base/launchers/window-launcher.ts +0 -93
- package/dist/templates/_shared/lib-ts/base/launchers/wt-launcher.ts +0 -64
- package/dist/templates/_shared/lib-ts/base/pane-launcher.ts +0 -55
- package/dist/templates/_shared/lib-ts/base/sentinel-ipc.ts +0 -87
- package/dist/templates/_shared/lib-ts/base/stop-words.ts +0 -184
- package/dist/templates/_shared/lib-ts/base/subprocess-utils.ts +0 -249
- package/dist/templates/_shared/lib-ts/base/tmux-driver.ts +0 -341
- package/dist/templates/_shared/lib-ts/base/tmux-pane-placement.ts +0 -78
- package/dist/templates/_shared/lib-ts/package.json +0 -20
- package/dist/templates/_shared/scripts/resolve-run.ts +0 -62
- package/dist/templates/_shared/skills/codex/CLAUDE.md +0 -70
- package/dist/templates/cc-native/_cc-native/CLAUDE.md +0 -73
- package/dist/templates/cc-native/_cc-native/artifacts/CLAUDE.md +0 -64
- package/dist/templates/cc-native/_cc-native/lib-ts/CLAUDE.md +0 -70
- package/dist/templates/cc-native/_cc-native/plan-review/CODING-STANDARDS-CHECKLIST.md +0 -75
- package/dist/templates/cc-native/_cc-native/plan-review/agents/CLAUDE.md +0 -143
- package/dist/templates/cc-native/_cc-native/plan-review/agents/PLAN-ORCHESTRATOR.md +0 -213
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-questions/PLAN-QUESTIONER.md +0 -70
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/ARCH-EVOLUTION.md +0 -62
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/ARCH-PATTERNS.md +0 -61
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/ARCH-STRUCTURE.md +0 -62
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/ASSUMPTION-TRACER.md +0 -56
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/CLARITY-AUDITOR.md +0 -53
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/COMPLETENESS-FEASIBILITY.md +0 -66
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/COMPLETENESS-GAPS.md +0 -70
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/COMPLETENESS-ORDERING.md +0 -62
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/CONSTRAINT-VALIDATOR.md +0 -72
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/DESIGN-ADR-VALIDATOR.md +0 -61
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/DESIGN-SCALE-MATCHER.md +0 -64
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/DEVILS-ADVOCATE.md +0 -56
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/DOCUMENTATION-PHILOSOPHY.md +0 -86
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/HANDOFF-READINESS.md +0 -59
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/HIDDEN-COMPLEXITY.md +0 -58
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/INCREMENTAL-DELIVERY.md +0 -66
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/RISK-DEPENDENCY.md +0 -62
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/RISK-FMEA.md +0 -66
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/RISK-PREMORTEM.md +0 -71
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/RISK-REVERSIBILITY.md +0 -74
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/SCOPE-BOUNDARY.md +0 -77
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/SIMPLICITY-GUARDIAN.md +0 -62
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/SKEPTIC.md +0 -68
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/TESTDRIVEN-BEHAVIOR-AUDITOR.md +0 -61
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/TESTDRIVEN-CHARACTERIZATION.md +0 -71
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/TESTDRIVEN-FIRST-VALIDATOR.md +0 -61
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/TESTDRIVEN-PYRAMID-ANALYZER.md +0 -61
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/TRADEOFF-COSTS.md +0 -67
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/TRADEOFF-STAKEHOLDERS.md +0 -65
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/VERIFY-COVERAGE.md +0 -74
- package/dist/templates/cc-native/_cc-native/plan-review/agents/plan-review/VERIFY-STRENGTH.md +0 -69
- package/dist/templates/cc-native/_cc-native/plan-review/lib/corroboration.ts +0 -172
- package/dist/templates/cc-native/_cc-native/plan-review/lib/reviewers/base/base-agent.ts +0 -7
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Centralized CLI argument construction for agent subprocesses.
|
|
3
|
+
* Single source of truth for Claude CLI and Codex CLI flag patterns,
|
|
4
|
+
* platform quoting, model tier resolution, and env setup.
|
|
5
|
+
*/
|
|
6
|
+
import { CLAUDE_MODELS, CODEX_MODELS, DEVIN_MODELS } from "./models.js";
|
|
7
|
+
import { getInternalSubprocessEnv, shellQuoteWin } from "./subprocess-utils.js";
|
|
8
|
+
const VALID_SANDBOXES = ["read-only", "workspace-write", "danger-full-access"];
|
|
9
|
+
export function isCodexSandbox(value) {
|
|
10
|
+
return VALID_SANDBOXES.includes(value);
|
|
11
|
+
}
|
|
12
|
+
// ---------------------------------------------------------------------------
|
|
13
|
+
// Model Tier Resolution
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
export const MODEL_TIERS = {
|
|
16
|
+
fast: CLAUDE_MODELS.haiku,
|
|
17
|
+
standard: CLAUDE_MODELS.sonnet,
|
|
18
|
+
smart: CLAUDE_MODELS.opus,
|
|
19
|
+
};
|
|
20
|
+
export const CODEX_MODEL_TIERS = {
|
|
21
|
+
fast: CODEX_MODELS.spark,
|
|
22
|
+
standard: CODEX_MODELS.codex,
|
|
23
|
+
smart: CODEX_MODELS.codex,
|
|
24
|
+
};
|
|
25
|
+
export const DEVIN_MODEL_TIERS = {
|
|
26
|
+
fast: DEVIN_MODELS.sonnet,
|
|
27
|
+
standard: DEVIN_MODELS.swe,
|
|
28
|
+
smart: DEVIN_MODELS.opus,
|
|
29
|
+
};
|
|
30
|
+
export const TIER_TIMEOUTS = {
|
|
31
|
+
fast: 15,
|
|
32
|
+
standard: 30,
|
|
33
|
+
smart: 90,
|
|
34
|
+
};
|
|
35
|
+
export function isModelTier(value) {
|
|
36
|
+
return value in MODEL_TIERS;
|
|
37
|
+
}
|
|
38
|
+
export function resolveModel(model) {
|
|
39
|
+
if (isModelTier(model))
|
|
40
|
+
return MODEL_TIERS[model];
|
|
41
|
+
return model;
|
|
42
|
+
}
|
|
43
|
+
export function resolveModelForProvider(model, provider) {
|
|
44
|
+
if (!isModelTier(model))
|
|
45
|
+
return model;
|
|
46
|
+
if (provider === "codex")
|
|
47
|
+
return CODEX_MODEL_TIERS[model];
|
|
48
|
+
if (provider === "devin")
|
|
49
|
+
return DEVIN_MODEL_TIERS[model];
|
|
50
|
+
return MODEL_TIERS[model];
|
|
51
|
+
}
|
|
52
|
+
export function getTierTimeout(tier) {
|
|
53
|
+
return TIER_TIMEOUTS[tier];
|
|
54
|
+
}
|
|
55
|
+
/** Resolve a Codex model: tier resolution + pass-through. No aliases (those are skill-specific). */
|
|
56
|
+
export function resolveCodexModel(input) {
|
|
57
|
+
if (isModelTier(input))
|
|
58
|
+
return CODEX_MODEL_TIERS[input];
|
|
59
|
+
return input;
|
|
60
|
+
}
|
|
61
|
+
/** Resolve a Devin model: tier resolution + pass-through. No aliases (those are skill-specific). */
|
|
62
|
+
export function resolveDevinModel(input) {
|
|
63
|
+
if (isModelTier(input))
|
|
64
|
+
return DEVIN_MODEL_TIERS[input];
|
|
65
|
+
return input;
|
|
66
|
+
}
|
|
67
|
+
// ---------------------------------------------------------------------------
|
|
68
|
+
// Core Builder
|
|
69
|
+
// ---------------------------------------------------------------------------
|
|
70
|
+
export function buildCliInvocation(spec) {
|
|
71
|
+
const env = getInternalSubprocessEnv();
|
|
72
|
+
delete env.ANTHROPIC_API_KEY;
|
|
73
|
+
if (spec.mode === "repl") {
|
|
74
|
+
const resolvedModel = spec.model ? resolveModelForProvider(spec.model, spec.provider) : undefined;
|
|
75
|
+
return buildCodexReplInvocation(spec, resolvedModel, env);
|
|
76
|
+
}
|
|
77
|
+
const resolvedModel = resolveModelForProvider(spec.model, spec.provider);
|
|
78
|
+
const isWin = process.platform === "win32";
|
|
79
|
+
const empty = isWin ? '""' : "";
|
|
80
|
+
if (spec.provider === "claude") {
|
|
81
|
+
return buildClaudeInvocation(spec, resolvedModel, isWin, empty, env);
|
|
82
|
+
}
|
|
83
|
+
return buildCodexInvocation(spec, resolvedModel, env);
|
|
84
|
+
}
|
|
85
|
+
function buildClaudeInvocation(spec, model, isWin, empty, env) {
|
|
86
|
+
const args = [];
|
|
87
|
+
args.push("--model", model);
|
|
88
|
+
if (spec.mode === "print") {
|
|
89
|
+
args.push("--print");
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
// structured and preflight both use json output
|
|
93
|
+
args.push("--output-format", "json");
|
|
94
|
+
if (spec.jsonSchema) {
|
|
95
|
+
args.push("--json-schema", shellQuoteWin(JSON.stringify(spec.jsonSchema)));
|
|
96
|
+
}
|
|
97
|
+
const maxTurns = spec.mode === "preflight" ? 1 : (spec.maxTurns ?? 3);
|
|
98
|
+
args.push("--max-turns", String(maxTurns));
|
|
99
|
+
}
|
|
100
|
+
args.push("--setting-sources", empty);
|
|
101
|
+
args.push("-p");
|
|
102
|
+
args.push("--no-session-persistence");
|
|
103
|
+
if (spec.systemPrompt) {
|
|
104
|
+
args.push("--system-prompt", shellQuoteWin(spec.systemPrompt));
|
|
105
|
+
}
|
|
106
|
+
if (spec.extraArgs) {
|
|
107
|
+
args.push(...spec.extraArgs);
|
|
108
|
+
}
|
|
109
|
+
return { cliName: "claude", args, needsShell: isWin, env };
|
|
110
|
+
}
|
|
111
|
+
function buildCodexInvocation(spec, model, env) {
|
|
112
|
+
const args = ["exec"];
|
|
113
|
+
if (spec.sandbox) {
|
|
114
|
+
args.push("--sandbox", spec.sandbox);
|
|
115
|
+
}
|
|
116
|
+
args.push("--model", model);
|
|
117
|
+
if (spec.outputSchemaPath) {
|
|
118
|
+
args.push("--output-schema", spec.outputSchemaPath);
|
|
119
|
+
}
|
|
120
|
+
if (spec.outputFilePath) {
|
|
121
|
+
args.push("-o", spec.outputFilePath);
|
|
122
|
+
}
|
|
123
|
+
args.push("-");
|
|
124
|
+
if (spec.extraArgs) {
|
|
125
|
+
args.push(...spec.extraArgs);
|
|
126
|
+
}
|
|
127
|
+
return { cliName: "codex", args, needsShell: false, env };
|
|
128
|
+
}
|
|
129
|
+
function buildCodexReplInvocation(spec, model, env) {
|
|
130
|
+
const args = [];
|
|
131
|
+
if (spec.yolo)
|
|
132
|
+
args.push("--dangerously-bypass-approvals-and-sandbox");
|
|
133
|
+
if (spec.sandbox)
|
|
134
|
+
args.push("--sandbox", spec.sandbox);
|
|
135
|
+
if (model)
|
|
136
|
+
args.push("--model", model);
|
|
137
|
+
if (spec.extraArgs)
|
|
138
|
+
args.push(...spec.extraArgs);
|
|
139
|
+
return { cliName: "codex", args, needsShell: false, env };
|
|
140
|
+
}
|
|
141
|
+
// ---------------------------------------------------------------------------
|
|
142
|
+
// Convenience Presets
|
|
143
|
+
// ---------------------------------------------------------------------------
|
|
144
|
+
export function preflightSpec(provider, model) {
|
|
145
|
+
if (provider === "codex") {
|
|
146
|
+
return {
|
|
147
|
+
provider: "codex",
|
|
148
|
+
model,
|
|
149
|
+
mode: "preflight",
|
|
150
|
+
sandbox: "read-only",
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
return {
|
|
154
|
+
provider: "claude",
|
|
155
|
+
model,
|
|
156
|
+
mode: "preflight",
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
export function inferenceSpec(model) {
|
|
160
|
+
return {
|
|
161
|
+
provider: "claude",
|
|
162
|
+
model,
|
|
163
|
+
mode: "print",
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
export function reviewSpec(provider, model, schema, systemPrompt) {
|
|
167
|
+
if (provider === "codex") {
|
|
168
|
+
return {
|
|
169
|
+
provider: "codex",
|
|
170
|
+
model,
|
|
171
|
+
mode: "structured",
|
|
172
|
+
sandbox: "read-only",
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
return {
|
|
176
|
+
provider: "claude",
|
|
177
|
+
model,
|
|
178
|
+
mode: "structured",
|
|
179
|
+
jsonSchema: schema,
|
|
180
|
+
...(systemPrompt ? { systemPrompt } : {}),
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
export function codexReplSpec(model, sandbox, yolo) {
|
|
184
|
+
return {
|
|
185
|
+
provider: "codex",
|
|
186
|
+
mode: "repl",
|
|
187
|
+
...(model ? { model } : {}),
|
|
188
|
+
...(sandbox ? { sandbox } : {}),
|
|
189
|
+
...(yolo !== undefined ? { yolo } : {}),
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
export function preflightCommandConfig(provider) {
|
|
193
|
+
const input = "Respond with exactly: ok";
|
|
194
|
+
return {
|
|
195
|
+
cliName: provider === "claude" ? "claude" : "codex",
|
|
196
|
+
buildArgs: (model) => buildCliInvocation(preflightSpec(provider, model)).args,
|
|
197
|
+
input,
|
|
198
|
+
};
|
|
199
|
+
}
|
|
200
|
+
export { CLAUDE_MODELS, CODEX_MODELS, DEVIN_MODELS } from "./models.js";
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Constants and path utilities for shared context management.
|
|
3
|
+
* See SPEC.md §2
|
|
4
|
+
*/
|
|
5
|
+
export declare const MAX_CONTEXT_ID_LENGTH = 64;
|
|
6
|
+
export declare const VALID_CONTEXT_ID_PATTERN: RegExp;
|
|
7
|
+
export declare const MAX_EVENT_SIZE: number;
|
|
8
|
+
export declare const MAX_INDEX_SIZE: number;
|
|
9
|
+
export declare const MAX_RETRY_ATTEMPTS = 2;
|
|
10
|
+
export declare const RETRY_BACKOFF_MS: number[];
|
|
11
|
+
/**
|
|
12
|
+
* Sanitize a string into a valid context ID.
|
|
13
|
+
* See SPEC.md §2.3
|
|
14
|
+
*/
|
|
15
|
+
export declare function sanitizeContextId(contextId: string): string;
|
|
16
|
+
/**
|
|
17
|
+
* Validate and normalize context ID.
|
|
18
|
+
* Throws only for security violations (path traversal).
|
|
19
|
+
* See SPEC.md §2.3
|
|
20
|
+
*/
|
|
21
|
+
export declare function validateContextId(contextId: string): string;
|
|
22
|
+
/**
|
|
23
|
+
* Get project root from environment or cwd.
|
|
24
|
+
* Priority: CLAUDE_PROJECT_DIR > walk up from payload cwd > walk up from process.cwd()
|
|
25
|
+
* Walks upward to find the nearest .aiwcli/ anchor, so cwd drift (e.g. after
|
|
26
|
+
* `cd packages/cli` in a Bash tool call) doesn't break hook resolution.
|
|
27
|
+
* See SPEC.md §2.2
|
|
28
|
+
*/
|
|
29
|
+
export declare function getProjectRoot(payloadCwd?: string): string;
|
|
30
|
+
export declare function getAiwcliDir(projectRoot?: string): string;
|
|
31
|
+
export declare function getOutputDir(projectRoot?: string): string;
|
|
32
|
+
export declare function getContextsDir(projectRoot?: string): string;
|
|
33
|
+
export declare function getContextDir(contextId: string, projectRoot?: string): string;
|
|
34
|
+
export declare function getContextPlansDir(contextId: string, projectRoot?: string): string;
|
|
35
|
+
export declare function getContextHandoffsDir(contextId: string, projectRoot?: string): string;
|
|
36
|
+
export declare function getContextReviewsDir(contextId: string, projectRoot?: string): string;
|
|
37
|
+
export declare function getIndexPath(projectRoot?: string): string;
|
|
38
|
+
export declare function getContextFilePath(contextId: string, projectRoot?: string): string;
|
|
39
|
+
export declare function getEventsFilePath(contextId: string, projectRoot?: string): string;
|
|
40
|
+
export declare function getAutoStatePath(contextId: string, projectRoot?: string): string;
|
|
41
|
+
export declare function getArchiveDir(projectRoot?: string): string;
|
|
42
|
+
export declare function getArchiveContextDir(contextId: string, projectRoot?: string): string;
|
|
43
|
+
export declare function getArchiveIndexPath(projectRoot?: string): string;
|
|
44
|
+
/**
|
|
45
|
+
* Get path for a new handoff folder with datetime naming.
|
|
46
|
+
* Handles collisions by appending -N suffix.
|
|
47
|
+
* See SPEC.md §2.4
|
|
48
|
+
*/
|
|
49
|
+
export declare function getHandoffFolderPath(contextId: string, projectRoot?: string): string;
|
|
50
|
+
/**
|
|
51
|
+
* Get path for a new review folder.
|
|
52
|
+
* See SPEC.md §2.4
|
|
53
|
+
*/
|
|
54
|
+
export declare function getReviewFolderPath(contextId: string, iteration: number, projectRoot?: string): string;
|
|
55
|
+
export declare function sanitizeFilename(s: string, maxLen?: number, allowLeadingDot?: boolean): string;
|
|
56
|
+
export declare function sanitizeTitle(s: string, maxLen?: number): string;
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Constants and path utilities for shared context management.
|
|
3
|
+
* See SPEC.md §2
|
|
4
|
+
*/
|
|
5
|
+
import * as fs from "node:fs";
|
|
6
|
+
import path from "node:path";
|
|
7
|
+
import { logWarn } from "./logger.js";
|
|
8
|
+
// Directory names (relative to project root)
|
|
9
|
+
const OUTPUT_DIR = "_output";
|
|
10
|
+
const CONTEXTS_DIR = "contexts";
|
|
11
|
+
const ARCHIVE_DIR = "_archive";
|
|
12
|
+
const INDEX_FILENAME = "index.json";
|
|
13
|
+
// Context ID validation
|
|
14
|
+
export const MAX_CONTEXT_ID_LENGTH = 64;
|
|
15
|
+
export const VALID_CONTEXT_ID_PATTERN = /^[a-z0-9][a-z0-9_-]*[a-z0-9]$|^[a-z0-9]$/;
|
|
16
|
+
// File size limits
|
|
17
|
+
export const MAX_EVENT_SIZE = 64 * 1024;
|
|
18
|
+
export const MAX_INDEX_SIZE = 1024 * 1024;
|
|
19
|
+
// Performance constants
|
|
20
|
+
export const MAX_RETRY_ATTEMPTS = 2;
|
|
21
|
+
export const RETRY_BACKOFF_MS = [500, 1000];
|
|
22
|
+
// Windows reserved filenames
|
|
23
|
+
const WINDOWS_RESERVED = new Set([
|
|
24
|
+
"AUX", "COM1", "COM2", "COM3",
|
|
25
|
+
"COM4", "COM5", "COM6", "COM7", "COM8", "COM9", "CON", "LPT1", "LPT2",
|
|
26
|
+
"LPT3", "LPT4", "LPT5", "LPT6", "LPT7", "LPT8", "LPT9", "NUL", "PRN",
|
|
27
|
+
]);
|
|
28
|
+
/**
|
|
29
|
+
* Sanitize a string into a valid context ID.
|
|
30
|
+
* See SPEC.md §2.3
|
|
31
|
+
*/
|
|
32
|
+
export function sanitizeContextId(contextId) {
|
|
33
|
+
if (!contextId)
|
|
34
|
+
return "context";
|
|
35
|
+
let result = contextId.toLowerCase();
|
|
36
|
+
result = result.replaceAll(/[^a-z0-9_-]/g, "-");
|
|
37
|
+
result = result.replaceAll(/[-_]+/g, "-");
|
|
38
|
+
result = result.replaceAll(/^[-_]+|[-_]+$/g, "");
|
|
39
|
+
if (result.length > MAX_CONTEXT_ID_LENGTH) {
|
|
40
|
+
result = result.slice(0, MAX_CONTEXT_ID_LENGTH).replace(/[-_]+$/, "");
|
|
41
|
+
}
|
|
42
|
+
return result || "context";
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Validate and normalize context ID.
|
|
46
|
+
* Throws only for security violations (path traversal).
|
|
47
|
+
* See SPEC.md §2.3
|
|
48
|
+
*/
|
|
49
|
+
export function validateContextId(contextId) {
|
|
50
|
+
if (!contextId)
|
|
51
|
+
return "context";
|
|
52
|
+
// SECURITY: Check for path traversal BEFORE unknown normalization
|
|
53
|
+
if (contextId.includes("..") ||
|
|
54
|
+
contextId.includes("/") ||
|
|
55
|
+
contextId.includes("\\")) {
|
|
56
|
+
throw new Error(`Invalid context ID '${contextId}': path traversal not allowed`);
|
|
57
|
+
}
|
|
58
|
+
// Check for URL-encoded variants
|
|
59
|
+
const lower = contextId.toLowerCase();
|
|
60
|
+
if (lower.includes("%2e") ||
|
|
61
|
+
lower.includes("%2f") ||
|
|
62
|
+
lower.includes("%5c")) {
|
|
63
|
+
throw new Error(`Invalid context ID '${contextId}': encoded path traversal not allowed`);
|
|
64
|
+
}
|
|
65
|
+
return sanitizeContextId(contextId);
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Walk up from startDir until a directory containing `.aiwcli/` is found.
|
|
69
|
+
* Returns startDir itself if no anchor is found (fail-safe).
|
|
70
|
+
* See SPEC.md §2.2
|
|
71
|
+
*/
|
|
72
|
+
function findProjectRoot(startDir) {
|
|
73
|
+
let dir = startDir;
|
|
74
|
+
while (true) {
|
|
75
|
+
if (fs.existsSync(path.join(dir, ".aiwcli")))
|
|
76
|
+
return dir;
|
|
77
|
+
const parent = path.dirname(dir);
|
|
78
|
+
if (parent === dir)
|
|
79
|
+
break; // filesystem root reached
|
|
80
|
+
dir = parent;
|
|
81
|
+
}
|
|
82
|
+
return startDir; // fallback: no .aiwcli anchor found
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Get project root from environment or cwd.
|
|
86
|
+
* Priority: CLAUDE_PROJECT_DIR > walk up from payload cwd > walk up from process.cwd()
|
|
87
|
+
* Walks upward to find the nearest .aiwcli/ anchor, so cwd drift (e.g. after
|
|
88
|
+
* `cd packages/cli` in a Bash tool call) doesn't break hook resolution.
|
|
89
|
+
* See SPEC.md §2.2
|
|
90
|
+
*/
|
|
91
|
+
export function getProjectRoot(payloadCwd) {
|
|
92
|
+
const envDir = process.env.CLAUDE_PROJECT_DIR;
|
|
93
|
+
if (envDir) {
|
|
94
|
+
if (!path.isAbsolute(envDir)) {
|
|
95
|
+
logWarn("utils", `CLAUDE_PROJECT_DIR is not absolute: '${envDir}', ignoring`);
|
|
96
|
+
}
|
|
97
|
+
else if (envDir.includes("..")) {
|
|
98
|
+
logWarn("utils", `CLAUDE_PROJECT_DIR contains '..': '${envDir}', ignoring`);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
return envDir;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (payloadCwd)
|
|
105
|
+
return findProjectRoot(payloadCwd);
|
|
106
|
+
return findProjectRoot(process.cwd());
|
|
107
|
+
}
|
|
108
|
+
// §2.4 — Path functions
|
|
109
|
+
export function getAiwcliDir(projectRoot) {
|
|
110
|
+
return path.join(projectRoot ?? getProjectRoot(), ".aiwcli");
|
|
111
|
+
}
|
|
112
|
+
export function getOutputDir(projectRoot) {
|
|
113
|
+
return path.join(projectRoot ?? getProjectRoot(), OUTPUT_DIR);
|
|
114
|
+
}
|
|
115
|
+
export function getContextsDir(projectRoot) {
|
|
116
|
+
return path.join(getOutputDir(projectRoot), CONTEXTS_DIR);
|
|
117
|
+
}
|
|
118
|
+
export function getContextDir(contextId, projectRoot) {
|
|
119
|
+
const validatedId = validateContextId(contextId);
|
|
120
|
+
const contextsDir = getContextsDir(projectRoot);
|
|
121
|
+
const resultPath = path.join(contextsDir, validatedId);
|
|
122
|
+
// SECURITY: Verify resolved path stays within contexts directory
|
|
123
|
+
const resolved = path.resolve(resultPath);
|
|
124
|
+
const contextsResolved = path.resolve(contextsDir);
|
|
125
|
+
if (!resolved.toLowerCase().startsWith(contextsResolved.toLowerCase())) {
|
|
126
|
+
throw new Error(`Invalid context ID '${contextId}': path escapes contexts directory`);
|
|
127
|
+
}
|
|
128
|
+
return resultPath;
|
|
129
|
+
}
|
|
130
|
+
export function getContextPlansDir(contextId, projectRoot) {
|
|
131
|
+
return path.join(getContextDir(contextId, projectRoot), "plans");
|
|
132
|
+
}
|
|
133
|
+
export function getContextHandoffsDir(contextId, projectRoot) {
|
|
134
|
+
return path.join(getContextDir(contextId, projectRoot), "handoffs");
|
|
135
|
+
}
|
|
136
|
+
export function getContextReviewsDir(contextId, projectRoot) {
|
|
137
|
+
return path.join(getContextDir(contextId, projectRoot), "reviews");
|
|
138
|
+
}
|
|
139
|
+
export function getIndexPath(projectRoot) {
|
|
140
|
+
return path.join(getOutputDir(projectRoot), INDEX_FILENAME);
|
|
141
|
+
}
|
|
142
|
+
export function getContextFilePath(contextId, projectRoot) {
|
|
143
|
+
return path.join(getContextDir(contextId, projectRoot), "context.json");
|
|
144
|
+
}
|
|
145
|
+
export function getEventsFilePath(contextId, projectRoot) {
|
|
146
|
+
return path.join(getContextDir(contextId, projectRoot), "events.jsonl");
|
|
147
|
+
}
|
|
148
|
+
export function getAutoStatePath(contextId, projectRoot) {
|
|
149
|
+
return path.join(getContextDir(contextId, projectRoot), "auto-state.json");
|
|
150
|
+
}
|
|
151
|
+
export function getArchiveDir(projectRoot) {
|
|
152
|
+
return path.join(getContextsDir(projectRoot), ARCHIVE_DIR);
|
|
153
|
+
}
|
|
154
|
+
export function getArchiveContextDir(contextId, projectRoot) {
|
|
155
|
+
const validatedId = validateContextId(contextId);
|
|
156
|
+
return path.join(getArchiveDir(projectRoot), validatedId);
|
|
157
|
+
}
|
|
158
|
+
export function getArchiveIndexPath(projectRoot) {
|
|
159
|
+
return path.join(getArchiveDir(projectRoot), INDEX_FILENAME);
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get path for a new handoff folder with datetime naming.
|
|
163
|
+
* Handles collisions by appending -N suffix.
|
|
164
|
+
* See SPEC.md §2.4
|
|
165
|
+
*/
|
|
166
|
+
export function getHandoffFolderPath(contextId, projectRoot) {
|
|
167
|
+
const handoffsDir = getContextHandoffsDir(contextId, projectRoot);
|
|
168
|
+
const now = new Date();
|
|
169
|
+
const timestamp = [
|
|
170
|
+
now.getFullYear().toString(),
|
|
171
|
+
String(now.getMonth() + 1).padStart(2, "0"),
|
|
172
|
+
String(now.getDate()).padStart(2, "0"),
|
|
173
|
+
"-",
|
|
174
|
+
String(now.getHours()).padStart(2, "0"),
|
|
175
|
+
String(now.getMinutes()).padStart(2, "0"),
|
|
176
|
+
].join("");
|
|
177
|
+
// Format: YYYY-MM-DD-HHMM
|
|
178
|
+
const ts = `${timestamp.slice(0, 4)}-${timestamp.slice(4, 6)}-${timestamp.slice(6, 8)}${timestamp.slice(8)}`;
|
|
179
|
+
let folder = path.join(handoffsDir, ts);
|
|
180
|
+
let counter = 1;
|
|
181
|
+
while (fs.existsSync(folder)) {
|
|
182
|
+
folder = path.join(handoffsDir, `${ts}-${counter}`);
|
|
183
|
+
counter++;
|
|
184
|
+
}
|
|
185
|
+
return folder;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Get path for a new review folder.
|
|
189
|
+
* See SPEC.md §2.4
|
|
190
|
+
*/
|
|
191
|
+
export function getReviewFolderPath(contextId, iteration, projectRoot) {
|
|
192
|
+
const reviewsDir = path.join(getContextReviewsDir(contextId, projectRoot), "cc-native");
|
|
193
|
+
const now = new Date();
|
|
194
|
+
const ts = [
|
|
195
|
+
now.getFullYear().toString(),
|
|
196
|
+
"-",
|
|
197
|
+
String(now.getMonth() + 1).padStart(2, "0"),
|
|
198
|
+
"-",
|
|
199
|
+
String(now.getDate()).padStart(2, "0"),
|
|
200
|
+
"-",
|
|
201
|
+
String(now.getHours()).padStart(2, "0"),
|
|
202
|
+
String(now.getMinutes()).padStart(2, "0"),
|
|
203
|
+
].join("");
|
|
204
|
+
return path.join(reviewsDir, `${ts}-iteration-${iteration}`);
|
|
205
|
+
}
|
|
206
|
+
// §2.5 — Filename sanitization
|
|
207
|
+
export function sanitizeFilename(s, maxLen = 32, allowLeadingDot = false) {
|
|
208
|
+
let result = s.replaceAll(/[^A-Za-z0-9._-]+/g, "_");
|
|
209
|
+
result = result.replaceAll(/^[._-]+|[._-]+$/g, "").slice(0, maxLen) || "unknown";
|
|
210
|
+
if (!allowLeadingDot) {
|
|
211
|
+
result = result.replace(/^\.+/, "");
|
|
212
|
+
}
|
|
213
|
+
const baseName = (result.split(".")[0] ?? result).toUpperCase();
|
|
214
|
+
if (WINDOWS_RESERVED.has(baseName)) {
|
|
215
|
+
result = `_${result}`;
|
|
216
|
+
}
|
|
217
|
+
return result || "unknown";
|
|
218
|
+
}
|
|
219
|
+
export function sanitizeTitle(s, maxLen = 50) {
|
|
220
|
+
let result = s.toLowerCase().trim();
|
|
221
|
+
result = result.replaceAll(' ', "-");
|
|
222
|
+
result = result.replaceAll(/[^a-z0-9._-]+/g, "_");
|
|
223
|
+
result = result.replaceAll(/[-_]+/g, "-");
|
|
224
|
+
result = result.replaceAll(/^[._-]+|[._-]+$/g, "").slice(0, maxLen) || "unknown";
|
|
225
|
+
const baseName = (result.split(".")[0] ?? result).toUpperCase();
|
|
226
|
+
if (WINDOWS_RESERVED.has(baseName)) {
|
|
227
|
+
result = `_${result}`;
|
|
228
|
+
}
|
|
229
|
+
return result || "unknown";
|
|
230
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export type WindowsLookupProfile = 'cmdOrExeFirst' | 'exeThenExtensionlessThenCmd';
|
|
2
|
+
export declare function parseLookupLines(stdout: string): string[];
|
|
3
|
+
export declare function pickWindowsPath(lines: string[], profile: WindowsLookupProfile): null | string;
|
|
4
|
+
export declare function selectLookupPath(lines: string[], platform?: NodeJS.Platform, windowsProfile?: WindowsLookupProfile): null | string;
|
|
5
|
+
export declare function resolveExecutable(name: string, options?: {
|
|
6
|
+
platform?: NodeJS.Platform | undefined;
|
|
7
|
+
timeoutMs?: number | undefined;
|
|
8
|
+
windowsHide?: boolean | undefined;
|
|
9
|
+
windowsProfile?: undefined | WindowsLookupProfile;
|
|
10
|
+
}): null | string;
|
|
11
|
+
export declare function isCommandAvailable(name: string, platform?: NodeJS.Platform): boolean;
|
|
12
|
+
export declare function lookupExecutables(name: string, options?: {
|
|
13
|
+
platform?: NodeJS.Platform | undefined;
|
|
14
|
+
timeoutMs?: number | undefined;
|
|
15
|
+
windowsHide?: boolean | undefined;
|
|
16
|
+
}): string[];
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { execSync } from 'node:child_process';
|
|
2
|
+
import { commandLookupBinary, isWindowsPlatform } from './platform-adapter.js';
|
|
3
|
+
export function parseLookupLines(stdout) {
|
|
4
|
+
return stdout
|
|
5
|
+
.trim()
|
|
6
|
+
.split(/\r?\n/)
|
|
7
|
+
.map((line) => line.trim())
|
|
8
|
+
.filter(Boolean);
|
|
9
|
+
}
|
|
10
|
+
export function pickWindowsPath(lines, profile) {
|
|
11
|
+
if (lines.length === 0)
|
|
12
|
+
return null;
|
|
13
|
+
if (profile === 'cmdOrExeFirst') {
|
|
14
|
+
return lines.find((line) => /\.(cmd|exe)$/i.test(line)) ?? lines[0] ?? null;
|
|
15
|
+
}
|
|
16
|
+
return lines.find((line) => /\.exe$/i.test(line))
|
|
17
|
+
?? lines.find((line) => !/\.(cmd|ps1)$/i.test(line))
|
|
18
|
+
?? lines.find((line) => /\.cmd$/i.test(line))
|
|
19
|
+
?? lines[0]
|
|
20
|
+
?? null;
|
|
21
|
+
}
|
|
22
|
+
export function selectLookupPath(lines, platform = process.platform, windowsProfile = 'cmdOrExeFirst') {
|
|
23
|
+
if (lines.length === 0)
|
|
24
|
+
return null;
|
|
25
|
+
if (!isWindowsPlatform(platform))
|
|
26
|
+
return lines[0] ?? null;
|
|
27
|
+
return pickWindowsPath(lines, windowsProfile);
|
|
28
|
+
}
|
|
29
|
+
export function resolveExecutable(name, options) {
|
|
30
|
+
const platform = options?.platform ?? process.platform;
|
|
31
|
+
const lines = lookupExecutables(name, {
|
|
32
|
+
platform,
|
|
33
|
+
timeoutMs: options?.timeoutMs,
|
|
34
|
+
windowsHide: options?.windowsHide,
|
|
35
|
+
});
|
|
36
|
+
return selectLookupPath(lines, platform, options?.windowsProfile ?? 'cmdOrExeFirst');
|
|
37
|
+
}
|
|
38
|
+
export function isCommandAvailable(name, platform = process.platform) {
|
|
39
|
+
return resolveExecutable(name, { platform }) !== null;
|
|
40
|
+
}
|
|
41
|
+
export function lookupExecutables(name, options) {
|
|
42
|
+
const platform = options?.platform ?? process.platform;
|
|
43
|
+
const lookupBin = commandLookupBinary(platform);
|
|
44
|
+
const cmd = `${lookupBin} ${name}`;
|
|
45
|
+
try {
|
|
46
|
+
return parseLookupLines(execSync(cmd, {
|
|
47
|
+
encoding: 'utf8',
|
|
48
|
+
stdio: ['pipe', 'pipe', 'pipe'],
|
|
49
|
+
shell: true,
|
|
50
|
+
timeout: options?.timeoutMs ?? 3000,
|
|
51
|
+
windowsHide: options?.windowsHide ?? true,
|
|
52
|
+
}));
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
return [];
|
|
56
|
+
}
|
|
57
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Capture current git state for session snapshots.
|
|
3
|
+
* All fields are optional — failures are silently ignored.
|
|
4
|
+
*/
|
|
5
|
+
export declare function getGitState(projectRoot: string): Record<string, unknown>;
|
|
6
|
+
/**
|
|
7
|
+
* Get short git status string for display (e.g., in handoff documents).
|
|
8
|
+
*/
|
|
9
|
+
export declare function getGitStatusShort(projectRoot?: string): string;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { execFileSync } from "node:child_process";
|
|
2
|
+
/**
|
|
3
|
+
* Capture current git state for session snapshots.
|
|
4
|
+
* All fields are optional — failures are silently ignored.
|
|
5
|
+
*/
|
|
6
|
+
export function getGitState(projectRoot) {
|
|
7
|
+
const gitState = {};
|
|
8
|
+
const isWin = process.platform === "win32";
|
|
9
|
+
const opts = {
|
|
10
|
+
cwd: projectRoot,
|
|
11
|
+
timeout: 5000,
|
|
12
|
+
encoding: "utf8",
|
|
13
|
+
stdio: ["pipe", "pipe", "pipe"],
|
|
14
|
+
shell: isWin,
|
|
15
|
+
};
|
|
16
|
+
try {
|
|
17
|
+
const branch = execFileSync("git", ["rev-parse", "--abbrev-ref", "HEAD"], opts);
|
|
18
|
+
if (branch)
|
|
19
|
+
gitState.branch = branch.trim();
|
|
20
|
+
}
|
|
21
|
+
catch { /* non-fatal */ }
|
|
22
|
+
try {
|
|
23
|
+
const status = execFileSync("git", ["status", "--short"], opts);
|
|
24
|
+
if (status) {
|
|
25
|
+
const files = status.trim().split(/\r?\n/)
|
|
26
|
+
.filter(Boolean)
|
|
27
|
+
.slice(0, 10)
|
|
28
|
+
.map(line => line.trimStart().split(/\s+/).slice(1).join(" "));
|
|
29
|
+
if (files.length > 0)
|
|
30
|
+
gitState.uncommitted_files = files;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
catch { /* non-fatal */ }
|
|
34
|
+
try {
|
|
35
|
+
const log = execFileSync("git", ["log", "-1", "--oneline"], opts);
|
|
36
|
+
if (log)
|
|
37
|
+
gitState.last_commit_short = log.trim();
|
|
38
|
+
}
|
|
39
|
+
catch { /* non-fatal */ }
|
|
40
|
+
return gitState;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Get short git status string for display (e.g., in handoff documents).
|
|
44
|
+
*/
|
|
45
|
+
export function getGitStatusShort(projectRoot) {
|
|
46
|
+
try {
|
|
47
|
+
const result = execFileSync("git", ["status", "--short"], {
|
|
48
|
+
encoding: "utf8",
|
|
49
|
+
timeout: 5000,
|
|
50
|
+
stdio: ["pipe", "pipe", "pipe"],
|
|
51
|
+
...(projectRoot ? { cwd: projectRoot } : {}),
|
|
52
|
+
shell: process.platform === "win32",
|
|
53
|
+
});
|
|
54
|
+
return result.trim() || "(no changes)";
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
return "(git status unavailable)";
|
|
58
|
+
}
|
|
59
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Inference utility for AI-powered text processing.
|
|
3
|
+
* Unified interface for Claude API calls using the claude CLI.
|
|
4
|
+
* See SPEC.md §6
|
|
5
|
+
*/
|
|
6
|
+
import type { InferenceResult } from "../types.js";
|
|
7
|
+
/**
|
|
8
|
+
* Run inference using the claude CLI.
|
|
9
|
+
* See SPEC.md §6.1
|
|
10
|
+
*/
|
|
11
|
+
export declare function inference(systemPrompt: string, userPrompt: string, level?: string, timeout?: number, options?: {
|
|
12
|
+
model?: string;
|
|
13
|
+
}): InferenceResult;
|
|
14
|
+
/**
|
|
15
|
+
* Generate a keyword summary of a user prompt.
|
|
16
|
+
* Uses Sonnet (standard tier). Returns null if inference fails.
|
|
17
|
+
* See SPEC.md §6.2
|
|
18
|
+
*/
|
|
19
|
+
export declare function generateSemanticSummary(prompt: string, timeout?: number): string | null;
|
|
20
|
+
/**
|
|
21
|
+
* Generate a 5-12 word context ID slug from a user prompt.
|
|
22
|
+
* Uses Codex Spark first, then falls back to current fast tier for resilience.
|
|
23
|
+
* See SPEC.md §6.3
|
|
24
|
+
*/
|
|
25
|
+
export declare function generateContextIdSlug(prompt: string, timeout?: number): string | null;
|
|
26
|
+
/**
|
|
27
|
+
* Async version of inference() that does NOT block the event loop.
|
|
28
|
+
* Use for parallel AI calls (e.g., Stage 3 parallel summarizers).
|
|
29
|
+
* Uses execFileAsync and getInternalSubprocessEnv for proper subprocess isolation.
|
|
30
|
+
*/
|
|
31
|
+
export declare function inferenceAsync(systemPrompt: string, userPrompt: string, level?: string, timeout?: number, options?: {
|
|
32
|
+
model?: string;
|
|
33
|
+
}): Promise<InferenceResult>;
|
|
34
|
+
export declare function codexInferAsync(prompt: string, model: string, options?: {
|
|
35
|
+
sandbox?: string;
|
|
36
|
+
timeout?: number;
|
|
37
|
+
}): Promise<InferenceResult>;
|