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
|
@@ -1,20 +1,142 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
3
|
-
*
|
|
2
|
+
* Unified Claude CLI output parser.
|
|
3
|
+
* Deduplicates identical logic from orchestrator.py and reviewers/agent.py.
|
|
4
|
+
* See cc-native-plan-review-spec.md §4.6
|
|
4
5
|
*/
|
|
5
6
|
|
|
6
|
-
import {
|
|
7
|
+
import { logDebug, logWarn, logError } from "../../_core/lib-ts/runtime/logger.js";
|
|
8
|
+
import { parseJsonMaybe } from "./json-parser.js";
|
|
7
9
|
|
|
8
10
|
/**
|
|
9
|
-
* Parse CLI JSON output
|
|
10
|
-
*
|
|
11
|
+
* Parse Claude CLI JSON output, handling various formats.
|
|
12
|
+
*
|
|
13
|
+
* Claude CLI can output in several formats:
|
|
14
|
+
* - Direct structured_output dict
|
|
15
|
+
* - Assistant message with StructuredOutput tool use
|
|
16
|
+
* - List of events with assistant messages
|
|
17
|
+
* - Raw text with embedded JSON (heuristic fallback)
|
|
18
|
+
*
|
|
19
|
+
* @param raw - Raw stdout from Claude CLI
|
|
20
|
+
* @param requireFields - Optional fields to validate in heuristic fallback
|
|
21
|
+
* @returns Parsed JSON dict or null if parsing failed
|
|
11
22
|
*/
|
|
12
23
|
export function parseCliOutput(
|
|
13
24
|
raw: string,
|
|
14
25
|
requireFields?: string[],
|
|
15
|
-
):
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
26
|
+
): Record<string, unknown> | null {
|
|
27
|
+
try {
|
|
28
|
+
const result: unknown = JSON.parse(raw);
|
|
29
|
+
|
|
30
|
+
if (result !== null && typeof result === "object" && !Array.isArray(result)) {
|
|
31
|
+
const dict = result as Record<string, unknown>;
|
|
32
|
+
|
|
33
|
+
// Strategy 1: Direct structured_output key
|
|
34
|
+
if ("structured_output" in dict) {
|
|
35
|
+
logDebug("cli_parser", "Found structured_output in root dict");
|
|
36
|
+
return dict.structured_output as Record<string, unknown>;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
// Strategy 1.5: Session result envelope (type: "result")
|
|
40
|
+
// When the model fails to call StructuredOutput, the CLI returns a
|
|
41
|
+
// session metadata object with type/subtype/duration_ms/usage/etc.
|
|
42
|
+
// but no structured_output key. Check for the `result` text field
|
|
43
|
+
// (model may have written review as text) and for error states.
|
|
44
|
+
if (dict.type === "result" || ("duration_ms" in dict && "session_id" in dict)) {
|
|
45
|
+
if (dict.is_error === true || (Array.isArray(dict.errors) && (dict.errors as unknown[]).length > 0)) {
|
|
46
|
+
logWarn("cli_parser", `CLI returned error result: ${JSON.stringify(dict.errors ?? "is_error=true")}`);
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
if (typeof dict.result === "string" && dict.result) {
|
|
50
|
+
logDebug("cli_parser", "Found result text in session envelope, attempting JSON extraction");
|
|
51
|
+
const extracted = parseJsonMaybe(dict.result as string, requireFields);
|
|
52
|
+
if (extracted) return extracted;
|
|
53
|
+
logWarn("cli_parser", "Session envelope result text contained no extractable JSON");
|
|
54
|
+
}
|
|
55
|
+
logDebug("cli_parser", "Session result envelope with no structured_output or extractable result");
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// Strategy 2: Assistant message with StructuredOutput tool use
|
|
60
|
+
if (dict.type === "assistant") {
|
|
61
|
+
const message = dict.message as Record<string, unknown> | undefined;
|
|
62
|
+
const content = message?.content;
|
|
63
|
+
if (Array.isArray(content)) {
|
|
64
|
+
for (const item of content) {
|
|
65
|
+
if (
|
|
66
|
+
item !== null &&
|
|
67
|
+
typeof item === "object" &&
|
|
68
|
+
(item as Record<string, unknown>).name === "StructuredOutput"
|
|
69
|
+
) {
|
|
70
|
+
logDebug(
|
|
71
|
+
"cli_parser",
|
|
72
|
+
"Found StructuredOutput in assistant message content",
|
|
73
|
+
);
|
|
74
|
+
return (item as Record<string, unknown>).input as Record<
|
|
75
|
+
string,
|
|
76
|
+
unknown
|
|
77
|
+
>;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
logDebug(
|
|
82
|
+
"cli_parser",
|
|
83
|
+
"Assistant message found but no StructuredOutput tool use in content",
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
} else if (Array.isArray(result)) {
|
|
87
|
+
// Strategy 3: List of events with assistant messages
|
|
88
|
+
logDebug(
|
|
89
|
+
"cli_parser",
|
|
90
|
+
`Received list of ${(result as unknown[]).length} events, searching for assistant message`,
|
|
91
|
+
);
|
|
92
|
+
for (let i = 0; i < (result as unknown[]).length; i++) {
|
|
93
|
+
const event = (result as unknown[])[i];
|
|
94
|
+
if (event === null || typeof event !== "object") continue;
|
|
95
|
+
|
|
96
|
+
const dict = event as Record<string, unknown>;
|
|
97
|
+
if (dict.type === "assistant") {
|
|
98
|
+
const message = dict.message as Record<string, unknown> | undefined;
|
|
99
|
+
const content = message?.content;
|
|
100
|
+
if (Array.isArray(content)) {
|
|
101
|
+
for (const item of content) {
|
|
102
|
+
if (
|
|
103
|
+
item !== null &&
|
|
104
|
+
typeof item === "object" &&
|
|
105
|
+
(item as Record<string, unknown>).name === "StructuredOutput"
|
|
106
|
+
) {
|
|
107
|
+
logDebug(
|
|
108
|
+
"cli_parser",
|
|
109
|
+
`Found StructuredOutput in event[${i}] assistant message`,
|
|
110
|
+
);
|
|
111
|
+
return (item as Record<string, unknown>).input as Record<
|
|
112
|
+
string,
|
|
113
|
+
unknown
|
|
114
|
+
>;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
logDebug(
|
|
121
|
+
"cli_parser",
|
|
122
|
+
"No StructuredOutput found in any assistant message in event list",
|
|
123
|
+
);
|
|
124
|
+
}
|
|
125
|
+
} catch (e: unknown) {
|
|
126
|
+
if (e instanceof SyntaxError) {
|
|
127
|
+
logWarn("cli_parser", `JSON decode error: ${e.message}`);
|
|
128
|
+
} else {
|
|
129
|
+
logError(
|
|
130
|
+
"cli_parser",
|
|
131
|
+
`Unexpected error during structured parsing: ${e}`,
|
|
132
|
+
);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
// Strategy 4: Heuristic {…} extraction fallback
|
|
137
|
+
logDebug(
|
|
138
|
+
"cli_parser",
|
|
139
|
+
"No structured output found, falling back to heuristic JSON extraction",
|
|
140
|
+
);
|
|
141
|
+
return parseJsonMaybe(raw, requireFields);
|
|
20
142
|
}
|
|
@@ -8,7 +8,7 @@ import * as path from "node:path";
|
|
|
8
8
|
|
|
9
9
|
import type { DisplaySettings, PlanReviewConfig } from "./types.js";
|
|
10
10
|
import { DEFAULT_DISPLAY } from "./types.js";
|
|
11
|
-
import { logWarn } from "../../
|
|
11
|
+
import { logWarn } from "../../_core/lib-ts/runtime/logger.js";
|
|
12
12
|
|
|
13
13
|
/**
|
|
14
14
|
* Load full CC-Native config from _cc-native/cc-native.config.json.
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
* See cc-native-plan-review-spec.md §4.15
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import * as os from "node:os";
|
|
7
6
|
import * as path from "node:path";
|
|
7
|
+
import * as os from "node:os";
|
|
8
8
|
|
|
9
9
|
// ---------------------------------------------------------------------------
|
|
10
10
|
// Feature Flags
|
|
@@ -60,7 +60,7 @@ export function validatePlanPath(planPath: string): string {
|
|
|
60
60
|
);
|
|
61
61
|
}
|
|
62
62
|
|
|
63
|
-
if (planPath.includes("\
|
|
63
|
+
if (planPath.includes("\x00")) {
|
|
64
64
|
throw new Error("Null bytes not allowed in path");
|
|
65
65
|
}
|
|
66
66
|
|
|
@@ -68,13 +68,13 @@ export function validatePlanPath(planPath: string): string {
|
|
|
68
68
|
let resolved: string;
|
|
69
69
|
try {
|
|
70
70
|
resolved = path.resolve(planPath);
|
|
71
|
-
} catch (
|
|
72
|
-
throw new Error(`Path resolution failed: ${
|
|
71
|
+
} catch (e: unknown) {
|
|
72
|
+
throw new Error(`Path resolution failed: ${e}`);
|
|
73
73
|
}
|
|
74
74
|
|
|
75
75
|
// Verify path is within allowed directory (case-insensitive on Windows)
|
|
76
|
-
const resolvedLower = resolved.toLowerCase().
|
|
77
|
-
const plansDirLower = PLANS_DIR.toLowerCase().
|
|
76
|
+
const resolvedLower = resolved.toLowerCase().replace(/\\/g, "/");
|
|
77
|
+
const plansDirLower = PLANS_DIR.toLowerCase().replace(/\\/g, "/");
|
|
78
78
|
if (!resolvedLower.startsWith(plansDirLower)) {
|
|
79
79
|
throw new Error(`Path outside allowed directory: ${PLANS_DIR}`);
|
|
80
80
|
}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Corroboration-based verdict computation for plan review.
|
|
3
|
+
*
|
|
4
|
+
* Replaces the old per-verdict aggregation with proportional thresholding:
|
|
5
|
+
* high-severity issues in a dimension only block when the total count
|
|
6
|
+
* exceeds 2× the number of distinct agents contributing to that dimension.
|
|
7
|
+
*
|
|
8
|
+
* **Why proportional thresholding:**
|
|
9
|
+
* The agent pool has dimensional imbalance (e.g., 10 completeness agents vs
|
|
10
|
+
* 1 maintainability agent). A fixed "2+ agents agree = block" would mean
|
|
11
|
+
* any 2 completeness agents always block. Proportional scaling (issues > 2×agents)
|
|
12
|
+
* sets a fair bar regardless of how many agents focus on each dimension.
|
|
13
|
+
*
|
|
14
|
+
* **Convergence problem this solves:**
|
|
15
|
+
* Agents with opposing philosophies (simplicity-guardian vs completeness-gaps)
|
|
16
|
+
* produce contradictory high-severity issues. Because the old system treated
|
|
17
|
+
* every agent's finding as independently authoritative, plans oscillated —
|
|
18
|
+
* addressing one agent's feedback triggered the opposing agent.
|
|
19
|
+
*
|
|
20
|
+
* **Revert path:** Change one line in cc-native-plan-review.ts back to
|
|
21
|
+
* `computeReviewDecision(allVerdicts)`. Old function kept in verdict.ts.
|
|
22
|
+
*/
|
|
23
|
+
|
|
24
|
+
import type {
|
|
25
|
+
ReviewerResult,
|
|
26
|
+
ReviewIssue,
|
|
27
|
+
IssueDimension,
|
|
28
|
+
CorroborationResult,
|
|
29
|
+
CorroboratedGroup,
|
|
30
|
+
SoloFinding,
|
|
31
|
+
} from "./types.js";
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Compute a corroboration-based review decision from all reviewer results.
|
|
35
|
+
*
|
|
36
|
+
* Algorithm:
|
|
37
|
+
* 1. Collect all high-severity issues with a `dimension` field
|
|
38
|
+
* 2. Group by dimension, tracking distinct agent names per group
|
|
39
|
+
* 3. For each dimension: block if `issues.length > 2 × agentCount`
|
|
40
|
+
* 4. Issues without `dimension` are unclassified (never block)
|
|
41
|
+
* 5. Non-high issues are ignored (informational only)
|
|
42
|
+
*
|
|
43
|
+
* @param allResults - Map of reviewer name → ReviewerResult (CLI + agent)
|
|
44
|
+
* @returns CorroborationResult with blocking groups, solo findings, and verdict
|
|
45
|
+
*/
|
|
46
|
+
export function computeCorroboratedDecision(
|
|
47
|
+
allResults: Record<string, ReviewerResult>,
|
|
48
|
+
): CorroborationResult {
|
|
49
|
+
// Accumulator: dimension → { issues, agentNames }
|
|
50
|
+
const dimMap = new Map<
|
|
51
|
+
IssueDimension,
|
|
52
|
+
{
|
|
53
|
+
issues: Array<{ agent: string; issue: ReviewIssue }>;
|
|
54
|
+
agentNames: Set<string>;
|
|
55
|
+
}
|
|
56
|
+
>();
|
|
57
|
+
|
|
58
|
+
const unclassified: Array<{ agent: string; issue: ReviewIssue }> = [];
|
|
59
|
+
|
|
60
|
+
for (const [agentName, result] of Object.entries(allResults)) {
|
|
61
|
+
if (!result.data) continue;
|
|
62
|
+
const issues = result.data.issues as ReviewIssue[] | undefined;
|
|
63
|
+
if (!Array.isArray(issues)) continue;
|
|
64
|
+
|
|
65
|
+
for (const issue of issues) {
|
|
66
|
+
// Only high-severity issues participate in corroboration
|
|
67
|
+
if (issue.severity !== "high") continue;
|
|
68
|
+
|
|
69
|
+
// Issues without dimension are unclassified — cannot block
|
|
70
|
+
if (!issue.dimension) {
|
|
71
|
+
unclassified.push({ agent: agentName, issue });
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
let group = dimMap.get(issue.dimension);
|
|
76
|
+
if (!group) {
|
|
77
|
+
group = { issues: [], agentNames: new Set() };
|
|
78
|
+
dimMap.set(issue.dimension, group);
|
|
79
|
+
}
|
|
80
|
+
group.issues.push({ agent: agentName, issue });
|
|
81
|
+
group.agentNames.add(agentName);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
const blocking: CorroboratedGroup[] = [];
|
|
86
|
+
const solo: SoloFinding[] = [];
|
|
87
|
+
|
|
88
|
+
for (const [dimension, group] of dimMap) {
|
|
89
|
+
const agentCount = group.agentNames.size;
|
|
90
|
+
const threshold = 2 * agentCount;
|
|
91
|
+
|
|
92
|
+
if (group.issues.length >= threshold) {
|
|
93
|
+
blocking.push({
|
|
94
|
+
dimension,
|
|
95
|
+
issues: group.issues,
|
|
96
|
+
agentCount,
|
|
97
|
+
threshold,
|
|
98
|
+
});
|
|
99
|
+
} else {
|
|
100
|
+
solo.push({
|
|
101
|
+
dimension,
|
|
102
|
+
issues: group.issues,
|
|
103
|
+
agentCount,
|
|
104
|
+
threshold,
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
return {
|
|
110
|
+
blocking,
|
|
111
|
+
solo,
|
|
112
|
+
unclassified,
|
|
113
|
+
verdict: blocking.length > 0
|
|
114
|
+
? "fail"
|
|
115
|
+
: solo.length > 0
|
|
116
|
+
? "warn"
|
|
117
|
+
: "pass",
|
|
118
|
+
};
|
|
119
|
+
}
|
|
@@ -8,8 +8,7 @@
|
|
|
8
8
|
|
|
9
9
|
import * as fs from "node:fs";
|
|
10
10
|
import * as path from "node:path";
|
|
11
|
-
|
|
12
|
-
import { hookLog } from "../../_shared/lib-ts/base/logger.js";
|
|
11
|
+
import { hookLog } from "../../_core/lib-ts/runtime/logger.js";
|
|
13
12
|
|
|
14
13
|
/** Feature flag — set CCNATIVE_DEBUG_DISABLE=1 to turn off */
|
|
15
14
|
const DEBUG_ENABLED = !["1", "true", "yes"].includes(
|
|
@@ -52,7 +51,7 @@ export function debugRaw(
|
|
|
52
51
|
component: string,
|
|
53
52
|
label: string,
|
|
54
53
|
raw: string,
|
|
55
|
-
maxLen =
|
|
54
|
+
maxLen = 10000,
|
|
56
55
|
): void {
|
|
57
56
|
if (!DEBUG_ENABLED) return;
|
|
58
57
|
|
|
@@ -1,132 +1,132 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Graduation logic: pass eligibility, pass streaks, graduation threshold, iteration advancement.
|
|
3
|
-
* Extracted from cc-native-plan-review.ts.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import type {
|
|
7
|
-
IterationState,
|
|
8
|
-
ReviewerResult,
|
|
9
|
-
CombinedReviewResult,
|
|
10
|
-
IterationAdvancement,
|
|
11
|
-
} from "
|
|
12
|
-
|
|
13
|
-
// ---------------------------------------------------------------------------
|
|
14
|
-
// Pass Eligibility
|
|
15
|
-
// ---------------------------------------------------------------------------
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Determine which agents are pass-eligible this iteration.
|
|
19
|
-
* Criteria: verdict === "pass" OR zero high-severity issues.
|
|
20
|
-
* Agents with "skip"/"error" are NOT eligible (no signal).
|
|
21
|
-
*/
|
|
22
|
-
export function computePassEligible(agentResults: Record<string, ReviewerResult>): string[] {
|
|
23
|
-
const eligible: string[] = [];
|
|
24
|
-
for (const [name, result] of Object.entries(agentResults)) {
|
|
25
|
-
if (result.verdict === "skip" || result.verdict === "error") continue;
|
|
26
|
-
if (result.verdict === "pass") { eligible.push(name); continue; }
|
|
27
|
-
const issues = Array.isArray(result.data?.issues)
|
|
28
|
-
? (result.data.issues as Array<{ severity?: string }>) : [];
|
|
29
|
-
if (issues.filter(i => i.severity === "high").length === 0) {
|
|
30
|
-
eligible.push(name);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return eligible;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// ---------------------------------------------------------------------------
|
|
37
|
-
// Tracker Issue Extraction
|
|
38
|
-
// ---------------------------------------------------------------------------
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Extract top high-severity issues for the review tracker.
|
|
42
|
-
*/
|
|
43
|
-
export function extractTopIssuesForTracker(
|
|
44
|
-
combined: CombinedReviewResult,
|
|
45
|
-
maxCount = 5,
|
|
46
|
-
): string[] {
|
|
47
|
-
const allReviewers = Object.values(combined.agents);
|
|
48
|
-
const issues: string[] = [];
|
|
49
|
-
for (const r of allReviewers) {
|
|
50
|
-
if (!r.data) continue;
|
|
51
|
-
const issueList = r.data.issues as Array<Record<string, unknown>> | undefined;
|
|
52
|
-
if (!issueList) continue;
|
|
53
|
-
for (const issue of issueList) {
|
|
54
|
-
if (issue.severity === "high") {
|
|
55
|
-
const text = String(issue.issue ?? "").trim();
|
|
56
|
-
if (text) {
|
|
57
|
-
issues.push(`[${r.name}] ${text}`);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
if (issues.length >= maxCount) break;
|
|
62
|
-
}
|
|
63
|
-
return issues.slice(0, maxCount);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// ---------------------------------------------------------------------------
|
|
67
|
-
// Iteration Advancement
|
|
68
|
-
// ---------------------------------------------------------------------------
|
|
69
|
-
|
|
70
|
-
const GRADUATION_THRESHOLD = 2;
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* Advance iteration state after a review cycle. Returns a new state copy
|
|
74
|
-
* (does not mutate input).
|
|
75
|
-
*
|
|
76
|
-
* - On pass/warrant: sets current past max (stop iterating)
|
|
77
|
-
* - On deny: increments current toward max (safety valve)
|
|
78
|
-
* - Updates pass streaks and graduates agents that reached threshold
|
|
79
|
-
*/
|
|
80
|
-
export function advanceIterationState(
|
|
81
|
-
state: IterationState,
|
|
82
|
-
planHash: string,
|
|
83
|
-
planPath: string,
|
|
84
|
-
verdict: string,
|
|
85
|
-
shouldDeny: boolean,
|
|
86
|
-
passEligible: string[],
|
|
87
|
-
agentResults: Record<string, ReviewerResult>,
|
|
88
|
-
graduationThreshold = GRADUATION_THRESHOLD,
|
|
89
|
-
): IterationAdvancement {
|
|
90
|
-
const updated: IterationState = {
|
|
91
|
-
...state,
|
|
92
|
-
history: [...state.history, { hash: planHash, verdict, timestamp: new Date().toISOString() }],
|
|
93
|
-
lastPlanHash: planHash,
|
|
94
|
-
lastPlanPath: planPath,
|
|
95
|
-
graduated: [...state.graduated],
|
|
96
|
-
passStreaks: { ...state.passStreaks },
|
|
97
|
-
};
|
|
98
|
-
|
|
99
|
-
if (!shouldDeny) {
|
|
100
|
-
// Pass/warrant: stop iterating
|
|
101
|
-
updated.current = updated.max + 1;
|
|
102
|
-
} else {
|
|
103
|
-
// Deny: advance toward max
|
|
104
|
-
updated.current = state.current + 1;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Update pass streaks — only for agents that actually ran this iteration
|
|
108
|
-
const passEligibleSet = new Set(passEligible);
|
|
109
|
-
const graduatedSet = new Set(updated.graduated);
|
|
110
|
-
|
|
111
|
-
for (const name of Object.keys(agentResults)) {
|
|
112
|
-
if (graduatedSet.has(name)) continue;
|
|
113
|
-
if (passEligibleSet.has(name)) {
|
|
114
|
-
updated.passStreaks[name] = (updated.passStreaks[name] ?? 0) + 1;
|
|
115
|
-
} else {
|
|
116
|
-
updated.passStreaks[name] = 0;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
// Graduate agents that reached threshold
|
|
121
|
-
const newGraduates: string[] = [];
|
|
122
|
-
for (const [name, streak] of Object.entries(updated.passStreaks)) {
|
|
123
|
-
if (streak >= graduationThreshold && !graduatedSet.has(name)) {
|
|
124
|
-
newGraduates.push(name);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
if (newGraduates.length > 0) {
|
|
128
|
-
updated.graduated = [...updated.graduated, ...newGraduates];
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
return { updatedState: updated, newGraduates };
|
|
132
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Graduation logic: pass eligibility, pass streaks, graduation threshold, iteration advancement.
|
|
3
|
+
* Extracted from cc-native-plan-review.ts.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import type {
|
|
7
|
+
IterationState,
|
|
8
|
+
ReviewerResult,
|
|
9
|
+
CombinedReviewResult,
|
|
10
|
+
IterationAdvancement,
|
|
11
|
+
} from "./types.js";
|
|
12
|
+
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
14
|
+
// Pass Eligibility
|
|
15
|
+
// ---------------------------------------------------------------------------
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Determine which agents are pass-eligible this iteration.
|
|
19
|
+
* Criteria: verdict === "pass" OR zero high-severity issues.
|
|
20
|
+
* Agents with "skip"/"error" are NOT eligible (no signal).
|
|
21
|
+
*/
|
|
22
|
+
export function computePassEligible(agentResults: Record<string, ReviewerResult>): string[] {
|
|
23
|
+
const eligible: string[] = [];
|
|
24
|
+
for (const [name, result] of Object.entries(agentResults)) {
|
|
25
|
+
if (result.verdict === "skip" || result.verdict === "error") continue;
|
|
26
|
+
if (result.verdict === "pass") { eligible.push(name); continue; }
|
|
27
|
+
const issues = Array.isArray(result.data?.issues)
|
|
28
|
+
? (result.data.issues as Array<{ severity?: string }>) : [];
|
|
29
|
+
if (issues.filter(i => i.severity === "high").length === 0) {
|
|
30
|
+
eligible.push(name);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return eligible;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// ---------------------------------------------------------------------------
|
|
37
|
+
// Tracker Issue Extraction
|
|
38
|
+
// ---------------------------------------------------------------------------
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Extract top high-severity issues for the review tracker.
|
|
42
|
+
*/
|
|
43
|
+
export function extractTopIssuesForTracker(
|
|
44
|
+
combined: CombinedReviewResult,
|
|
45
|
+
maxCount = 5,
|
|
46
|
+
): string[] {
|
|
47
|
+
const allReviewers = Object.values(combined.agents);
|
|
48
|
+
const issues: string[] = [];
|
|
49
|
+
for (const r of allReviewers) {
|
|
50
|
+
if (!r.data) continue;
|
|
51
|
+
const issueList = r.data.issues as Array<Record<string, unknown>> | undefined;
|
|
52
|
+
if (!issueList) continue;
|
|
53
|
+
for (const issue of issueList) {
|
|
54
|
+
if (issue.severity === "high") {
|
|
55
|
+
const text = String(issue.issue ?? "").trim();
|
|
56
|
+
if (text) {
|
|
57
|
+
issues.push(`[${r.name}] ${text}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
if (issues.length >= maxCount) break;
|
|
62
|
+
}
|
|
63
|
+
return issues.slice(0, maxCount);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// ---------------------------------------------------------------------------
|
|
67
|
+
// Iteration Advancement
|
|
68
|
+
// ---------------------------------------------------------------------------
|
|
69
|
+
|
|
70
|
+
const GRADUATION_THRESHOLD = 2;
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Advance iteration state after a review cycle. Returns a new state copy
|
|
74
|
+
* (does not mutate input).
|
|
75
|
+
*
|
|
76
|
+
* - On pass/warrant: sets current past max (stop iterating)
|
|
77
|
+
* - On deny: increments current toward max (safety valve)
|
|
78
|
+
* - Updates pass streaks and graduates agents that reached threshold
|
|
79
|
+
*/
|
|
80
|
+
export function advanceIterationState(
|
|
81
|
+
state: IterationState,
|
|
82
|
+
planHash: string,
|
|
83
|
+
planPath: string,
|
|
84
|
+
verdict: string,
|
|
85
|
+
shouldDeny: boolean,
|
|
86
|
+
passEligible: string[],
|
|
87
|
+
agentResults: Record<string, ReviewerResult>,
|
|
88
|
+
graduationThreshold = GRADUATION_THRESHOLD,
|
|
89
|
+
): IterationAdvancement {
|
|
90
|
+
const updated: IterationState = {
|
|
91
|
+
...state,
|
|
92
|
+
history: [...state.history, { hash: planHash, verdict, timestamp: new Date().toISOString() }],
|
|
93
|
+
lastPlanHash: planHash,
|
|
94
|
+
lastPlanPath: planPath,
|
|
95
|
+
graduated: [...state.graduated],
|
|
96
|
+
passStreaks: { ...(state.passStreaks ?? {}) },
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
if (!shouldDeny) {
|
|
100
|
+
// Pass/warrant: stop iterating
|
|
101
|
+
updated.current = updated.max + 1;
|
|
102
|
+
} else {
|
|
103
|
+
// Deny: advance toward max
|
|
104
|
+
updated.current = state.current + 1;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// Update pass streaks — only for agents that actually ran this iteration
|
|
108
|
+
const passEligibleSet = new Set(passEligible);
|
|
109
|
+
const graduatedSet = new Set(updated.graduated);
|
|
110
|
+
|
|
111
|
+
for (const name of Object.keys(agentResults)) {
|
|
112
|
+
if (graduatedSet.has(name)) continue;
|
|
113
|
+
if (passEligibleSet.has(name)) {
|
|
114
|
+
updated.passStreaks[name] = (updated.passStreaks[name] ?? 0) + 1;
|
|
115
|
+
} else {
|
|
116
|
+
updated.passStreaks[name] = 0;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
// Graduate agents that reached threshold
|
|
121
|
+
const newGraduates: string[] = [];
|
|
122
|
+
for (const [name, streak] of Object.entries(updated.passStreaks)) {
|
|
123
|
+
if (streak >= graduationThreshold && !graduatedSet.has(name)) {
|
|
124
|
+
newGraduates.push(name);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
if (newGraduates.length > 0) {
|
|
128
|
+
updated.graduated = [...updated.graduated, ...newGraduates];
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
return { updatedState: updated, newGraduates };
|
|
132
|
+
}
|