muonroi-cli 1.3.4 → 1.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/README.md +122 -122
- package/dist/packages/agent-harness-core/src/predicate.d.ts +2 -2
- package/dist/packages/agent-harness-core/src/protocol.d.ts +8 -0
- package/dist/src/__test-helpers__/catalog-fixtures.d.ts +22 -0
- package/dist/src/__test-helpers__/catalog-fixtures.js +55 -0
- package/dist/src/agent-harness/index.js +1 -1
- package/dist/src/agent-harness/mock-model.d.ts +5 -0
- package/dist/src/agent-harness/mock-model.js +68 -23
- package/dist/src/agent-harness/test-spawn.d.ts +7 -1
- package/dist/src/agent-harness/test-spawn.js +19 -4
- package/dist/src/chat/__tests__/broadcast-bus.test.js +2 -2
- package/dist/src/chat/__tests__/client.test.js +1 -1
- package/dist/src/chat/broadcast-bus.js +2 -2
- package/dist/src/chat/chat-keychain.js +11 -2
- package/dist/src/chat/providers/discord/client.d.ts +1 -1
- package/dist/src/chat/providers/discord/client.js +1 -1
- package/dist/src/cli/config/screen-council.js +1 -1
- package/dist/src/cli/config/screen-models.js +2 -2
- package/dist/src/cli/config/screen-providers.js +2 -2
- package/dist/src/cli/config/tui.js +1 -1
- package/dist/src/cli/cost-forensics.d.ts +31 -0
- package/dist/src/cli/cost-forensics.js +58 -12
- package/dist/src/cli/cost-forensics.test.js +125 -2
- package/dist/src/cli/keys.d.ts +5 -1
- package/dist/src/cli/keys.js +48 -20
- package/dist/src/cli/keys.test.js +1 -1
- package/dist/src/cli/reporter-cmd.d.ts +15 -0
- package/dist/src/cli/reporter-cmd.js +120 -0
- package/dist/src/cli/usage-report.d.ts +38 -1
- package/dist/src/cli/usage-report.js +133 -0
- package/dist/src/council/__tests__/audit-replay.test.js +1 -1
- package/dist/src/council/__tests__/clarifier-max-rounds.test.js +5 -5
- package/dist/src/council/__tests__/clarifier-ready-gate.test.js +233 -0
- package/dist/src/council/__tests__/debate-planner-structured.test.js +2 -2
- package/dist/src/council/__tests__/decisions-lock.test.d.ts +6 -0
- package/dist/src/council/__tests__/decisions-lock.test.js +336 -0
- package/dist/src/council/__tests__/tool-trace.test.js +2 -2
- package/dist/src/council/clarifier.d.ts +19 -2
- package/dist/src/council/clarifier.js +84 -6
- package/dist/src/council/context.js +3 -3
- package/dist/src/council/debate-planner.d.ts +1 -1
- package/dist/src/council/debate-planner.js +40 -7
- package/dist/src/council/debate.js +1 -1
- package/dist/src/council/decisions-lock.d.ts +76 -0
- package/dist/src/council/decisions-lock.js +239 -0
- package/dist/src/council/index.d.ts +5 -0
- package/dist/src/council/index.js +50 -18
- package/dist/src/council/leader.d.ts +1 -1
- package/dist/src/council/leader.js +14 -1
- package/dist/src/council/llm.js +33 -61
- package/dist/src/council/phase-events.d.ts +5 -0
- package/dist/src/council/phase-events.js +1 -0
- package/dist/src/council/planner.js +1 -1
- package/dist/src/council/prompts.d.ts +24 -0
- package/dist/src/council/prompts.js +112 -22
- package/dist/src/council/types.d.ts +18 -0
- package/dist/src/ee/__tests__/export-transcripts.test.d.ts +11 -0
- package/dist/src/ee/__tests__/export-transcripts.test.js +200 -0
- package/dist/src/ee/__tests__/recall-format.test.d.ts +10 -0
- package/dist/src/ee/__tests__/recall-format.test.js +57 -0
- package/dist/src/ee/__tests__/recall-ledger.test.d.ts +1 -0
- package/dist/src/ee/__tests__/recall-ledger.test.js +45 -0
- package/dist/src/ee/auth.test.js +2 -2
- package/dist/src/ee/client.js +59 -0
- package/dist/src/ee/client.test.js +30 -0
- package/dist/src/ee/council-bridge.js +3 -3
- package/dist/src/ee/export-transcripts.d.ts +26 -0
- package/dist/src/ee/export-transcripts.js +115 -0
- package/dist/src/ee/intercept.d.ts +9 -0
- package/dist/src/ee/intercept.js +19 -0
- package/dist/src/ee/offline-queue.test.js +3 -3
- package/dist/src/ee/phase-tracker.js +1 -1
- package/dist/src/ee/recall-ledger.d.ts +32 -0
- package/dist/src/ee/recall-ledger.js +52 -0
- package/dist/src/ee/recall-mirror.test.d.ts +1 -0
- package/dist/src/ee/recall-mirror.test.js +65 -0
- package/dist/src/ee/scope.js +1 -1
- package/dist/src/ee/scope.test.js +1 -1
- package/dist/src/ee/search.d.ts +99 -0
- package/dist/src/ee/search.js +220 -0
- package/dist/src/ee/session-trajectory.js +1 -1
- package/dist/src/ee/session-trajectory.test.js +1 -1
- package/dist/src/ee/transcript-emit.d.ts +51 -0
- package/dist/src/ee/transcript-emit.js +140 -0
- package/dist/src/ee/types.d.ts +37 -1
- package/dist/src/flow/__tests__/migration.test.js +1 -1
- package/dist/src/flow/__tests__/run-manager-product.test.js +1 -1
- package/dist/src/flow/__tests__/run-manager.test.js +1 -1
- package/dist/src/flow/__tests__/scaffold-checkpoint.test.js +2 -2
- package/dist/src/flow/__tests__/scaffold.test.js +1 -1
- package/dist/src/flow/__tests__/warning-persist.test.js +1 -1
- package/dist/src/generated/version.d.ts +1 -1
- package/dist/src/generated/version.js +1 -1
- package/dist/src/gsd/__tests__/directives.test.js +35 -0
- package/dist/src/gsd/__tests__/types.test.js +14 -1
- package/dist/src/gsd/directives.d.ts +10 -0
- package/dist/src/gsd/directives.js +38 -2
- package/dist/src/gsd/gray-areas.js +1 -1
- package/dist/src/gsd/types.d.ts +1 -1
- package/dist/src/gsd/types.js +20 -6
- package/dist/src/headless/__tests__/council-answers.test.js +26 -1
- package/dist/src/headless/council-answers.d.ts +17 -2
- package/dist/src/headless/council-answers.js +21 -0
- package/dist/src/hooks/index.js +74 -49
- package/dist/src/index.js +180 -16
- package/dist/src/lsp/builtins.js +44 -0
- package/dist/src/lsp/builtins.test.js +22 -1
- package/dist/src/lsp/manager.js +40 -9
- package/dist/src/lsp/manager.test.js +23 -1
- package/dist/src/lsp/npm-cache.js +2 -1
- package/dist/src/lsp/npm-cache.test.js +1 -1
- package/dist/src/lsp/smoke.test.js +1 -1
- package/dist/src/lsp/types.d.ts +3 -1
- package/dist/src/maintain/__tests__/codebase-intel.test.d.ts +5 -0
- package/dist/src/maintain/__tests__/codebase-intel.test.js +237 -0
- package/dist/src/maintain/__tests__/gh-create-pr.test.d.ts +11 -0
- package/dist/src/maintain/__tests__/gh-create-pr.test.js +156 -0
- package/dist/src/maintain/__tests__/pr-builder.test.d.ts +10 -0
- package/dist/src/maintain/__tests__/pr-builder.test.js +225 -0
- package/dist/src/maintain/__tests__/repo-map.test.d.ts +5 -0
- package/dist/src/maintain/__tests__/repo-map.test.js +90 -0
- package/dist/src/maintain/__tests__/task-runner.test.d.ts +11 -0
- package/dist/src/maintain/__tests__/task-runner.test.js +281 -0
- package/dist/src/maintain/codebase-intel.d.ts +22 -0
- package/dist/src/maintain/codebase-intel.js +548 -0
- package/dist/src/maintain/gh-create-pr.d.ts +24 -0
- package/dist/src/maintain/gh-create-pr.js +111 -0
- package/dist/src/maintain/index.d.ts +12 -0
- package/dist/src/maintain/index.js +10 -0
- package/dist/src/maintain/pr-builder.d.ts +35 -0
- package/dist/src/maintain/pr-builder.js +305 -0
- package/dist/src/maintain/repo-map.d.ts +25 -0
- package/dist/src/maintain/repo-map.js +189 -0
- package/dist/src/maintain/task-runner.d.ts +45 -0
- package/dist/src/maintain/task-runner.js +401 -0
- package/dist/src/maintain/types.d.ts +45 -0
- package/dist/src/maintain/types.js +7 -0
- package/dist/src/mcp/__tests__/auto-setup.test.js +1 -1
- package/dist/src/mcp/__tests__/cap-tool-result.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/cap-tool-result.test.js +58 -0
- package/dist/src/mcp/__tests__/ee-tools.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/ee-tools.test.js +198 -0
- package/dist/src/mcp/__tests__/forensics-tools.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/forensics-tools.test.js +53 -0
- package/dist/src/mcp/__tests__/harness-driver-action-tools.spec.js +3 -1
- package/dist/src/mcp/__tests__/harness-driver-async-tools.spec.js +3 -1
- package/dist/src/mcp/__tests__/lsp-tools.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/lsp-tools.test.js +56 -0
- package/dist/src/mcp/__tests__/runtime-output-cap.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/runtime-output-cap.test.js +42 -0
- package/dist/src/mcp/__tests__/self-verify-jobs.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/self-verify-jobs.test.js +92 -0
- package/dist/src/mcp/__tests__/smart-filter.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/smart-filter.test.js +121 -0
- package/dist/src/mcp/__tests__/tools-server.smoke.test.d.ts +1 -0
- package/dist/src/mcp/__tests__/tools-server.smoke.test.js +42 -0
- package/dist/src/mcp/cap-tool-result.d.ts +1 -0
- package/dist/src/mcp/cap-tool-result.js +35 -0
- package/dist/src/mcp/ee-tools.d.ts +36 -0
- package/dist/src/mcp/ee-tools.js +159 -0
- package/dist/src/mcp/forensics-tools.d.ts +13 -0
- package/dist/src/mcp/forensics-tools.js +52 -0
- package/dist/src/mcp/lsp-tools.d.ts +16 -0
- package/dist/src/mcp/lsp-tools.js +65 -0
- package/dist/src/mcp/mcp-keychain.js +11 -2
- package/dist/src/mcp/oauth-callback.js +2 -2
- package/dist/src/mcp/opentui-spawn.js +1 -1
- package/dist/src/mcp/parse-headers.test.js +14 -14
- package/dist/src/mcp/runtime.js +11 -0
- package/dist/src/mcp/self-verify-jobs.d.ts +55 -0
- package/dist/src/mcp/self-verify-jobs.js +86 -0
- package/dist/src/mcp/smart-filter.d.ts +48 -0
- package/dist/src/mcp/smart-filter.js +115 -0
- package/dist/src/mcp/smoke.test.js +44 -44
- package/dist/src/mcp/tools-server.d.ts +14 -0
- package/dist/src/mcp/tools-server.js +147 -0
- package/dist/src/models/catalog-client.d.ts +22 -0
- package/dist/src/models/catalog-client.js +95 -9
- package/dist/src/models/catalog-gemini.test.d.ts +1 -0
- package/dist/src/models/catalog-gemini.test.js +46 -0
- package/dist/src/models/catalog-url.test.d.ts +1 -0
- package/dist/src/models/catalog-url.test.js +26 -0
- package/dist/src/models/catalog-validation.test.d.ts +1 -0
- package/dist/src/models/catalog-validation.test.js +63 -0
- package/dist/src/models/catalog.json +349 -177
- package/dist/src/models/classify-tier.d.ts +1 -1
- package/dist/src/models/classify-tier.js +1 -1
- package/dist/src/models/registry.d.ts +2 -0
- package/dist/src/models/registry.js +9 -0
- package/dist/src/ops/__tests__/doctor-ee-health.test.js +1 -1
- package/dist/src/ops/doctor.js +7 -7
- package/dist/src/orchestrator/__tests__/agent-base-url-switch.test.d.ts +1 -0
- package/dist/src/orchestrator/__tests__/agent-base-url-switch.test.js +77 -0
- package/dist/src/orchestrator/__tests__/batch-turn-runner.test.js +10 -3
- package/dist/src/orchestrator/__tests__/cross-turn-dedup.test.js +38 -16
- package/dist/src/orchestrator/__tests__/error-forensics.test.d.ts +1 -0
- package/dist/src/orchestrator/__tests__/error-forensics.test.js +93 -0
- package/dist/src/orchestrator/__tests__/flow-resume.test.js +1 -1
- package/dist/src/orchestrator/__tests__/humanize-api-error.test.d.ts +1 -0
- package/dist/src/orchestrator/__tests__/humanize-api-error.test.js +68 -0
- package/dist/src/orchestrator/__tests__/message-processor.test.js +6 -1
- package/dist/src/orchestrator/__tests__/read-path-budget.test.js +62 -4
- package/dist/src/orchestrator/__tests__/retry-classifier.test.js +10 -0
- package/dist/src/orchestrator/__tests__/stream-runner.test.js +77 -4
- package/dist/src/orchestrator/__tests__/sub-agent-model-tier.test.d.ts +1 -0
- package/dist/src/orchestrator/__tests__/sub-agent-model-tier.test.js +45 -0
- package/dist/src/orchestrator/__tests__/usage-shape-threading.test.d.ts +1 -0
- package/dist/src/orchestrator/__tests__/usage-shape-threading.test.js +98 -0
- package/dist/src/orchestrator/agent.test.js +33 -18
- package/dist/src/orchestrator/batch-turn-runner.d.ts +1 -1
- package/dist/src/orchestrator/batch-turn-runner.js +3 -2
- package/dist/src/orchestrator/compaction.js +99 -87
- package/dist/src/orchestrator/compaction.test.js +17 -0
- package/dist/src/orchestrator/council-manager.d.ts +1 -1
- package/dist/src/orchestrator/council-manager.js +3 -10
- package/dist/src/orchestrator/cross-turn-dedup.js +21 -1
- package/dist/src/orchestrator/delegations.js +7 -1
- package/dist/src/orchestrator/delegations.test.js +1 -1
- package/dist/src/orchestrator/error-utils.d.ts +27 -1
- package/dist/src/orchestrator/error-utils.js +63 -1
- package/dist/src/orchestrator/grounding-check.d.ts +50 -0
- package/dist/src/orchestrator/grounding-check.js +123 -0
- package/dist/src/orchestrator/grounding-check.test.d.ts +1 -0
- package/dist/src/orchestrator/grounding-check.test.js +94 -0
- package/dist/src/orchestrator/interrupted-turn.d.ts +19 -0
- package/dist/src/orchestrator/interrupted-turn.js +28 -0
- package/dist/src/orchestrator/interrupted-turn.test.d.ts +1 -0
- package/dist/src/orchestrator/interrupted-turn.test.js +34 -0
- package/dist/src/orchestrator/message-processor.d.ts +11 -10
- package/dist/src/orchestrator/message-processor.js +1367 -93
- package/dist/src/orchestrator/orchestrator.d.ts +7 -3
- package/dist/src/orchestrator/orchestrator.js +158 -43
- package/dist/src/orchestrator/pending-calls.test.js +1 -1
- package/dist/src/orchestrator/prompts.d.ts +1 -1
- package/dist/src/orchestrator/prompts.js +237 -154
- package/dist/src/orchestrator/read-path-budget.d.ts +22 -2
- package/dist/src/orchestrator/read-path-budget.js +96 -18
- package/dist/src/orchestrator/reasoning.js +43 -1
- package/dist/src/orchestrator/reasoning.test.js +75 -0
- package/dist/src/orchestrator/repair-tool-call.d.ts +32 -0
- package/dist/src/orchestrator/repair-tool-call.js +50 -0
- package/dist/src/orchestrator/repetition-detector.d.ts +58 -0
- package/dist/src/orchestrator/repetition-detector.js +126 -0
- package/dist/src/orchestrator/repetition-detector.test.d.ts +1 -0
- package/dist/src/orchestrator/repetition-detector.test.js +103 -0
- package/dist/src/orchestrator/retry-classifier.js +8 -0
- package/dist/src/orchestrator/sandbox.test.js +3 -1
- package/dist/src/orchestrator/scope-ceiling.d.ts +86 -0
- package/dist/src/orchestrator/scope-ceiling.js +161 -0
- package/dist/src/orchestrator/scope-ceiling.test.d.ts +13 -0
- package/dist/src/orchestrator/scope-ceiling.test.js +181 -0
- package/dist/src/orchestrator/scope-reminder.d.ts +102 -0
- package/dist/src/orchestrator/scope-reminder.js +221 -0
- package/dist/src/orchestrator/scope-reminder.test.d.ts +15 -0
- package/dist/src/orchestrator/scope-reminder.test.js +204 -0
- package/dist/src/orchestrator/stall-rescue.d.ts +67 -0
- package/dist/src/orchestrator/stall-rescue.js +72 -0
- package/dist/src/orchestrator/stall-rescue.test.d.ts +1 -0
- package/dist/src/orchestrator/stall-rescue.test.js +88 -0
- package/dist/src/orchestrator/stall-watchdog.d.ts +34 -0
- package/dist/src/orchestrator/stall-watchdog.js +72 -0
- package/dist/src/orchestrator/stall-watchdog.test.d.ts +1 -0
- package/dist/src/orchestrator/stall-watchdog.test.js +73 -0
- package/dist/src/orchestrator/stream-runner.d.ts +18 -2
- package/dist/src/orchestrator/stream-runner.js +248 -77
- package/dist/src/orchestrator/sub-agent-cap.js +21 -1
- package/dist/src/orchestrator/sub-agent-cap.test.js +41 -3
- package/dist/src/orchestrator/sub-agent-model-tier.d.ts +13 -0
- package/dist/src/orchestrator/sub-agent-model-tier.js +45 -0
- package/dist/src/orchestrator/subagent-compactor.d.ts +49 -0
- package/dist/src/orchestrator/subagent-compactor.js +184 -11
- package/dist/src/orchestrator/subagent-compactor.spec.js +187 -2
- package/dist/src/orchestrator/text-tool-call-detector.d.ts +61 -0
- package/dist/src/orchestrator/text-tool-call-detector.js +163 -0
- package/dist/src/orchestrator/text-tool-call-detector.test.d.ts +1 -0
- package/dist/src/orchestrator/text-tool-call-detector.test.js +89 -0
- package/dist/src/orchestrator/tool-args-hash.d.ts +51 -0
- package/dist/src/orchestrator/tool-args-hash.js +219 -0
- package/dist/src/orchestrator/tool-args-hash.test.d.ts +1 -0
- package/dist/src/orchestrator/tool-args-hash.test.js +105 -0
- package/dist/src/orchestrator/tool-args-repair.d.ts +93 -0
- package/dist/src/orchestrator/tool-args-repair.js +219 -0
- package/dist/src/orchestrator/tool-args-repair.test.d.ts +1 -0
- package/dist/src/orchestrator/tool-args-repair.test.js +136 -0
- package/dist/src/orchestrator/tool-loop-cap.d.ts +66 -0
- package/dist/src/orchestrator/tool-loop-cap.js +138 -0
- package/dist/src/orchestrator/tool-loop-cap.test.d.ts +1 -0
- package/dist/src/orchestrator/tool-loop-cap.test.js +176 -0
- package/dist/src/orchestrator/tool-repetition-detector.d.ts +64 -0
- package/dist/src/orchestrator/tool-repetition-detector.js +0 -0
- package/dist/src/orchestrator/tool-repetition-detector.test.d.ts +1 -0
- package/dist/src/orchestrator/tool-repetition-detector.test.js +101 -0
- package/dist/src/orchestrator/turn-runner-deps.d.ts +3 -1
- package/dist/src/pil/__tests__/clarity-gate.test.d.ts +1 -0
- package/dist/src/pil/__tests__/clarity-gate.test.js +228 -0
- package/dist/src/pil/__tests__/config.test.js +44 -1
- package/dist/src/pil/__tests__/discovery-cache.test.d.ts +1 -0
- package/dist/src/pil/__tests__/discovery-cache.test.js +38 -0
- package/dist/src/pil/__tests__/discovery-types.test.d.ts +1 -0
- package/dist/src/pil/__tests__/discovery-types.test.js +54 -0
- package/dist/src/pil/__tests__/discovery.test.d.ts +1 -0
- package/dist/src/pil/__tests__/discovery.test.js +101 -0
- package/dist/src/pil/__tests__/layer1-intent-trace.test.js +5 -3
- package/dist/src/pil/__tests__/layer1-intent.test.js +25 -7
- package/dist/src/pil/__tests__/layer15-context-scan.test.d.ts +1 -0
- package/dist/src/pil/__tests__/layer15-context-scan.test.js +64 -0
- package/dist/src/pil/__tests__/layer16-clarity.test.d.ts +1 -0
- package/dist/src/pil/__tests__/layer16-clarity.test.js +153 -0
- package/dist/src/pil/__tests__/layer17-feasibility.test.d.ts +1 -0
- package/dist/src/pil/__tests__/layer17-feasibility.test.js +36 -0
- package/dist/src/pil/__tests__/layer18-acceptance.test.d.ts +1 -0
- package/dist/src/pil/__tests__/layer18-acceptance.test.js +95 -0
- package/dist/src/pil/__tests__/layer3-ee-injection.test.js +4 -1
- package/dist/src/pil/__tests__/layer3-injected-chunk.test.js +3 -3
- package/dist/src/pil/__tests__/layer6-output.test.js +69 -9
- package/dist/src/pil/__tests__/llm-classify.test.d.ts +1 -0
- package/dist/src/pil/__tests__/llm-classify.test.js +113 -0
- package/dist/src/pil/__tests__/native-capabilities-workbook.test.d.ts +1 -0
- package/dist/src/pil/__tests__/native-capabilities-workbook.test.js +40 -0
- package/dist/src/pil/__tests__/pipeline.test.js +3 -2
- package/dist/src/pil/__tests__/renderer-coverage.test.js +1 -1
- package/dist/src/pil/__tests__/response-tools.test.js +49 -1
- package/dist/src/pil/__tests__/scoreComplexity.test.js +2 -2
- package/dist/src/pil/agent-operating-contract.d.ts +51 -0
- package/dist/src/pil/agent-operating-contract.js +66 -0
- package/dist/src/pil/agent-operating-contract.test.d.ts +1 -0
- package/dist/src/pil/agent-operating-contract.test.js +75 -0
- package/dist/src/pil/budget-log.js +1 -1
- package/dist/src/pil/cheap-model-playbook.d.ts +80 -0
- package/dist/src/pil/cheap-model-playbook.js +147 -0
- package/dist/src/pil/cheap-model-playbook.test.d.ts +1 -0
- package/dist/src/pil/cheap-model-playbook.test.js +160 -0
- package/dist/src/pil/cheap-model-workbooks.d.ts +55 -0
- package/dist/src/pil/cheap-model-workbooks.js +102 -0
- package/dist/src/pil/cheap-model-workbooks.test.d.ts +1 -0
- package/dist/src/pil/cheap-model-workbooks.test.js +129 -0
- package/dist/src/pil/clarity-gate.d.ts +22 -0
- package/dist/src/pil/clarity-gate.js +162 -0
- package/dist/src/pil/config.d.ts +3 -0
- package/dist/src/pil/config.js +11 -0
- package/dist/src/pil/discovery-cache.d.ts +4 -0
- package/dist/src/pil/discovery-cache.js +18 -0
- package/dist/src/pil/discovery-types.d.ts +94 -0
- package/dist/src/pil/discovery-types.js +2 -0
- package/dist/src/pil/discovery.d.ts +18 -0
- package/dist/src/pil/discovery.js +341 -0
- package/dist/src/pil/index.d.ts +3 -1
- package/dist/src/pil/index.js +2 -1
- package/dist/src/pil/layer1-intent.d.ts +37 -1
- package/dist/src/pil/layer1-intent.js +675 -39
- package/dist/src/pil/layer1-intent.test.js +333 -1
- package/dist/src/pil/layer15-context-scan.d.ts +9 -0
- package/dist/src/pil/layer15-context-scan.js +164 -0
- package/dist/src/pil/layer16-clarity.d.ts +19 -0
- package/dist/src/pil/layer16-clarity.js +394 -0
- package/dist/src/pil/layer16-clarity.test.d.ts +1 -0
- package/dist/src/pil/layer16-clarity.test.js +31 -0
- package/dist/src/pil/layer17-feasibility.d.ts +4 -0
- package/dist/src/pil/layer17-feasibility.js +30 -0
- package/dist/src/pil/layer18-acceptance.d.ts +4 -0
- package/dist/src/pil/layer18-acceptance.js +84 -0
- package/dist/src/pil/layer1_5-complexity-size.d.ts +23 -0
- package/dist/src/pil/layer1_5-complexity-size.js +152 -0
- package/dist/src/pil/layer1_5-complexity-size.test.d.ts +10 -0
- package/dist/src/pil/layer1_5-complexity-size.test.js +248 -0
- package/dist/src/pil/layer3-ee-injection.js +63 -6
- package/dist/src/pil/layer4-gsd.js +7 -1
- package/dist/src/pil/layer5-context.js +15 -5
- package/dist/src/pil/layer6-output.d.ts +2 -0
- package/dist/src/pil/layer6-output.js +110 -18
- package/dist/src/pil/llm-classify.d.ts +16 -0
- package/dist/src/pil/llm-classify.js +179 -0
- package/dist/src/pil/native-capabilities-workbook.d.ts +39 -0
- package/dist/src/pil/native-capabilities-workbook.js +112 -0
- package/dist/src/pil/pipeline.d.ts +21 -0
- package/dist/src/pil/pipeline.js +89 -13
- package/dist/src/pil/response-tools.d.ts +56 -0
- package/dist/src/pil/response-tools.js +76 -2
- package/dist/src/pil/schema.d.ts +10 -1
- package/dist/src/pil/schema.js +8 -0
- package/dist/src/pil/session-state.d.ts +44 -0
- package/dist/src/pil/session-state.js +143 -0
- package/dist/src/pil/session-state.test.d.ts +1 -0
- package/dist/src/pil/session-state.test.js +73 -0
- package/dist/src/pil/task-tier-map.d.ts +6 -1
- package/dist/src/pil/task-tier-map.js +13 -6
- package/dist/src/pil/types.d.ts +18 -0
- package/dist/src/product-loop/__tests__/artifact-io.test.js +1 -1
- package/dist/src/product-loop/__tests__/assumption-ledger.test.js +1 -1
- package/dist/src/product-loop/__tests__/backlog-builder.test.d.ts +10 -0
- package/dist/src/product-loop/__tests__/backlog-builder.test.js +175 -0
- package/dist/src/product-loop/__tests__/backlog-store.test.d.ts +4 -0
- package/dist/src/product-loop/__tests__/backlog-store.test.js +96 -0
- package/dist/src/product-loop/__tests__/cb2-retry-bonus.test.js +1 -1
- package/dist/src/product-loop/__tests__/complexity-routing.spec.js +113 -7
- package/dist/src/product-loop/__tests__/context-policy.test.js +3 -3
- package/dist/src/product-loop/__tests__/cost-scoper.test.js +1 -1
- package/dist/src/product-loop/__tests__/discovery-context-format.test.d.ts +13 -0
- package/dist/src/product-loop/__tests__/discovery-context-format.test.js +100 -0
- package/dist/src/product-loop/__tests__/discovery-ecosystem.test.js +100 -1
- package/dist/src/product-loop/__tests__/discovery-prompt-specificity.test.d.ts +1 -0
- package/dist/src/product-loop/__tests__/discovery-prompt-specificity.test.js +55 -0
- package/dist/src/product-loop/__tests__/discovery-recommender-ecosystem.test.js +92 -0
- package/dist/src/product-loop/__tests__/ee-extract-wiring.test.js +8 -3
- package/dist/src/product-loop/__tests__/extract-to-ee.test.js +2 -2
- package/dist/src/product-loop/__tests__/gather-selectable-alts.test.d.ts +15 -0
- package/dist/src/product-loop/__tests__/gather-selectable-alts.test.js +109 -0
- package/dist/src/product-loop/__tests__/integration.test.js +7 -2
- package/dist/src/product-loop/__tests__/loop-driver-audit.test.js +7 -2
- package/dist/src/product-loop/__tests__/loop-driver.test.js +7 -2
- package/dist/src/product-loop/__tests__/maintenance-task-synthesis.test.d.ts +8 -0
- package/dist/src/product-loop/__tests__/maintenance-task-synthesis.test.js +67 -0
- package/dist/src/product-loop/__tests__/phase-a1-a3-sprint-runner.test.d.ts +13 -0
- package/dist/src/product-loop/__tests__/phase-a1-a3-sprint-runner.test.js +268 -0
- package/dist/src/product-loop/__tests__/phase-a2-backlog-build.test.d.ts +8 -0
- package/dist/src/product-loop/__tests__/phase-a2-backlog-build.test.js +162 -0
- package/dist/src/product-loop/__tests__/phase-rituals.test.js +1 -1
- package/dist/src/product-loop/__tests__/pick-backend-stack.test.d.ts +11 -0
- package/dist/src/product-loop/__tests__/pick-backend-stack.test.js +95 -0
- package/dist/src/product-loop/__tests__/progress-snapshot.test.d.ts +8 -0
- package/dist/src/product-loop/__tests__/progress-snapshot.test.js +152 -0
- package/dist/src/product-loop/__tests__/repo-audit.test.js +1 -1
- package/dist/src/product-loop/__tests__/repo-brief.test.d.ts +9 -0
- package/dist/src/product-loop/__tests__/repo-brief.test.js +132 -0
- package/dist/src/product-loop/__tests__/route-decision-emit.test.js +51 -2
- package/dist/src/product-loop/__tests__/ship-polish.test.js +1 -1
- package/dist/src/product-loop/__tests__/sprint-planner.test.d.ts +6 -0
- package/dist/src/product-loop/__tests__/sprint-planner.test.js +140 -0
- package/dist/src/product-loop/__tests__/sprint-runner-backlog.test.d.ts +8 -0
- package/dist/src/product-loop/__tests__/sprint-runner-backlog.test.js +221 -0
- package/dist/src/product-loop/__tests__/sprint-runner-phase-chunks.test.d.ts +14 -0
- package/dist/src/product-loop/__tests__/sprint-runner-phase-chunks.test.js +193 -0
- package/dist/src/product-loop/__tests__/sprint-self-verify.test.d.ts +8 -0
- package/dist/src/product-loop/__tests__/sprint-self-verify.test.js +73 -0
- package/dist/src/product-loop/__tests__/sprint-store.test.d.ts +7 -0
- package/dist/src/product-loop/__tests__/sprint-store.test.js +84 -0
- package/dist/src/product-loop/__tests__/sufficiency-routing.spec.js +6 -0
- package/dist/src/product-loop/__tests__/types.test.js +7 -7
- package/dist/src/product-loop/__tests__/verify-failure-threshold.test.js +3 -2
- package/dist/src/product-loop/__tests__/verify-failure-tracking.test.js +2 -2
- package/dist/src/product-loop/assumption-ledger.js +6 -6
- package/dist/src/product-loop/backlog-builder.d.ts +32 -0
- package/dist/src/product-loop/backlog-builder.js +198 -0
- package/dist/src/product-loop/backlog-store.d.ts +22 -0
- package/dist/src/product-loop/backlog-store.js +49 -0
- package/dist/src/product-loop/context-policy.js +1 -1
- package/dist/src/product-loop/cost-preview.js +17 -1
- package/dist/src/product-loop/cross-run-memory.js +11 -11
- package/dist/src/product-loop/discover.js +6 -6
- package/dist/src/product-loop/discovery-context-format.d.ts +16 -0
- package/dist/src/product-loop/discovery-context-format.js +45 -13
- package/dist/src/product-loop/discovery-council-runner.js +5 -10
- package/dist/src/product-loop/discovery-detection.js +3 -3
- package/dist/src/product-loop/discovery-ecosystem.d.ts +23 -0
- package/dist/src/product-loop/discovery-ecosystem.js +104 -0
- package/dist/src/product-loop/discovery-interview.d.ts +6 -0
- package/dist/src/product-loop/discovery-interview.js +38 -2
- package/dist/src/product-loop/discovery-recommender.d.ts +29 -0
- package/dist/src/product-loop/discovery-recommender.js +126 -7
- package/dist/src/product-loop/done-gate.js +5 -5
- package/dist/src/product-loop/gather.d.ts +12 -1
- package/dist/src/product-loop/gather.js +93 -12
- package/dist/src/product-loop/index.d.ts +23 -0
- package/dist/src/product-loop/index.js +502 -9
- package/dist/src/product-loop/loop-driver.js +27 -28
- package/dist/src/product-loop/phase-budget.js +2 -2
- package/dist/src/product-loop/progress-snapshot.d.ts +25 -0
- package/dist/src/product-loop/progress-snapshot.js +180 -0
- package/dist/src/product-loop/repo-brief.d.ts +40 -0
- package/dist/src/product-loop/repo-brief.js +212 -0
- package/dist/src/product-loop/role-registry.js +1 -1
- package/dist/src/product-loop/sprint-planner.d.ts +39 -0
- package/dist/src/product-loop/sprint-planner.js +189 -0
- package/dist/src/product-loop/sprint-runner.js +201 -9
- package/dist/src/product-loop/sprint-self-verify.d.ts +54 -0
- package/dist/src/product-loop/sprint-self-verify.js +145 -0
- package/dist/src/product-loop/sprint-store.d.ts +27 -0
- package/dist/src/product-loop/sprint-store.js +81 -0
- package/dist/src/product-loop/typed-artifacts.js +5 -5
- package/dist/src/product-loop/types.d.ts +113 -2
- package/dist/src/product-loop/verify-failure-tracking.js +1 -1
- package/dist/src/providers/__tests__/adapter-oauth-wiring.test.js +18 -2
- package/dist/src/providers/__tests__/capabilities-provider-options.test.js +23 -1
- package/dist/src/providers/__tests__/capabilities-sanitize.test.js +46 -61
- package/dist/src/providers/__tests__/reasoning-roundtrip.test.d.ts +1 -0
- package/dist/src/providers/__tests__/reasoning-roundtrip.test.js +135 -0
- package/dist/src/providers/__tests__/runtime-integration.test.js +19 -12
- package/dist/src/providers/__tests__/runtime.test.js +3 -6
- package/dist/src/providers/__tests__/siliconflow-sse-repair.test.d.ts +1 -0
- package/dist/src/providers/__tests__/siliconflow-sse-repair.test.js +267 -0
- package/dist/src/providers/auth/__tests__/browser-flow.test.js +1 -1
- package/dist/src/providers/auth/__tests__/gemini-oauth.test.js +1 -1
- package/dist/src/providers/auth/__tests__/grok-oauth.test.d.ts +8 -0
- package/dist/src/providers/auth/__tests__/grok-oauth.test.js +236 -0
- package/dist/src/providers/auth/__tests__/token-store.test.js +7 -7
- package/dist/src/providers/auth/gemini-oauth.js +2 -2
- package/dist/src/providers/auth/grok-oauth.d.ts +63 -0
- package/dist/src/providers/auth/grok-oauth.js +341 -0
- package/dist/src/providers/auth/registry.js +17 -0
- package/dist/src/providers/auth/token-store.js +1 -1
- package/dist/src/providers/capabilities.js +9 -15
- package/dist/src/providers/keychain.js +14 -2
- package/dist/src/providers/mcp-vision-bridge.js +49 -49
- package/dist/src/providers/mcp-vision-bridge.test.js +12 -12
- package/dist/src/providers/openai-compatible.js +5 -1
- package/dist/src/providers/pricing.d.ts +7 -4
- package/dist/src/providers/pricing.js +21 -5
- package/dist/src/providers/pricing.test.js +35 -9
- package/dist/src/providers/runtime.d.ts +1 -0
- package/dist/src/providers/runtime.js +39 -13
- package/dist/src/providers/siliconflow-sse-repair.d.ts +58 -0
- package/dist/src/providers/siliconflow-sse-repair.js +177 -0
- package/dist/src/providers/strategies/deepseek.strategy.js +28 -0
- package/dist/src/providers/strategies/siliconflow.strategy.js +2 -0
- package/dist/src/providers/strategies/xai.strategy.js +8 -1
- package/dist/src/providers/wire-debug.js +2 -2
- package/dist/src/reporter/__tests__/acl-check.test.d.ts +6 -0
- package/dist/src/reporter/__tests__/acl-check.test.js +59 -0
- package/dist/src/reporter/__tests__/auto-fire.test.d.ts +10 -0
- package/dist/src/reporter/__tests__/auto-fire.test.js +140 -0
- package/dist/src/reporter/__tests__/budget.test.d.ts +7 -0
- package/dist/src/reporter/__tests__/budget.test.js +60 -0
- package/dist/src/reporter/__tests__/handlers.test.d.ts +7 -0
- package/dist/src/reporter/__tests__/handlers.test.js +163 -0
- package/dist/src/reporter/__tests__/query-router.test.d.ts +6 -0
- package/dist/src/reporter/__tests__/query-router.test.js +90 -0
- package/dist/src/reporter/acl-check.d.ts +23 -0
- package/dist/src/reporter/acl-check.js +43 -0
- package/dist/src/reporter/auto-fire.d.ts +59 -0
- package/dist/src/reporter/auto-fire.js +126 -0
- package/dist/src/reporter/budget.d.ts +17 -0
- package/dist/src/reporter/budget.js +52 -0
- package/dist/src/reporter/handlers.d.ts +32 -0
- package/dist/src/reporter/handlers.js +180 -0
- package/dist/src/reporter/index.d.ts +44 -0
- package/dist/src/reporter/index.js +167 -0
- package/dist/src/reporter/query-router.d.ts +21 -0
- package/dist/src/reporter/query-router.js +32 -0
- package/dist/src/router/__tests__/step-router.test.js +3 -3
- package/dist/src/router/classifier/regex.js +49 -2
- package/dist/src/router/classifier/regex.test.js +3 -1
- package/dist/src/router/decide.d.ts +18 -0
- package/dist/src/router/decide.js +39 -7
- package/dist/src/router/decide.test.js +58 -8
- package/dist/src/router/role-override.test.d.ts +1 -0
- package/dist/src/router/role-override.test.js +26 -0
- package/dist/src/router/step-router.js +1 -1
- package/dist/src/router/warm.d.ts +2 -0
- package/dist/src/router/warm.js +42 -12
- package/dist/src/router/warm.test.js +59 -1
- package/dist/src/scaffold/__tests__/init-new.spec.js +3 -3
- package/dist/src/scaffold/bb-ecosystem-apply.js +51 -49
- package/dist/src/scaffold/bb-quality-gate.js +5 -5
- package/dist/src/scaffold/continuation-prompt.js +60 -60
- package/dist/src/scaffold/init-new.js +454 -454
- package/dist/src/self-qa/__tests__/agentic-context.test.d.ts +1 -0
- package/dist/src/self-qa/__tests__/agentic-context.test.js +98 -0
- package/dist/src/self-qa/__tests__/agentic-loop.test.d.ts +1 -0
- package/dist/src/self-qa/__tests__/agentic-loop.test.js +62 -0
- package/dist/src/self-qa/__tests__/delta-encoder.test.d.ts +1 -0
- package/dist/src/self-qa/__tests__/delta-encoder.test.js +97 -0
- package/dist/src/self-qa/__tests__/judge.test.d.ts +1 -0
- package/dist/src/self-qa/__tests__/judge.test.js +131 -0
- package/dist/src/self-qa/__tests__/scenario-planner.test.d.ts +1 -0
- package/dist/src/self-qa/__tests__/scenario-planner.test.js +79 -0
- package/dist/src/self-qa/__tests__/spec-emitter.test.d.ts +1 -0
- package/dist/src/self-qa/__tests__/spec-emitter.test.js +62 -0
- package/dist/src/self-qa/agentic-context.d.ts +29 -0
- package/dist/src/self-qa/agentic-context.js +189 -0
- package/dist/src/self-qa/agentic-loop.d.ts +96 -0
- package/dist/src/self-qa/agentic-loop.js +516 -0
- package/dist/src/self-qa/delta-encoder.d.ts +35 -0
- package/dist/src/self-qa/delta-encoder.js +138 -0
- package/dist/src/self-qa/index.d.ts +43 -0
- package/dist/src/self-qa/index.js +65 -0
- package/dist/src/self-qa/judge.d.ts +25 -0
- package/dist/src/self-qa/judge.js +233 -0
- package/dist/src/self-qa/orchestrator.d.ts +31 -0
- package/dist/src/self-qa/orchestrator.js +236 -0
- package/dist/src/self-qa/scenario-planner.d.ts +39 -0
- package/dist/src/self-qa/scenario-planner.js +262 -0
- package/dist/src/self-qa/spec-emitter.d.ts +25 -0
- package/dist/src/self-qa/spec-emitter.js +138 -0
- package/dist/src/self-qa/types.d.ts +113 -0
- package/dist/src/self-qa/types.js +11 -0
- package/dist/src/storage/__tests__/migrations.test.js +2 -2
- package/dist/src/storage/__tests__/sweep-stale-pending.test.d.ts +10 -0
- package/dist/src/storage/__tests__/sweep-stale-pending.test.js +97 -0
- package/dist/src/storage/__tests__/ui-interaction-log.test.js +30 -0
- package/dist/src/storage/atomic-io.test.js +2 -2
- package/dist/src/storage/config.test.js +1 -1
- package/dist/src/storage/interaction-log.d.ts +1 -1
- package/dist/src/storage/interaction-log.js +5 -5
- package/dist/src/storage/migrations.js +122 -122
- package/dist/src/storage/sessions.js +57 -42
- package/dist/src/storage/transcript-response-entry.test.d.ts +1 -0
- package/dist/src/storage/transcript-response-entry.test.js +98 -0
- package/dist/src/storage/transcript.d.ts +22 -0
- package/dist/src/storage/transcript.js +149 -74
- package/dist/src/storage/ui-interaction-log.d.ts +11 -1
- package/dist/src/storage/usage-cap.test.js +1 -1
- package/dist/src/storage/usage.js +14 -14
- package/dist/src/storage/workspaces.js +12 -12
- package/dist/src/tools/__tests__/vision-gate.test.d.ts +1 -0
- package/dist/src/tools/__tests__/vision-gate.test.js +56 -0
- package/dist/src/tools/bash-output-cache.d.ts +59 -0
- package/dist/src/tools/bash-output-cache.js +108 -0
- package/dist/src/tools/bash-output-cache.test.d.ts +1 -0
- package/dist/src/tools/bash-output-cache.test.js +89 -0
- package/dist/src/tools/bash-output-integration.test.d.ts +10 -0
- package/dist/src/tools/bash-output-integration.test.js +30 -0
- package/dist/src/tools/bash.d.ts +12 -0
- package/dist/src/tools/bash.js +114 -21
- package/dist/src/tools/bash.test.js +80 -3
- package/dist/src/tools/computer.test.js +1 -1
- package/dist/src/tools/file-tracker.test.js +1 -1
- package/dist/src/tools/file.js +23 -2
- package/dist/src/tools/file.test.js +49 -1
- package/dist/src/tools/registry-bash-empty-command.test.d.ts +13 -0
- package/dist/src/tools/registry-bash-empty-command.test.js +56 -0
- package/dist/src/tools/registry-bash-footer.test.d.ts +7 -0
- package/dist/src/tools/registry-bash-footer.test.js +82 -0
- package/dist/src/tools/registry-ee-query.test.d.ts +11 -0
- package/dist/src/tools/registry-ee-query.test.js +48 -0
- package/dist/src/tools/registry-session-repeat.test.d.ts +12 -0
- package/dist/src/tools/registry-session-repeat.test.js +87 -0
- package/dist/src/tools/registry.d.ts +38 -0
- package/dist/src/tools/registry.js +262 -4
- package/dist/src/tools/schedule.test.js +1 -1
- package/dist/src/tools/todo-write-snapshot.d.ts +18 -0
- package/dist/src/tools/todo-write-snapshot.js +66 -0
- package/dist/src/tools/todo-write-snapshot.test.d.ts +1 -0
- package/dist/src/tools/todo-write-snapshot.test.js +43 -0
- package/dist/src/tools/vision-gate.d.ts +41 -0
- package/dist/src/tools/vision-gate.js +67 -0
- package/dist/src/types/index.d.ts +65 -4
- package/dist/src/ui/__tests__/picker-providers.test.d.ts +1 -0
- package/dist/src/ui/__tests__/picker-providers.test.js +31 -0
- package/dist/src/ui/agents-modal.js +2 -0
- package/dist/src/ui/app.d.ts +1 -0
- package/dist/src/ui/app.js +0 -0
- package/dist/src/ui/components/__tests__/task-list-panel.test.d.ts +1 -0
- package/dist/src/ui/components/__tests__/task-list-panel.test.js +31 -0
- package/dist/src/ui/components/council-info-card.d.ts +1 -2
- package/dist/src/ui/components/council-leader-bubble.d.ts +1 -2
- package/dist/src/ui/components/council-message-bubble.d.ts +1 -2
- package/dist/src/ui/components/council-phase-timeline.js +20 -1
- package/dist/src/ui/components/council-placeholder-bubble.d.ts +1 -2
- package/dist/src/ui/components/council-question-card.js +3 -0
- package/dist/src/ui/components/council-synthesis-banner.d.ts +1 -2
- package/dist/src/ui/components/halt-recovery-card.js +1 -0
- package/dist/src/ui/components/message-view.d.ts +11 -1
- package/dist/src/ui/components/message-view.js +65 -3
- package/dist/src/ui/components/point-to-existing-form-card.js +5 -1
- package/dist/src/ui/components/task-list-panel.d.ts +32 -0
- package/dist/src/ui/components/task-list-panel.js +84 -0
- package/dist/src/ui/components/tool-group.d.ts +22 -0
- package/dist/src/ui/components/tool-group.js +85 -0
- package/dist/src/ui/hooks/use-agent-editor.js +2 -3
- package/dist/src/ui/hooks/use-model-picker.d.ts +2 -2
- package/dist/src/ui/modals/model-picker-modal.d.ts +2 -0
- package/dist/src/ui/modals/model-picker-modal.js +2 -4
- package/dist/src/ui/picker-providers.d.ts +21 -0
- package/dist/src/ui/picker-providers.js +39 -0
- package/dist/src/ui/slash/__tests__/clear.test.js +1 -1
- package/dist/src/ui/slash/__tests__/compact.test.js +1 -1
- package/dist/src/ui/slash/__tests__/discuss.test.js +1 -1
- package/dist/src/ui/slash/__tests__/execute.test.js +1 -1
- package/dist/src/ui/slash/__tests__/expand.test.js +1 -1
- package/dist/src/ui/slash/__tests__/ideal.test.js +41 -0
- package/dist/src/ui/slash/__tests__/menu-parity.test.d.ts +1 -0
- package/dist/src/ui/slash/__tests__/menu-parity.test.js +1 -0
- package/dist/src/ui/slash/__tests__/plan.test.js +4 -1
- package/dist/src/ui/slash/__tests__/status-render.test.d.ts +7 -0
- package/dist/src/ui/slash/__tests__/status-render.test.js +77 -0
- package/dist/src/ui/slash/council-inspect.js +4 -4
- package/dist/src/ui/slash/export.js +32 -5
- package/dist/src/ui/slash/ideal.d.ts +9 -0
- package/dist/src/ui/slash/ideal.js +27 -1
- package/dist/src/ui/slash/menu-items.js +1 -0
- package/dist/src/ui/slash/status.d.ts +12 -0
- package/dist/src/ui/slash/status.js +32 -0
- package/dist/src/ui/state/active-run.d.ts +26 -0
- package/dist/src/ui/state/active-run.js +44 -0
- package/dist/src/ui/status-bar/index.d.ts +6 -1
- package/dist/src/ui/status-bar/index.js +21 -2
- package/dist/src/ui/status-bar/index.test.js +60 -1
- package/dist/src/ui/status-bar/store.d.ts +16 -0
- package/dist/src/ui/status-bar/store.js +120 -1
- package/dist/src/ui/utils/__tests__/format.test.d.ts +1 -0
- package/dist/src/ui/utils/__tests__/format.test.js +50 -0
- package/dist/src/ui/utils/__tests__/tools.test.d.ts +1 -0
- package/dist/src/ui/utils/__tests__/tools.test.js +48 -0
- package/dist/src/ui/utils/format.d.ts +17 -0
- package/dist/src/ui/utils/format.js +45 -2
- package/dist/src/ui/utils/text.js +2 -1
- package/dist/src/ui/utils/tools.d.ts +2 -0
- package/dist/src/ui/utils/tools.js +58 -9
- package/dist/src/usage/__tests__/product-ledger.test.js +5 -4
- package/dist/src/usage/decision-log.d.ts +1 -1
- package/dist/src/usage/downgrade.d.ts +3 -2
- package/dist/src/usage/downgrade.js +25 -9
- package/dist/src/usage/downgrade.test.js +40 -37
- package/dist/src/usage/product-ledger.d.ts +4 -0
- package/dist/src/usage/product-ledger.js +8 -1
- package/dist/src/utils/__tests__/llm-deadline.test.d.ts +1 -0
- package/dist/src/utils/__tests__/llm-deadline.test.js +56 -0
- package/dist/src/utils/__tests__/settings-disabled-models.test.js +1 -1
- package/dist/src/utils/__tests__/settings-web-research.test.js +1 -1
- package/dist/src/utils/__tests__/visible-retry.test.js +1 -1
- package/dist/src/utils/clipboard-image.js +23 -23
- package/dist/src/utils/install-manager.test.js +1 -1
- package/dist/src/utils/llm-deadline.d.ts +44 -0
- package/dist/src/utils/llm-deadline.js +80 -0
- package/dist/src/utils/permission-mode.d.ts +16 -9
- package/dist/src/utils/permission-mode.js +55 -4
- package/dist/src/utils/settings.d.ts +22 -0
- package/dist/src/utils/settings.js +47 -6
- package/dist/src/utils/shell.d.ts +12 -0
- package/dist/src/utils/shell.js +23 -12
- package/dist/src/utils/shell.test.js +27 -1
- package/dist/src/utils/side-question.js +2 -2
- package/dist/src/utils/skills.js +3 -3
- package/dist/src/utils/skills.test.js +1 -1
- package/dist/src/utils/subagents-settings.test.js +9 -3
- package/dist/src/verify/__tests__/coverage-parsers.test.js +30 -30
- package/dist/src/verify/__tests__/dotnet-recipe.test.js +1 -1
- package/dist/src/verify/checkpoint.test.js +1 -1
- package/dist/src/verify/entrypoint.d.ts +8 -8
- package/dist/src/verify/entrypoint.js +69 -32
- package/dist/src/verify/entrypoint.test.js +1 -1
- package/dist/src/verify/environment.test.js +1 -1
- package/dist/src/verify/orchestrator.test.js +1 -1
- package/dist/src/verify/runtime-prep.test.js +1 -1
- package/package.json +125 -122
- package/scripts/postinstall.cjs +76 -73
- package/dist/packages/agent-harness-core/src/driver.js.map +0 -1
- package/dist/packages/agent-harness-core/src/event-filter.js.map +0 -1
- package/dist/packages/agent-harness-core/src/event-redact.js.map +0 -1
- package/dist/packages/agent-harness-core/src/idle.js.map +0 -1
- package/dist/packages/agent-harness-core/src/index.js.map +0 -1
- package/dist/packages/agent-harness-core/src/mcp-server.js.map +0 -1
- package/dist/packages/agent-harness-core/src/mock-llm.js.map +0 -1
- package/dist/packages/agent-harness-core/src/predicate.js.map +0 -1
- package/dist/packages/agent-harness-core/src/protocol.js.map +0 -1
- package/dist/packages/agent-harness-core/src/registry.js.map +0 -1
- package/dist/packages/agent-harness-core/src/selector.js.map +0 -1
- package/dist/packages/agent-harness-core/src/spec-helpers.js.map +0 -1
- package/dist/packages/agent-harness-core/src/transports/sidechannel.js.map +0 -1
- package/dist/packages/agent-harness-core/src/transports/ws.js.map +0 -1
- package/dist/packages/agent-harness-opentui/src/agent-mode.js.map +0 -1
- package/dist/packages/agent-harness-opentui/src/index.js.map +0 -1
- package/dist/packages/agent-harness-opentui/src/input-bridge.js.map +0 -1
- package/dist/packages/agent-harness-opentui/src/install.js.map +0 -1
- package/dist/packages/agent-harness-opentui/src/reconciler-hook.js.map +0 -1
- package/dist/packages/agent-harness-opentui/src/semantic.js.map +0 -1
- package/dist/src/__test-stubs__/ee-server.js.map +0 -1
- package/dist/src/__test-stubs__/vitest-setup.js.map +0 -1
- package/dist/src/__tests__/council/bubble-layout.test.js.map +0 -1
- package/dist/src/__tests__/council/code-block-truncate.test.js.map +0 -1
- package/dist/src/__tests__/council/role-palette.test.js.map +0 -1
- package/dist/src/__tests__/first-run-wizard.test.js.map +0 -1
- package/dist/src/agent-harness/__tests__/cli-flags.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/driver.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/idle.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/mock-llm.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/mock-model.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/predicate.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/protocol.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/schema.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/selector.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/sidechannel.spec.js.map +0 -1
- package/dist/src/agent-harness/__tests__/spec-helpers.spec.js.map +0 -1
- package/dist/src/agent-harness/index.js.map +0 -1
- package/dist/src/agent-harness/mock-model.js.map +0 -1
- package/dist/src/agent-harness/test-spawn.js.map +0 -1
- package/dist/src/billing/index.js.map +0 -1
- package/dist/src/chat/__tests__/broadcast-bus.test.js.map +0 -1
- package/dist/src/chat/__tests__/channel-manager.test.js.map +0 -1
- package/dist/src/chat/__tests__/client.test.js.map +0 -1
- package/dist/src/chat/__tests__/discord-integration.test.js.map +0 -1
- package/dist/src/chat/__tests__/intent-prompt.test.js.map +0 -1
- package/dist/src/chat/__tests__/verdict-resolver.test.js.map +0 -1
- package/dist/src/chat/broadcast-bus.js.map +0 -1
- package/dist/src/chat/channel-manager.js.map +0 -1
- package/dist/src/chat/chat-keychain.js.map +0 -1
- package/dist/src/chat/factory.js.map +0 -1
- package/dist/src/chat/intent-prompt.js.map +0 -1
- package/dist/src/chat/providers/discord/client.js.map +0 -1
- package/dist/src/chat/types.js.map +0 -1
- package/dist/src/chat/verdict-constants.js.map +0 -1
- package/dist/src/chat/verdict-resolver.js.map +0 -1
- package/dist/src/cli/__tests__/bw-vault.test.js.map +0 -1
- package/dist/src/cli/__tests__/keys-bundle.test.js.map +0 -1
- package/dist/src/cli/__tests__/share-cmd.test.js.map +0 -1
- package/dist/src/cli/bw-vault.js.map +0 -1
- package/dist/src/cli/config/__tests__/model-picker.test.js.map +0 -1
- package/dist/src/cli/config/__tests__/provider-fetch.test.js.map +0 -1
- package/dist/src/cli/config/index.js.map +0 -1
- package/dist/src/cli/config/model-picker.js.map +0 -1
- package/dist/src/cli/config/provider-fetch.js.map +0 -1
- package/dist/src/cli/config/screen-council.js.map +0 -1
- package/dist/src/cli/config/screen-models.js.map +0 -1
- package/dist/src/cli/config/screen-providers.js.map +0 -1
- package/dist/src/cli/config/tui.js.map +0 -1
- package/dist/src/cli/cost-forensics.js.map +0 -1
- package/dist/src/cli/cost-forensics.test.js.map +0 -1
- package/dist/src/cli/keys-bundle.js.map +0 -1
- package/dist/src/cli/keys.js.map +0 -1
- package/dist/src/cli/keys.test.js.map +0 -1
- package/dist/src/cli/pil-report.js.map +0 -1
- package/dist/src/cli/share-cmd.js.map +0 -1
- package/dist/src/cli/usage-report.js.map +0 -1
- package/dist/src/cloud/index.js.map +0 -1
- package/dist/src/council/__tests__/accounting.test.js.map +0 -1
- package/dist/src/council/__tests__/audit-replay.test.js.map +0 -1
- package/dist/src/council/__tests__/clarifier-max-rounds.test.js.map +0 -1
- package/dist/src/council/__tests__/clarifier-options.test.js.map +0 -1
- package/dist/src/council/__tests__/cost-aware.test.js.map +0 -1
- package/dist/src/council/__tests__/debate-planner-structured.test.js.map +0 -1
- package/dist/src/council/__tests__/evaluator-metrics.test.js.map +0 -1
- package/dist/src/council/__tests__/parse-outcome-fallback.test.js.map +0 -1
- package/dist/src/council/__tests__/research-tools.test.js.map +0 -1
- package/dist/src/council/__tests__/round-tools.test.js.map +0 -1
- package/dist/src/council/__tests__/tool-trace.test.js.map +0 -1
- package/dist/src/council/__tests__/types-contract.test.js.map +0 -1
- package/dist/src/council/clarifier.js.map +0 -1
- package/dist/src/council/context.js.map +0 -1
- package/dist/src/council/debate-planner.js.map +0 -1
- package/dist/src/council/debate.js.map +0 -1
- package/dist/src/council/executor.js.map +0 -1
- package/dist/src/council/index.js.map +0 -1
- package/dist/src/council/leader.js.map +0 -1
- package/dist/src/council/llm.js.map +0 -1
- package/dist/src/council/phase-events.js.map +0 -1
- package/dist/src/council/planner.js.map +0 -1
- package/dist/src/council/preflight.js.map +0 -1
- package/dist/src/council/prompts.js.map +0 -1
- package/dist/src/council/types.js.map +0 -1
- package/dist/src/daemon/scheduler.js.map +0 -1
- package/dist/src/daemon/scheduler.test.js.map +0 -1
- package/dist/src/ee/__tests__/bb-design.test.js.map +0 -1
- package/dist/src/ee/__tests__/pil-context-bridge.test.js.map +0 -1
- package/dist/src/ee/__tests__/pipeline.integration.test.js.map +0 -1
- package/dist/src/ee/__tests__/render-sink-wiring.test.js.map +0 -1
- package/dist/src/ee/auth.js.map +0 -1
- package/dist/src/ee/auth.test.js.map +0 -1
- package/dist/src/ee/bb-design.js.map +0 -1
- package/dist/src/ee/bb-retrieval.js.map +0 -1
- package/dist/src/ee/bridge.js.map +0 -1
- package/dist/src/ee/bridge.test.js.map +0 -1
- package/dist/src/ee/client-mode.js.map +0 -1
- package/dist/src/ee/client.js.map +0 -1
- package/dist/src/ee/client.test.js.map +0 -1
- package/dist/src/ee/council-bridge.js.map +0 -1
- package/dist/src/ee/embedding-cache.js.map +0 -1
- package/dist/src/ee/extract-session.js.map +0 -1
- package/dist/src/ee/extract-session.test.js.map +0 -1
- package/dist/src/ee/health.js.map +0 -1
- package/dist/src/ee/index.js.map +0 -1
- package/dist/src/ee/intercept.js.map +0 -1
- package/dist/src/ee/intercept.test.js.map +0 -1
- package/dist/src/ee/judge.js.map +0 -1
- package/dist/src/ee/judge.test.js.map +0 -1
- package/dist/src/ee/mistake-detector.js.map +0 -1
- package/dist/src/ee/mistake-detector.test.js.map +0 -1
- package/dist/src/ee/offline-queue.js.map +0 -1
- package/dist/src/ee/offline-queue.test.js.map +0 -1
- package/dist/src/ee/phase-outcome.js.map +0 -1
- package/dist/src/ee/phase-outcome.test.js.map +0 -1
- package/dist/src/ee/phase-tracker.js.map +0 -1
- package/dist/src/ee/phase-tracker.test.js.map +0 -1
- package/dist/src/ee/posttool.js.map +0 -1
- package/dist/src/ee/posttool.test.js.map +0 -1
- package/dist/src/ee/prompt-stale.js.map +0 -1
- package/dist/src/ee/prompt-stale.test.js.map +0 -1
- package/dist/src/ee/render.js.map +0 -1
- package/dist/src/ee/render.test.js.map +0 -1
- package/dist/src/ee/scope.js.map +0 -1
- package/dist/src/ee/scope.test.js.map +0 -1
- package/dist/src/ee/session-trajectory.js.map +0 -1
- package/dist/src/ee/session-trajectory.test.js.map +0 -1
- package/dist/src/ee/tenant.js.map +0 -1
- package/dist/src/ee/touch.test.js.map +0 -1
- package/dist/src/ee/types.js.map +0 -1
- package/dist/src/flow/__tests__/migration.test.js.map +0 -1
- package/dist/src/flow/__tests__/parser.test.js.map +0 -1
- package/dist/src/flow/__tests__/run-manager-product.test.js.map +0 -1
- package/dist/src/flow/__tests__/run-manager.test.js.map +0 -1
- package/dist/src/flow/__tests__/scaffold-checkpoint.test.js.map +0 -1
- package/dist/src/flow/__tests__/scaffold.test.js.map +0 -1
- package/dist/src/flow/__tests__/warning-persist.test.js.map +0 -1
- package/dist/src/flow/artifact-io.js.map +0 -1
- package/dist/src/flow/compaction/__tests__/compress.test.js.map +0 -1
- package/dist/src/flow/compaction/__tests__/extract.test.js.map +0 -1
- package/dist/src/flow/compaction/__tests__/preserve.test.js.map +0 -1
- package/dist/src/flow/compaction/compress.js.map +0 -1
- package/dist/src/flow/compaction/extract.js.map +0 -1
- package/dist/src/flow/compaction/index.js.map +0 -1
- package/dist/src/flow/compaction/preserve.js.map +0 -1
- package/dist/src/flow/index.js.map +0 -1
- package/dist/src/flow/migration.js.map +0 -1
- package/dist/src/flow/parser.js.map +0 -1
- package/dist/src/flow/run-manager.js.map +0 -1
- package/dist/src/flow/scaffold-checkpoint.js.map +0 -1
- package/dist/src/flow/scaffold.js.map +0 -1
- package/dist/src/flow/warning-persist.js.map +0 -1
- package/dist/src/generated/version.js.map +0 -1
- package/dist/src/gsd/__tests__/complexity.test.js.map +0 -1
- package/dist/src/gsd/__tests__/directives.test.js.map +0 -1
- package/dist/src/gsd/__tests__/gray-areas.test.js.map +0 -1
- package/dist/src/gsd/__tests__/types.test.js.map +0 -1
- package/dist/src/gsd/complexity.js.map +0 -1
- package/dist/src/gsd/directives.js.map +0 -1
- package/dist/src/gsd/gray-areas.js.map +0 -1
- package/dist/src/gsd/index.js.map +0 -1
- package/dist/src/gsd/types.js.map +0 -1
- package/dist/src/headless/__tests__/council-answers.test.js.map +0 -1
- package/dist/src/headless/council-answers.js.map +0 -1
- package/dist/src/headless/output.js.map +0 -1
- package/dist/src/headless/output.test.js.map +0 -1
- package/dist/src/hooks/config.js.map +0 -1
- package/dist/src/hooks/index.js.map +0 -1
- package/dist/src/hooks/types.js.map +0 -1
- package/dist/src/index.js.map +0 -1
- package/dist/src/lsp/builtins.js.map +0 -1
- package/dist/src/lsp/builtins.test.js.map +0 -1
- package/dist/src/lsp/client.js.map +0 -1
- package/dist/src/lsp/manager.js.map +0 -1
- package/dist/src/lsp/manager.test.js.map +0 -1
- package/dist/src/lsp/npm-cache.js.map +0 -1
- package/dist/src/lsp/npm-cache.test.js.map +0 -1
- package/dist/src/lsp/runtime.js.map +0 -1
- package/dist/src/lsp/smoke.test.js.map +0 -1
- package/dist/src/lsp/types.js.map +0 -1
- package/dist/src/mcp/__tests__/auto-setup.test.js.map +0 -1
- package/dist/src/mcp/__tests__/harness-driver-action-tools.spec.js.map +0 -1
- package/dist/src/mcp/__tests__/harness-driver-async-tools.spec.js.map +0 -1
- package/dist/src/mcp/__tests__/harness-driver-read-tools.spec.js.map +0 -1
- package/dist/src/mcp/__tests__/harness-driver-security.spec.js.map +0 -1
- package/dist/src/mcp/__tests__/harness-driver.spec.js.map +0 -1
- package/dist/src/mcp/__tests__/lazy-schema.spec.js.map +0 -1
- package/dist/src/mcp/__tests__/mcp-keychain.test.js.map +0 -1
- package/dist/src/mcp/__tests__/research-onboarding.test.js.map +0 -1
- package/dist/src/mcp/__tests__/runtime-hydration.test.js.map +0 -1
- package/dist/src/mcp/__tests__/runtime-sanitize.test.js.map +0 -1
- package/dist/src/mcp/auto-setup.js.map +0 -1
- package/dist/src/mcp/catalog.js.map +0 -1
- package/dist/src/mcp/mcp-keychain.js.map +0 -1
- package/dist/src/mcp/oauth-callback.js.map +0 -1
- package/dist/src/mcp/oauth-provider.js.map +0 -1
- package/dist/src/mcp/opentui-spawn.js.map +0 -1
- package/dist/src/mcp/parse-headers.js.map +0 -1
- package/dist/src/mcp/parse-headers.test.js.map +0 -1
- package/dist/src/mcp/research-onboarding.js.map +0 -1
- package/dist/src/mcp/runtime.js.map +0 -1
- package/dist/src/mcp/smoke.test.js.map +0 -1
- package/dist/src/mcp/validate.js.map +0 -1
- package/dist/src/models/__tests__/registry.test.js.map +0 -1
- package/dist/src/models/catalog-client.js.map +0 -1
- package/dist/src/models/classify-tier.js.map +0 -1
- package/dist/src/models/index.js.map +0 -1
- package/dist/src/models/registry.js.map +0 -1
- package/dist/src/ops/__tests__/doctor-council-mcp.test.js.map +0 -1
- package/dist/src/ops/__tests__/doctor-ee-health.test.js.map +0 -1
- package/dist/src/ops/bug-report.js.map +0 -1
- package/dist/src/ops/bug-report.test.js.map +0 -1
- package/dist/src/ops/doctor.js.map +0 -1
- package/dist/src/ops/doctor.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/batch-turn-runner.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/council-manager.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/cross-turn-dedup.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/current-call-id.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/flow-resume.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/message-processor.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/message-write-ahead.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/read-path-budget.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/retry-classifier.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/retry-stream.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/route-feedback.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/stream-runner.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/usage-events-shape.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/usage-normalizer-c1.test.js.map +0 -1
- package/dist/src/orchestrator/__tests__/write-ahead.test.js.map +0 -1
- package/dist/src/orchestrator/abort.js.map +0 -1
- package/dist/src/orchestrator/abort.test.js.map +0 -1
- package/dist/src/orchestrator/agent-options.js.map +0 -1
- package/dist/src/orchestrator/agent.test.js.map +0 -1
- package/dist/src/orchestrator/batch-turn-runner.js.map +0 -1
- package/dist/src/orchestrator/batch-utils.js.map +0 -1
- package/dist/src/orchestrator/cleanup.test.js.map +0 -1
- package/dist/src/orchestrator/compaction.js.map +0 -1
- package/dist/src/orchestrator/compaction.test.js.map +0 -1
- package/dist/src/orchestrator/council-manager.js.map +0 -1
- package/dist/src/orchestrator/cross-turn-dedup.js.map +0 -1
- package/dist/src/orchestrator/delegations.js.map +0 -1
- package/dist/src/orchestrator/delegations.test.js.map +0 -1
- package/dist/src/orchestrator/error-utils.js.map +0 -1
- package/dist/src/orchestrator/flow-resume.js.map +0 -1
- package/dist/src/orchestrator/message-processor.js.map +0 -1
- package/dist/src/orchestrator/message-seq.js.map +0 -1
- package/dist/src/orchestrator/message-seq.test.js.map +0 -1
- package/dist/src/orchestrator/orchestrator.js.map +0 -1
- package/dist/src/orchestrator/pending-calls.js.map +0 -1
- package/dist/src/orchestrator/pending-calls.test.js.map +0 -1
- package/dist/src/orchestrator/prompts.js.map +0 -1
- package/dist/src/orchestrator/provider-options-shape.js.map +0 -1
- package/dist/src/orchestrator/provider-options-shape.spec.js.map +0 -1
- package/dist/src/orchestrator/read-path-budget.js.map +0 -1
- package/dist/src/orchestrator/reasoning.js.map +0 -1
- package/dist/src/orchestrator/reasoning.test.js.map +0 -1
- package/dist/src/orchestrator/retry-classifier.js.map +0 -1
- package/dist/src/orchestrator/retry-stream.js.map +0 -1
- package/dist/src/orchestrator/sandbox.test.js.map +0 -1
- package/dist/src/orchestrator/stream-runner.js.map +0 -1
- package/dist/src/orchestrator/sub-agent-cap.js.map +0 -1
- package/dist/src/orchestrator/sub-agent-cap.test.js.map +0 -1
- package/dist/src/orchestrator/subagent-compactor.js.map +0 -1
- package/dist/src/orchestrator/subagent-compactor.spec.js.map +0 -1
- package/dist/src/orchestrator/token-counter.js.map +0 -1
- package/dist/src/orchestrator/token-counter.test.js.map +0 -1
- package/dist/src/orchestrator/tool-utils.js.map +0 -1
- package/dist/src/orchestrator/turn-runner-deps.js.map +0 -1
- package/dist/src/pil/__tests__/budget.test.js.map +0 -1
- package/dist/src/pil/__tests__/config.test.js.map +0 -1
- package/dist/src/pil/__tests__/dual-run.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer1-intent-trace.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer1-intent.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer2-personality.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer3-ee-injection.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer3-injected-chunk.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer4-gsd.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer5-context.test.js.map +0 -1
- package/dist/src/pil/__tests__/layer6-output.test.js.map +0 -1
- package/dist/src/pil/__tests__/ollama-classify.test.js.map +0 -1
- package/dist/src/pil/__tests__/orchestrator-integration.test.js.map +0 -1
- package/dist/src/pil/__tests__/pipeline.test.js.map +0 -1
- package/dist/src/pil/__tests__/renderer-coverage.test.js.map +0 -1
- package/dist/src/pil/__tests__/response-tools.test.js.map +0 -1
- package/dist/src/pil/__tests__/schema.test.js.map +0 -1
- package/dist/src/pil/__tests__/scoreComplexity.test.js.map +0 -1
- package/dist/src/pil/__tests__/scoreSufficiency.test.js.map +0 -1
- package/dist/src/pil/__tests__/store.test.js.map +0 -1
- package/dist/src/pil/__tests__/task-tier-map.test.js.map +0 -1
- package/dist/src/pil/budget-log.js.map +0 -1
- package/dist/src/pil/budget.js.map +0 -1
- package/dist/src/pil/config.js.map +0 -1
- package/dist/src/pil/index.js.map +0 -1
- package/dist/src/pil/layer1-intent.js.map +0 -1
- package/dist/src/pil/layer1-intent.test.js.map +0 -1
- package/dist/src/pil/layer2-personality.js.map +0 -1
- package/dist/src/pil/layer3-ee-injection.js.map +0 -1
- package/dist/src/pil/layer4-gsd.js.map +0 -1
- package/dist/src/pil/layer5-context.js.map +0 -1
- package/dist/src/pil/layer6-output.js.map +0 -1
- package/dist/src/pil/ollama-classify.js.map +0 -1
- package/dist/src/pil/pipeline.js.map +0 -1
- package/dist/src/pil/response-tools.js.map +0 -1
- package/dist/src/pil/schema.js.map +0 -1
- package/dist/src/pil/store.js.map +0 -1
- package/dist/src/pil/task-tier-map.js.map +0 -1
- package/dist/src/pil/timeout.js.map +0 -1
- package/dist/src/pil/types.js.map +0 -1
- package/dist/src/product-loop/__tests__/artifact-io.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/assumption-ledger.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/cb2-retry-bonus.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/circuit-breakers-coverage.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/circuit-breakers.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/complexity-routing.spec.js.map +0 -1
- package/dist/src/product-loop/__tests__/context-policy.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/cost-preview.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/cost-scoper.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/cross-run-memory.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/design-output.spec.js.map +0 -1
- package/dist/src/product-loop/__tests__/discover.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-council-runner.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-detection.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-ecosystem.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-integration.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-interview.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-migrations.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-persistence.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-prompt-parser.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-recommender-ecosystem.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-recommender.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/discovery-schema.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/done-gate-coverage.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/done-gate.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/ee-extract-wiring.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/extract-to-ee.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/feedback-routing.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/hot-path.spec.js.map +0 -1
- package/dist/src/product-loop/__tests__/integration.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/loop-driver-audit.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/loop-driver.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/phase-budget.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/phase-orchestrator-integration.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/phase-plan.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/phase-rituals.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/phase-runner.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/phase-tracker-bridge.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/product-identity.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/reality-anchor.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/repo-audit.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/role-memory.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/role-registry.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/role-routing-ee.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/route-decision-emit.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/seed-questions.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/ship-polish.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/sprint-runner-emit.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/sprint-runner.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/stakeholder-acl.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/state-md-ee-injections.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/sufficiency-routing.spec.js.map +0 -1
- package/dist/src/product-loop/__tests__/typed-artifacts.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/types.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/verify-failure-threshold.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/verify-failure-tracking.test.js.map +0 -1
- package/dist/src/product-loop/__tests__/verify-result.test.js.map +0 -1
- package/dist/src/product-loop/artifact-io.js.map +0 -1
- package/dist/src/product-loop/assumption-ledger.js.map +0 -1
- package/dist/src/product-loop/circuit-breakers.js.map +0 -1
- package/dist/src/product-loop/context-policy.js.map +0 -1
- package/dist/src/product-loop/cost-preview.js.map +0 -1
- package/dist/src/product-loop/cost-scoper.js.map +0 -1
- package/dist/src/product-loop/cross-run-memory.js.map +0 -1
- package/dist/src/product-loop/design-output.js.map +0 -1
- package/dist/src/product-loop/discover.js.map +0 -1
- package/dist/src/product-loop/discovery-context-format.js.map +0 -1
- package/dist/src/product-loop/discovery-council-runner.js.map +0 -1
- package/dist/src/product-loop/discovery-detection.js.map +0 -1
- package/dist/src/product-loop/discovery-ecosystem.js.map +0 -1
- package/dist/src/product-loop/discovery-interview.js.map +0 -1
- package/dist/src/product-loop/discovery-migrations.js.map +0 -1
- package/dist/src/product-loop/discovery-persistence.js.map +0 -1
- package/dist/src/product-loop/discovery-prompt-parser.js.map +0 -1
- package/dist/src/product-loop/discovery-recommender.js.map +0 -1
- package/dist/src/product-loop/discovery-schema.js.map +0 -1
- package/dist/src/product-loop/done-gate.js.map +0 -1
- package/dist/src/product-loop/feedback-routing.js.map +0 -1
- package/dist/src/product-loop/gather.js.map +0 -1
- package/dist/src/product-loop/index.js.map +0 -1
- package/dist/src/product-loop/loop-driver.js.map +0 -1
- package/dist/src/product-loop/phase-budget.js.map +0 -1
- package/dist/src/product-loop/phase-plan.js.map +0 -1
- package/dist/src/product-loop/phase-rituals.js.map +0 -1
- package/dist/src/product-loop/phase-runner.js.map +0 -1
- package/dist/src/product-loop/phase-tracker-bridge.js.map +0 -1
- package/dist/src/product-loop/product-identity.js.map +0 -1
- package/dist/src/product-loop/reality-anchor.js.map +0 -1
- package/dist/src/product-loop/repo-audit.js.map +0 -1
- package/dist/src/product-loop/role-memory.js.map +0 -1
- package/dist/src/product-loop/role-registry.js.map +0 -1
- package/dist/src/product-loop/seed-questions.js.map +0 -1
- package/dist/src/product-loop/ship-polish.js.map +0 -1
- package/dist/src/product-loop/sprint-runner.js.map +0 -1
- package/dist/src/product-loop/stakeholder-acl.js.map +0 -1
- package/dist/src/product-loop/typed-artifacts.js.map +0 -1
- package/dist/src/product-loop/types.js.map +0 -1
- package/dist/src/product-loop/verify-failure-tracking.js.map +0 -1
- package/dist/src/product-loop/verify-result.js.map +0 -1
- package/dist/src/providers/__test-utils__/load-fixture.js.map +0 -1
- package/dist/src/providers/__tests__/adapter-oauth-wiring.test.js.map +0 -1
- package/dist/src/providers/__tests__/capabilities-cosmetic.test.js.map +0 -1
- package/dist/src/providers/__tests__/capabilities-flags.test.js.map +0 -1
- package/dist/src/providers/__tests__/capabilities-provider-options.test.js.map +0 -1
- package/dist/src/providers/__tests__/capabilities-sanitize.test.js.map +0 -1
- package/dist/src/providers/__tests__/capabilities.test.js.map +0 -1
- package/dist/src/providers/__tests__/provider-coverage.test.js.map +0 -1
- package/dist/src/providers/__tests__/runtime-integration.test.js.map +0 -1
- package/dist/src/providers/__tests__/runtime.test.js.map +0 -1
- package/dist/src/providers/__tests__/siliconflow-history.test.js +0 -76
- package/dist/src/providers/__tests__/siliconflow-history.test.js.map +0 -1
- package/dist/src/providers/__tests__/strategies-registry.test.js.map +0 -1
- package/dist/src/providers/__tests__/strategies-resolve.test.js.map +0 -1
- package/dist/src/providers/__tests__/wire-debug.test.js.map +0 -1
- package/dist/src/providers/adapter.js.map +0 -1
- package/dist/src/providers/adapter.test.js.map +0 -1
- package/dist/src/providers/anthropic.js.map +0 -1
- package/dist/src/providers/auth/__tests__/browser-flow.test.js.map +0 -1
- package/dist/src/providers/auth/__tests__/device-flow.test.js.map +0 -1
- package/dist/src/providers/auth/__tests__/gemini-oauth.test.js.map +0 -1
- package/dist/src/providers/auth/__tests__/openai-oauth.test.js.map +0 -1
- package/dist/src/providers/auth/__tests__/token-store.test.js.map +0 -1
- package/dist/src/providers/auth/browser-flow.js.map +0 -1
- package/dist/src/providers/auth/device-flow.js.map +0 -1
- package/dist/src/providers/auth/gemini-oauth.js.map +0 -1
- package/dist/src/providers/auth/openai-oauth.js.map +0 -1
- package/dist/src/providers/auth/registry.js.map +0 -1
- package/dist/src/providers/auth/token-store.js.map +0 -1
- package/dist/src/providers/auth/types.js.map +0 -1
- package/dist/src/providers/capabilities.js.map +0 -1
- package/dist/src/providers/endpoints.js.map +0 -1
- package/dist/src/providers/errors.js.map +0 -1
- package/dist/src/providers/errors.test.js.map +0 -1
- package/dist/src/providers/gemini.js.map +0 -1
- package/dist/src/providers/gemini.test.js.map +0 -1
- package/dist/src/providers/index.js.map +0 -1
- package/dist/src/providers/keychain.js.map +0 -1
- package/dist/src/providers/keychain.test.js.map +0 -1
- package/dist/src/providers/mcp-vision-bridge.js.map +0 -1
- package/dist/src/providers/mcp-vision-bridge.test.js.map +0 -1
- package/dist/src/providers/ollama.js.map +0 -1
- package/dist/src/providers/ollama.test.js.map +0 -1
- package/dist/src/providers/openai-compatible.js.map +0 -1
- package/dist/src/providers/openai-compatible.test.js.map +0 -1
- package/dist/src/providers/openai.js.map +0 -1
- package/dist/src/providers/openai.test.js.map +0 -1
- package/dist/src/providers/patch-zod-schema.js.map +0 -1
- package/dist/src/providers/pricing.js.map +0 -1
- package/dist/src/providers/pricing.test.js.map +0 -1
- package/dist/src/providers/prompt-cache-key.spec.js.map +0 -1
- package/dist/src/providers/runtime-mock.spec.js.map +0 -1
- package/dist/src/providers/runtime.js.map +0 -1
- package/dist/src/providers/siliconflow-history.d.ts +0 -50
- package/dist/src/providers/siliconflow-history.js +0 -64
- package/dist/src/providers/siliconflow-history.js.map +0 -1
- package/dist/src/providers/strategies/anthropic.strategy.js.map +0 -1
- package/dist/src/providers/strategies/base.strategy.js.map +0 -1
- package/dist/src/providers/strategies/deepseek.strategy.js.map +0 -1
- package/dist/src/providers/strategies/google.strategy.js.map +0 -1
- package/dist/src/providers/strategies/ollama.strategy.js.map +0 -1
- package/dist/src/providers/strategies/openai.strategy.js.map +0 -1
- package/dist/src/providers/strategies/registry.js.map +0 -1
- package/dist/src/providers/strategies/siliconflow.strategy.js.map +0 -1
- package/dist/src/providers/strategies/xai.strategy.js.map +0 -1
- package/dist/src/providers/stream-loop.js.map +0 -1
- package/dist/src/providers/types.js.map +0 -1
- package/dist/src/providers/vision-proxy.js.map +0 -1
- package/dist/src/providers/vision-proxy.test.js.map +0 -1
- package/dist/src/providers/wire-debug.js.map +0 -1
- package/dist/src/router/__tests__/step-router.test.js.map +0 -1
- package/dist/src/router/classifier/grammars.js.map +0 -1
- package/dist/src/router/classifier/index.js.map +0 -1
- package/dist/src/router/classifier/index.test.js.map +0 -1
- package/dist/src/router/classifier/regex.js.map +0 -1
- package/dist/src/router/classifier/regex.test.js.map +0 -1
- package/dist/src/router/classifier/tree-sitter.js.map +0 -1
- package/dist/src/router/classifier/tree-sitter.test.js.map +0 -1
- package/dist/src/router/cold.js.map +0 -1
- package/dist/src/router/cold.test.js.map +0 -1
- package/dist/src/router/decide.js.map +0 -1
- package/dist/src/router/decide.test.js.map +0 -1
- package/dist/src/router/health.js.map +0 -1
- package/dist/src/router/health.test.js.map +0 -1
- package/dist/src/router/provider-sentinel.js.map +0 -1
- package/dist/src/router/provider-sentinel.test.js.map +0 -1
- package/dist/src/router/step-router.js.map +0 -1
- package/dist/src/router/store.js.map +0 -1
- package/dist/src/router/types.js.map +0 -1
- package/dist/src/router/warm.js.map +0 -1
- package/dist/src/router/warm.test.js.map +0 -1
- package/dist/src/scaffold/__tests__/continuation-prompt.test.js.map +0 -1
- package/dist/src/scaffold/__tests__/continue-as-council.spec.js.map +0 -1
- package/dist/src/scaffold/__tests__/dotnet-assembly-name.test.js.map +0 -1
- package/dist/src/scaffold/__tests__/fe-scaffold-contents.test.js.map +0 -1
- package/dist/src/scaffold/__tests__/init-new.smoke.spec.js.map +0 -1
- package/dist/src/scaffold/__tests__/init-new.spec.js.map +0 -1
- package/dist/src/scaffold/__tests__/install-bb-templates.spec.js.map +0 -1
- package/dist/src/scaffold/__tests__/point-to-existing.spec.js.map +0 -1
- package/dist/src/scaffold/bb-ecosystem-apply.js.map +0 -1
- package/dist/src/scaffold/bb-quality-gate.js.map +0 -1
- package/dist/src/scaffold/continuation-prompt.js.map +0 -1
- package/dist/src/scaffold/continue-as-council.js.map +0 -1
- package/dist/src/scaffold/init-new.js.map +0 -1
- package/dist/src/scaffold/point-to-existing.js.map +0 -1
- package/dist/src/scaffold/resume-from-gate-failures.js.map +0 -1
- package/dist/src/storage/__tests__/migrations.test.js.map +0 -1
- package/dist/src/storage/__tests__/ui-interaction-log.test.js.map +0 -1
- package/dist/src/storage/atomic-io.js.map +0 -1
- package/dist/src/storage/atomic-io.test.js.map +0 -1
- package/dist/src/storage/config.js.map +0 -1
- package/dist/src/storage/config.test.js.map +0 -1
- package/dist/src/storage/db.js.map +0 -1
- package/dist/src/storage/index.js.map +0 -1
- package/dist/src/storage/interaction-log.js.map +0 -1
- package/dist/src/storage/migrations.js.map +0 -1
- package/dist/src/storage/session-dir.js.map +0 -1
- package/dist/src/storage/sessions.js.map +0 -1
- package/dist/src/storage/tool-results.js.map +0 -1
- package/dist/src/storage/transcript-view.js.map +0 -1
- package/dist/src/storage/transcript.js.map +0 -1
- package/dist/src/storage/transcript.test.js.map +0 -1
- package/dist/src/storage/ui-interaction-log.js.map +0 -1
- package/dist/src/storage/usage-cap.js.map +0 -1
- package/dist/src/storage/usage-cap.test.js.map +0 -1
- package/dist/src/storage/usage.js.map +0 -1
- package/dist/src/storage/workspaces.js.map +0 -1
- package/dist/src/tools/bash.js.map +0 -1
- package/dist/src/tools/bash.test.js.map +0 -1
- package/dist/src/tools/computer.js.map +0 -1
- package/dist/src/tools/computer.test.js.map +0 -1
- package/dist/src/tools/file-tracker.js.map +0 -1
- package/dist/src/tools/file-tracker.test.js.map +0 -1
- package/dist/src/tools/file.js.map +0 -1
- package/dist/src/tools/file.test.js.map +0 -1
- package/dist/src/tools/grep.js.map +0 -1
- package/dist/src/tools/registry.js.map +0 -1
- package/dist/src/tools/registry.test.js.map +0 -1
- package/dist/src/tools/schedule.js.map +0 -1
- package/dist/src/tools/schedule.test.js.map +0 -1
- package/dist/src/types/index.js.map +0 -1
- package/dist/src/ui/agents-modal.js.map +0 -1
- package/dist/src/ui/app.js.map +0 -1
- package/dist/src/ui/cards/__tests__/product-status-card.test.js.map +0 -1
- package/dist/src/ui/cards/product-status-card.js.map +0 -1
- package/dist/src/ui/components/SuggestionOverlay.js.map +0 -1
- package/dist/src/ui/components/Toast.js.map +0 -1
- package/dist/src/ui/components/__tests__/council-leader-bubble.test.js.map +0 -1
- package/dist/src/ui/components/__tests__/council-message-bubble.test.js.map +0 -1
- package/dist/src/ui/components/__tests__/council-phase-timeline.test.js.map +0 -1
- package/dist/src/ui/components/__tests__/council-placeholder-bubble.test.js.map +0 -1
- package/dist/src/ui/components/__tests__/council-question-card.test.js.map +0 -1
- package/dist/src/ui/components/__tests__/council-synthesis-banner.test.js.map +0 -1
- package/dist/src/ui/components/__tests__/use-pair-quote-buffer.test.js.map +0 -1
- package/dist/src/ui/components/btw-overlay.js.map +0 -1
- package/dist/src/ui/components/bubble-layout.js.map +0 -1
- package/dist/src/ui/components/code-block-truncate.js.map +0 -1
- package/dist/src/ui/components/copy-flash-banner.js.map +0 -1
- package/dist/src/ui/components/council-info-card.js.map +0 -1
- package/dist/src/ui/components/council-leader-bubble.js.map +0 -1
- package/dist/src/ui/components/council-message-bubble.js.map +0 -1
- package/dist/src/ui/components/council-phase-timeline.js.map +0 -1
- package/dist/src/ui/components/council-placeholder-bubble.js.map +0 -1
- package/dist/src/ui/components/council-question-card.js.map +0 -1
- package/dist/src/ui/components/council-status-list.js.map +0 -1
- package/dist/src/ui/components/council-synthesis-banner.js.map +0 -1
- package/dist/src/ui/components/diff-view.js.map +0 -1
- package/dist/src/ui/components/halt-recovery-card.js.map +0 -1
- package/dist/src/ui/components/hero-logo.js.map +0 -1
- package/dist/src/ui/components/init-new-form-card.js.map +0 -1
- package/dist/src/ui/components/lsp-views.js.map +0 -1
- package/dist/src/ui/components/media-views.js.map +0 -1
- package/dist/src/ui/components/message-view.js.map +0 -1
- package/dist/src/ui/components/point-to-existing-form-card.js.map +0 -1
- package/dist/src/ui/components/prompt-box.js.map +0 -1
- package/dist/src/ui/components/role-palette.js.map +0 -1
- package/dist/src/ui/components/session-header.js.map +0 -1
- package/dist/src/ui/components/slash-inline-menu.js.map +0 -1
- package/dist/src/ui/components/structured-response-view.js.map +0 -1
- package/dist/src/ui/components/tool-result-views.js.map +0 -1
- package/dist/src/ui/components/use-pair-quote-buffer.js.map +0 -1
- package/dist/src/ui/constants.js.map +0 -1
- package/dist/src/ui/hooks/use-agent-editor.js.map +0 -1
- package/dist/src/ui/hooks/use-mcp-editor.js.map +0 -1
- package/dist/src/ui/hooks/use-model-picker.js.map +0 -1
- package/dist/src/ui/hooks/useTypeahead.js.map +0 -1
- package/dist/src/ui/markdown.js.map +0 -1
- package/dist/src/ui/mcp-modal-types.js.map +0 -1
- package/dist/src/ui/mcp-modal.js.map +0 -1
- package/dist/src/ui/modals/api-key-modal.js.map +0 -1
- package/dist/src/ui/modals/connect-modal.js.map +0 -1
- package/dist/src/ui/modals/model-picker-modal.js.map +0 -1
- package/dist/src/ui/modals/sandbox-picker-modal.js.map +0 -1
- package/dist/src/ui/modals/update-modal.js.map +0 -1
- package/dist/src/ui/modals/wallet-picker-modal.js.map +0 -1
- package/dist/src/ui/plan.js.map +0 -1
- package/dist/src/ui/schedule-modal.js.map +0 -1
- package/dist/src/ui/slash/__tests__/clear.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/compact.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/cost.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/discuss.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/execute.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/expand.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/ideal.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/menu-parity.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/optimize.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/pin.test.js.map +0 -1
- package/dist/src/ui/slash/__tests__/plan.test.js.map +0 -1
- package/dist/src/ui/slash/clear.js.map +0 -1
- package/dist/src/ui/slash/compact.js.map +0 -1
- package/dist/src/ui/slash/cost.js.map +0 -1
- package/dist/src/ui/slash/council-inspect.js.map +0 -1
- package/dist/src/ui/slash/council.js.map +0 -1
- package/dist/src/ui/slash/debug.js.map +0 -1
- package/dist/src/ui/slash/discuss.js.map +0 -1
- package/dist/src/ui/slash/ee.js.map +0 -1
- package/dist/src/ui/slash/execute.js.map +0 -1
- package/dist/src/ui/slash/expand.js.map +0 -1
- package/dist/src/ui/slash/export.js.map +0 -1
- package/dist/src/ui/slash/ideal.js.map +0 -1
- package/dist/src/ui/slash/menu-items.js.map +0 -1
- package/dist/src/ui/slash/optimize.js.map +0 -1
- package/dist/src/ui/slash/pin.js.map +0 -1
- package/dist/src/ui/slash/plan.js.map +0 -1
- package/dist/src/ui/slash/registry.js.map +0 -1
- package/dist/src/ui/slash/route.js.map +0 -1
- package/dist/src/ui/slash/route.test.js.map +0 -1
- package/dist/src/ui/status-bar/index.js.map +0 -1
- package/dist/src/ui/status-bar/index.test.js.map +0 -1
- package/dist/src/ui/status-bar/store.js.map +0 -1
- package/dist/src/ui/status-bar/store.test.js.map +0 -1
- package/dist/src/ui/status-bar/tier-badge.js.map +0 -1
- package/dist/src/ui/status-bar/tier-badge.test.js.map +0 -1
- package/dist/src/ui/status-bar/usd-meter.js.map +0 -1
- package/dist/src/ui/status-bar/usd-meter.test.js.map +0 -1
- package/dist/src/ui/syntax-highlight.js.map +0 -1
- package/dist/src/ui/terminal-selection-text.js.map +0 -1
- package/dist/src/ui/theme.js.map +0 -1
- package/dist/src/ui/types.js.map +0 -1
- package/dist/src/ui/utils/color.js.map +0 -1
- package/dist/src/ui/utils/format.js.map +0 -1
- package/dist/src/ui/utils/modal.js.map +0 -1
- package/dist/src/ui/utils/text.js.map +0 -1
- package/dist/src/ui/utils/tools.js.map +0 -1
- package/dist/src/usage/__tests__/product-ledger.test.js.map +0 -1
- package/dist/src/usage/cost-log.js.map +0 -1
- package/dist/src/usage/decision-log.js.map +0 -1
- package/dist/src/usage/downgrade.js.map +0 -1
- package/dist/src/usage/downgrade.test.js.map +0 -1
- package/dist/src/usage/estimator.js.map +0 -1
- package/dist/src/usage/estimator.test.js.map +0 -1
- package/dist/src/usage/ledger.js.map +0 -1
- package/dist/src/usage/ledger.test.js.map +0 -1
- package/dist/src/usage/midstream.js.map +0 -1
- package/dist/src/usage/midstream.test.js.map +0 -1
- package/dist/src/usage/product-ledger.js.map +0 -1
- package/dist/src/usage/thresholds.js.map +0 -1
- package/dist/src/usage/thresholds.test.js.map +0 -1
- package/dist/src/usage/types.js.map +0 -1
- package/dist/src/utils/__tests__/auto-council-settings.test.js.map +0 -1
- package/dist/src/utils/__tests__/ee-logger.test.js.map +0 -1
- package/dist/src/utils/__tests__/file-lock.test.js.map +0 -1
- package/dist/src/utils/__tests__/rate-limit.test.js.map +0 -1
- package/dist/src/utils/__tests__/settings-disabled-models.test.js.map +0 -1
- package/dist/src/utils/__tests__/settings-web-research.test.js.map +0 -1
- package/dist/src/utils/__tests__/slugify.test.js.map +0 -1
- package/dist/src/utils/__tests__/visible-retry.test.js.map +0 -1
- package/dist/src/utils/at-mentions.js.map +0 -1
- package/dist/src/utils/clipboard-image.js.map +0 -1
- package/dist/src/utils/ee-logger.js.map +0 -1
- package/dist/src/utils/file-index.js.map +0 -1
- package/dist/src/utils/file-lock.js.map +0 -1
- package/dist/src/utils/git-root.js.map +0 -1
- package/dist/src/utils/host-clipboard.js.map +0 -1
- package/dist/src/utils/install-manager.js.map +0 -1
- package/dist/src/utils/install-manager.test.js.map +0 -1
- package/dist/src/utils/instructions.js.map +0 -1
- package/dist/src/utils/instructions.test.js.map +0 -1
- package/dist/src/utils/permission-mode.js.map +0 -1
- package/dist/src/utils/permission-mode.test.js.map +0 -1
- package/dist/src/utils/rate-limit.js.map +0 -1
- package/dist/src/utils/redactor.js.map +0 -1
- package/dist/src/utils/redactor.test.js.map +0 -1
- package/dist/src/utils/settings.js.map +0 -1
- package/dist/src/utils/settings.test.js.map +0 -1
- package/dist/src/utils/shell.js.map +0 -1
- package/dist/src/utils/shell.test.js.map +0 -1
- package/dist/src/utils/side-question.js.map +0 -1
- package/dist/src/utils/skills.js.map +0 -1
- package/dist/src/utils/skills.test.js.map +0 -1
- package/dist/src/utils/slugify.js.map +0 -1
- package/dist/src/utils/subagent-display.js.map +0 -1
- package/dist/src/utils/subagent-display.test.js.map +0 -1
- package/dist/src/utils/subagents-settings.test.js.map +0 -1
- package/dist/src/utils/telegram-audio-settings.test.js.map +0 -1
- package/dist/src/utils/update-checker.js.map +0 -1
- package/dist/src/utils/update-checker.test.js.map +0 -1
- package/dist/src/utils/visible-retry.js.map +0 -1
- package/dist/src/verify/__tests__/coverage-parsers.test.js.map +0 -1
- package/dist/src/verify/__tests__/dotnet-recipe.test.js.map +0 -1
- package/dist/src/verify/checkpoint.js.map +0 -1
- package/dist/src/verify/checkpoint.test.js.map +0 -1
- package/dist/src/verify/coverage-parsers.js.map +0 -1
- package/dist/src/verify/entrypoint.js.map +0 -1
- package/dist/src/verify/entrypoint.test.js.map +0 -1
- package/dist/src/verify/environment.js.map +0 -1
- package/dist/src/verify/environment.test.js.map +0 -1
- package/dist/src/verify/evidence.js.map +0 -1
- package/dist/src/verify/orchestrator.js.map +0 -1
- package/dist/src/verify/orchestrator.test.js.map +0 -1
- package/dist/src/verify/recipes.js.map +0 -1
- package/dist/src/verify/retry.js.map +0 -1
- package/dist/src/verify/runtime-prep.test.js.map +0 -1
- package/src/__test-stubs__/ee-server.ts +0 -173
- package/src/__test-stubs__/vitest-setup.ts +0 -36
- package/src/__tests__/council/bubble-layout.test.ts +0 -45
- package/src/__tests__/council/code-block-truncate.test.ts +0 -50
- package/src/__tests__/council/role-palette.test.ts +0 -66
- package/src/__tests__/first-run-wizard.test.ts +0 -9
- package/src/agent-harness/__tests__/cli-flags.spec.ts +0 -35
- package/src/agent-harness/__tests__/driver.spec.ts +0 -154
- package/src/agent-harness/__tests__/idle.spec.ts +0 -90
- package/src/agent-harness/__tests__/mock-llm.spec.ts +0 -126
- package/src/agent-harness/__tests__/mock-model.spec.ts +0 -195
- package/src/agent-harness/__tests__/predicate.spec.ts +0 -33
- package/src/agent-harness/__tests__/protocol.spec.ts +0 -62
- package/src/agent-harness/__tests__/schema.spec.ts +0 -81
- package/src/agent-harness/__tests__/selector.spec.ts +0 -82
- package/src/agent-harness/__tests__/sidechannel.spec.ts +0 -40
- package/src/agent-harness/__tests__/spec-helpers.spec.ts +0 -76
- package/src/agent-harness/index.ts +0 -24
- package/src/agent-harness/mock-model.ts +0 -394
- package/src/agent-harness/test-spawn.ts +0 -200
- package/src/billing/index.ts +0 -5
- package/src/bun-sqlite.d.ts +0 -15
- package/src/chat/__tests__/broadcast-bus.test.ts +0 -90
- package/src/chat/__tests__/channel-manager.test.ts +0 -149
- package/src/chat/__tests__/client.test.ts +0 -118
- package/src/chat/__tests__/discord-integration.test.ts +0 -162
- package/src/chat/__tests__/intent-prompt.test.ts +0 -92
- package/src/chat/__tests__/verdict-resolver.test.ts +0 -336
- package/src/chat/broadcast-bus.ts +0 -53
- package/src/chat/channel-manager.ts +0 -146
- package/src/chat/chat-keychain.ts +0 -129
- package/src/chat/factory.ts +0 -37
- package/src/chat/intent-prompt.ts +0 -72
- package/src/chat/providers/discord/client.ts +0 -91
- package/src/chat/types.ts +0 -42
- package/src/chat/verdict-constants.ts +0 -26
- package/src/chat/verdict-resolver.ts +0 -231
- package/src/cli/__tests__/bw-vault.test.ts +0 -97
- package/src/cli/__tests__/keys-bundle.test.ts +0 -46
- package/src/cli/__tests__/share-cmd.test.ts +0 -197
- package/src/cli/bw-vault.ts +0 -184
- package/src/cli/config/__tests__/model-picker.test.ts +0 -59
- package/src/cli/config/__tests__/provider-fetch.test.ts +0 -38
- package/src/cli/config/index.ts +0 -112
- package/src/cli/config/model-picker.ts +0 -193
- package/src/cli/config/provider-fetch.ts +0 -75
- package/src/cli/config/screen-council.ts +0 -245
- package/src/cli/config/screen-models.ts +0 -104
- package/src/cli/config/screen-providers.ts +0 -197
- package/src/cli/config/tui.ts +0 -153
- package/src/cli/cost-forensics.test.ts +0 -128
- package/src/cli/cost-forensics.ts +0 -264
- package/src/cli/keys-bundle.ts +0 -91
- package/src/cli/keys.test.ts +0 -104
- package/src/cli/keys.ts +0 -787
- package/src/cli/pil-report.ts +0 -202
- package/src/cli/share-cmd.ts +0 -132
- package/src/cli/usage-report.ts +0 -266
- package/src/cloud/index.ts +0 -5
- package/src/council/__tests__/accounting.test.ts +0 -72
- package/src/council/__tests__/audit-replay.test.ts +0 -344
- package/src/council/__tests__/clarifier-max-rounds.test.ts +0 -91
- package/src/council/__tests__/clarifier-options.test.ts +0 -63
- package/src/council/__tests__/cost-aware.test.ts +0 -60
- package/src/council/__tests__/debate-planner-structured.test.ts +0 -236
- package/src/council/__tests__/evaluator-metrics.test.ts +0 -513
- package/src/council/__tests__/parse-outcome-fallback.test.ts +0 -125
- package/src/council/__tests__/research-tools.test.ts +0 -239
- package/src/council/__tests__/round-tools.test.ts +0 -334
- package/src/council/__tests__/tool-trace.test.ts +0 -152
- package/src/council/__tests__/types-contract.test.ts +0 -88
- package/src/council/clarifier.ts +0 -409
- package/src/council/context.ts +0 -250
- package/src/council/debate-planner.ts +0 -264
- package/src/council/debate.ts +0 -1179
- package/src/council/executor.ts +0 -27
- package/src/council/index.ts +0 -916
- package/src/council/leader.ts +0 -262
- package/src/council/llm.ts +0 -967
- package/src/council/phase-events.ts +0 -58
- package/src/council/planner.ts +0 -303
- package/src/council/preflight.ts +0 -86
- package/src/council/prompts.ts +0 -600
- package/src/council/types.ts +0 -286
- package/src/daemon/scheduler.test.ts +0 -128
- package/src/daemon/scheduler.ts +0 -152
- package/src/ee/.gitkeep +0 -0
- package/src/ee/__tests__/bb-design.test.ts +0 -223
- package/src/ee/__tests__/pil-context-bridge.test.ts +0 -59
- package/src/ee/__tests__/pipeline.integration.test.ts +0 -193
- package/src/ee/__tests__/render-sink-wiring.test.ts +0 -89
- package/src/ee/auth.test.ts +0 -76
- package/src/ee/auth.ts +0 -80
- package/src/ee/bb-design.ts +0 -284
- package/src/ee/bb-retrieval.ts +0 -467
- package/src/ee/bridge.test.ts +0 -283
- package/src/ee/bridge.ts +0 -443
- package/src/ee/client-mode.ts +0 -161
- package/src/ee/client.test.ts +0 -171
- package/src/ee/client.ts +0 -620
- package/src/ee/council-bridge.ts +0 -89
- package/src/ee/embedding-cache.ts +0 -42
- package/src/ee/extract-session.test.ts +0 -231
- package/src/ee/extract-session.ts +0 -71
- package/src/ee/health.ts +0 -83
- package/src/ee/index.ts +0 -33
- package/src/ee/intercept.test.ts +0 -197
- package/src/ee/intercept.ts +0 -143
- package/src/ee/judge.test.ts +0 -213
- package/src/ee/judge.ts +0 -126
- package/src/ee/mistake-detector.test.ts +0 -252
- package/src/ee/mistake-detector.ts +0 -297
- package/src/ee/offline-queue.test.ts +0 -302
- package/src/ee/offline-queue.ts +0 -205
- package/src/ee/phase-outcome.test.ts +0 -107
- package/src/ee/phase-outcome.ts +0 -165
- package/src/ee/phase-tracker.test.ts +0 -175
- package/src/ee/phase-tracker.ts +0 -180
- package/src/ee/posttool.test.ts +0 -81
- package/src/ee/posttool.ts +0 -16
- package/src/ee/prompt-stale.test.ts +0 -92
- package/src/ee/prompt-stale.ts +0 -39
- package/src/ee/render.test.ts +0 -74
- package/src/ee/render.ts +0 -68
- package/src/ee/scope.test.ts +0 -112
- package/src/ee/scope.ts +0 -93
- package/src/ee/session-trajectory.test.ts +0 -139
- package/src/ee/session-trajectory.ts +0 -226
- package/src/ee/tenant.ts +0 -14
- package/src/ee/touch.test.ts +0 -73
- package/src/ee/types.ts +0 -387
- package/src/flow/.gitkeep +0 -0
- package/src/flow/__tests__/migration.test.ts +0 -133
- package/src/flow/__tests__/parser.test.ts +0 -77
- package/src/flow/__tests__/run-manager-product.test.ts +0 -59
- package/src/flow/__tests__/run-manager.test.ts +0 -95
- package/src/flow/__tests__/scaffold-checkpoint.test.ts +0 -113
- package/src/flow/__tests__/scaffold.test.ts +0 -57
- package/src/flow/__tests__/warning-persist.test.ts +0 -112
- package/src/flow/artifact-io.ts +0 -41
- package/src/flow/compaction/__tests__/compress.test.ts +0 -69
- package/src/flow/compaction/__tests__/extract.test.ts +0 -74
- package/src/flow/compaction/__tests__/preserve.test.ts +0 -69
- package/src/flow/compaction/compress.ts +0 -67
- package/src/flow/compaction/extract.ts +0 -60
- package/src/flow/compaction/index.ts +0 -86
- package/src/flow/compaction/preserve.ts +0 -48
- package/src/flow/index.ts +0 -18
- package/src/flow/migration.ts +0 -139
- package/src/flow/parser.ts +0 -78
- package/src/flow/run-manager.ts +0 -162
- package/src/flow/scaffold-checkpoint.ts +0 -132
- package/src/flow/scaffold.ts +0 -52
- package/src/flow/warning-persist.ts +0 -84
- package/src/generated/version.ts +0 -4
- package/src/gsd/.gitkeep +0 -0
- package/src/gsd/__tests__/complexity.test.ts +0 -0
- package/src/gsd/__tests__/directives.test.ts +0 -49
- package/src/gsd/__tests__/gray-areas.test.ts +0 -33
- package/src/gsd/__tests__/types.test.ts +0 -77
- package/src/gsd/complexity.ts +0 -124
- package/src/gsd/directives.ts +0 -94
- package/src/gsd/gray-areas.ts +0 -144
- package/src/gsd/index.ts +0 -1
- package/src/gsd/types.ts +0 -49
- package/src/headless/__tests__/council-answers.test.ts +0 -266
- package/src/headless/council-answers.ts +0 -130
- package/src/headless/output.test.ts +0 -201
- package/src/headless/output.ts +0 -312
- package/src/hooks/config.ts +0 -41
- package/src/hooks/index.ts +0 -547
- package/src/hooks/types.ts +0 -263
- package/src/index.ts +0 -1570
- package/src/lsp/builtins.test.ts +0 -104
- package/src/lsp/builtins.ts +0 -409
- package/src/lsp/client.ts +0 -342
- package/src/lsp/manager.test.ts +0 -164
- package/src/lsp/manager.ts +0 -293
- package/src/lsp/npm-cache.test.ts +0 -68
- package/src/lsp/npm-cache.ts +0 -108
- package/src/lsp/runtime.ts +0 -70
- package/src/lsp/smoke.test.ts +0 -74
- package/src/lsp/types.ts +0 -116
- package/src/mcp/__tests__/auto-setup.test.ts +0 -88
- package/src/mcp/__tests__/harness-driver-action-tools.spec.ts +0 -114
- package/src/mcp/__tests__/harness-driver-async-tools.spec.ts +0 -127
- package/src/mcp/__tests__/harness-driver-read-tools.spec.ts +0 -140
- package/src/mcp/__tests__/harness-driver-security.spec.ts +0 -71
- package/src/mcp/__tests__/harness-driver.spec.ts +0 -21
- package/src/mcp/__tests__/lazy-schema.spec.ts +0 -173
- package/src/mcp/__tests__/mcp-keychain.test.ts +0 -46
- package/src/mcp/__tests__/research-onboarding.test.ts +0 -163
- package/src/mcp/__tests__/runtime-hydration.test.ts +0 -86
- package/src/mcp/__tests__/runtime-sanitize.test.ts +0 -44
- package/src/mcp/auto-setup.ts +0 -99
- package/src/mcp/catalog.ts +0 -155
- package/src/mcp/mcp-keychain.ts +0 -77
- package/src/mcp/oauth-callback.ts +0 -75
- package/src/mcp/oauth-provider.ts +0 -128
- package/src/mcp/opentui-spawn.ts +0 -64
- package/src/mcp/parse-headers.test.ts +0 -54
- package/src/mcp/parse-headers.ts +0 -35
- package/src/mcp/research-onboarding.ts +0 -143
- package/src/mcp/runtime.ts +0 -171
- package/src/mcp/smoke.test.ts +0 -170
- package/src/mcp/validate.ts +0 -48
- package/src/models/__tests__/registry.test.ts +0 -95
- package/src/models/catalog-client.ts +0 -140
- package/src/models/catalog.README.md +0 -136
- package/src/models/catalog.json +0 -177
- package/src/models/classify-tier.ts +0 -48
- package/src/models/index.ts +0 -9
- package/src/models/registry.ts +0 -77
- package/src/ops/__tests__/doctor-council-mcp.test.ts +0 -161
- package/src/ops/__tests__/doctor-ee-health.test.ts +0 -129
- package/src/ops/bug-report.test.ts +0 -172
- package/src/ops/bug-report.ts +0 -80
- package/src/ops/doctor.test.ts +0 -108
- package/src/ops/doctor.ts +0 -366
- package/src/orchestrator/__tests__/batch-turn-runner.test.ts +0 -178
- package/src/orchestrator/__tests__/council-manager.test.ts +0 -171
- package/src/orchestrator/__tests__/cross-turn-dedup.test.ts +0 -174
- package/src/orchestrator/__tests__/current-call-id.test.ts +0 -160
- package/src/orchestrator/__tests__/flow-resume.test.ts +0 -71
- package/src/orchestrator/__tests__/message-processor.test.ts +0 -196
- package/src/orchestrator/__tests__/message-write-ahead.test.ts +0 -170
- package/src/orchestrator/__tests__/read-path-budget.test.ts +0 -107
- package/src/orchestrator/__tests__/retry-classifier.test.ts +0 -120
- package/src/orchestrator/__tests__/retry-stream.test.ts +0 -186
- package/src/orchestrator/__tests__/route-feedback.test.ts +0 -55
- package/src/orchestrator/__tests__/stream-runner.test.ts +0 -123
- package/src/orchestrator/__tests__/usage-events-shape.test.ts +0 -80
- package/src/orchestrator/__tests__/usage-normalizer-c1.test.ts +0 -172
- package/src/orchestrator/__tests__/write-ahead.test.ts +0 -162
- package/src/orchestrator/abort.test.ts +0 -37
- package/src/orchestrator/abort.ts +0 -51
- package/src/orchestrator/agent-options.ts +0 -168
- package/src/orchestrator/agent.test.ts +0 -184
- package/src/orchestrator/batch-turn-runner.ts +0 -425
- package/src/orchestrator/batch-utils.ts +0 -340
- package/src/orchestrator/cleanup.test.ts +0 -86
- package/src/orchestrator/compaction.test.ts +0 -181
- package/src/orchestrator/compaction.ts +0 -613
- package/src/orchestrator/council-manager.ts +0 -580
- package/src/orchestrator/cross-turn-dedup.ts +0 -187
- package/src/orchestrator/delegations.test.ts +0 -145
- package/src/orchestrator/delegations.ts +0 -364
- package/src/orchestrator/error-utils.ts +0 -72
- package/src/orchestrator/flow-resume.ts +0 -54
- package/src/orchestrator/message-processor.ts +0 -1985
- package/src/orchestrator/message-seq.test.ts +0 -29
- package/src/orchestrator/message-seq.ts +0 -19
- package/src/orchestrator/orchestrator.ts +0 -2641
- package/src/orchestrator/pending-calls.test.ts +0 -226
- package/src/orchestrator/pending-calls.ts +0 -240
- package/src/orchestrator/prompts.ts +0 -482
- package/src/orchestrator/provider-options-shape.spec.ts +0 -67
- package/src/orchestrator/provider-options-shape.ts +0 -70
- package/src/orchestrator/read-path-budget.ts +0 -128
- package/src/orchestrator/reasoning.test.ts +0 -29
- package/src/orchestrator/reasoning.ts +0 -69
- package/src/orchestrator/retry-classifier.ts +0 -131
- package/src/orchestrator/retry-stream.ts +0 -159
- package/src/orchestrator/sandbox.test.ts +0 -115
- package/src/orchestrator/stream-runner.ts +0 -729
- package/src/orchestrator/sub-agent-cap.test.ts +0 -186
- package/src/orchestrator/sub-agent-cap.ts +0 -218
- package/src/orchestrator/subagent-compactor.spec.ts +0 -144
- package/src/orchestrator/subagent-compactor.ts +0 -242
- package/src/orchestrator/token-counter.test.ts +0 -69
- package/src/orchestrator/token-counter.ts +0 -81
- package/src/orchestrator/tool-utils.ts +0 -214
- package/src/orchestrator/turn-runner-deps.ts +0 -83
- package/src/pil/__tests__/budget.test.ts +0 -39
- package/src/pil/__tests__/config.test.ts +0 -32
- package/src/pil/__tests__/dual-run.test.ts +0 -53
- package/src/pil/__tests__/layer1-intent-trace.test.ts +0 -140
- package/src/pil/__tests__/layer1-intent.test.ts +0 -346
- package/src/pil/__tests__/layer2-personality.test.ts +0 -63
- package/src/pil/__tests__/layer3-ee-injection.test.ts +0 -181
- package/src/pil/__tests__/layer3-injected-chunk.test.ts +0 -122
- package/src/pil/__tests__/layer4-gsd.test.ts +0 -109
- package/src/pil/__tests__/layer5-context.test.ts +0 -157
- package/src/pil/__tests__/layer6-output.test.ts +0 -284
- package/src/pil/__tests__/ollama-classify.test.ts +0 -81
- package/src/pil/__tests__/orchestrator-integration.test.ts +0 -107
- package/src/pil/__tests__/pipeline.test.ts +0 -190
- package/src/pil/__tests__/renderer-coverage.test.ts +0 -46
- package/src/pil/__tests__/response-tools.test.ts +0 -174
- package/src/pil/__tests__/schema.test.ts +0 -233
- package/src/pil/__tests__/scoreComplexity.test.ts +0 -134
- package/src/pil/__tests__/scoreSufficiency.test.ts +0 -104
- package/src/pil/__tests__/store.test.ts +0 -49
- package/src/pil/__tests__/task-tier-map.test.ts +0 -41
- package/src/pil/budget-log.ts +0 -86
- package/src/pil/budget.ts +0 -18
- package/src/pil/config.ts +0 -11
- package/src/pil/index.ts +0 -12
- package/src/pil/layer1-intent.test.ts +0 -127
- package/src/pil/layer1-intent.ts +0 -580
- package/src/pil/layer2-personality.ts +0 -46
- package/src/pil/layer3-ee-injection.ts +0 -345
- package/src/pil/layer4-gsd.ts +0 -118
- package/src/pil/layer5-context.ts +0 -160
- package/src/pil/layer6-output.ts +0 -260
- package/src/pil/ollama-classify.ts +0 -49
- package/src/pil/pipeline.ts +0 -207
- package/src/pil/response-tools.ts +0 -110
- package/src/pil/schema.ts +0 -103
- package/src/pil/store.ts +0 -29
- package/src/pil/task-tier-map.ts +0 -90
- package/src/pil/timeout.ts +0 -10
- package/src/pil/types.ts +0 -150
- package/src/product-loop/__tests__/artifact-io.test.ts +0 -97
- package/src/product-loop/__tests__/assumption-ledger.test.ts +0 -292
- package/src/product-loop/__tests__/cb2-retry-bonus.test.ts +0 -182
- package/src/product-loop/__tests__/circuit-breakers-coverage.test.ts +0 -82
- package/src/product-loop/__tests__/circuit-breakers.test.ts +0 -90
- package/src/product-loop/__tests__/complexity-routing.spec.ts +0 -169
- package/src/product-loop/__tests__/context-policy.test.ts +0 -280
- package/src/product-loop/__tests__/cost-preview.test.ts +0 -118
- package/src/product-loop/__tests__/cost-scoper.test.ts +0 -76
- package/src/product-loop/__tests__/cross-run-memory.test.ts +0 -195
- package/src/product-loop/__tests__/design-output.spec.ts +0 -39
- package/src/product-loop/__tests__/discover.test.ts +0 -98
- package/src/product-loop/__tests__/discovery-council-runner.test.ts +0 -13
- package/src/product-loop/__tests__/discovery-detection.test.ts +0 -180
- package/src/product-loop/__tests__/discovery-ecosystem.test.ts +0 -132
- package/src/product-loop/__tests__/discovery-integration.test.ts +0 -133
- package/src/product-loop/__tests__/discovery-interview.test.ts +0 -305
- package/src/product-loop/__tests__/discovery-migrations.test.ts +0 -75
- package/src/product-loop/__tests__/discovery-persistence.test.ts +0 -171
- package/src/product-loop/__tests__/discovery-prompt-parser.test.ts +0 -77
- package/src/product-loop/__tests__/discovery-recommender-ecosystem.test.ts +0 -94
- package/src/product-loop/__tests__/discovery-recommender.test.ts +0 -382
- package/src/product-loop/__tests__/discovery-schema.test.ts +0 -102
- package/src/product-loop/__tests__/done-gate-coverage.test.ts +0 -151
- package/src/product-loop/__tests__/done-gate.test.ts +0 -140
- package/src/product-loop/__tests__/ee-extract-wiring.test.ts +0 -216
- package/src/product-loop/__tests__/extract-to-ee.test.ts +0 -205
- package/src/product-loop/__tests__/feedback-routing.test.ts +0 -93
- package/src/product-loop/__tests__/hot-path.spec.ts +0 -177
- package/src/product-loop/__tests__/integration.test.ts +0 -344
- package/src/product-loop/__tests__/loop-driver-audit.test.ts +0 -321
- package/src/product-loop/__tests__/loop-driver.test.ts +0 -247
- package/src/product-loop/__tests__/phase-budget.test.ts +0 -172
- package/src/product-loop/__tests__/phase-orchestrator-integration.test.ts +0 -143
- package/src/product-loop/__tests__/phase-plan.test.ts +0 -241
- package/src/product-loop/__tests__/phase-rituals.test.ts +0 -211
- package/src/product-loop/__tests__/phase-runner.test.ts +0 -454
- package/src/product-loop/__tests__/phase-tracker-bridge.test.ts +0 -85
- package/src/product-loop/__tests__/product-identity.test.ts +0 -47
- package/src/product-loop/__tests__/reality-anchor.test.ts +0 -58
- package/src/product-loop/__tests__/repo-audit.test.ts +0 -103
- package/src/product-loop/__tests__/role-memory.test.ts +0 -70
- package/src/product-loop/__tests__/role-registry.test.ts +0 -235
- package/src/product-loop/__tests__/role-routing-ee.test.ts +0 -90
- package/src/product-loop/__tests__/route-decision-emit.test.ts +0 -207
- package/src/product-loop/__tests__/seed-questions.test.ts +0 -33
- package/src/product-loop/__tests__/ship-polish.test.ts +0 -109
- package/src/product-loop/__tests__/sprint-runner-emit.test.ts +0 -324
- package/src/product-loop/__tests__/sprint-runner.test.ts +0 -501
- package/src/product-loop/__tests__/stakeholder-acl.test.ts +0 -94
- package/src/product-loop/__tests__/state-md-ee-injections.test.ts +0 -229
- package/src/product-loop/__tests__/sufficiency-routing.spec.ts +0 -177
- package/src/product-loop/__tests__/typed-artifacts.test.ts +0 -261
- package/src/product-loop/__tests__/types.test.ts +0 -103
- package/src/product-loop/__tests__/verify-failure-threshold.test.ts +0 -177
- package/src/product-loop/__tests__/verify-failure-tracking.test.ts +0 -154
- package/src/product-loop/__tests__/verify-result.test.ts +0 -60
- package/src/product-loop/artifact-io.ts +0 -239
- package/src/product-loop/assumption-ledger.ts +0 -270
- package/src/product-loop/circuit-breakers.ts +0 -76
- package/src/product-loop/context-policy.ts +0 -180
- package/src/product-loop/cost-preview.ts +0 -124
- package/src/product-loop/cost-scoper.ts +0 -49
- package/src/product-loop/cross-run-memory.ts +0 -450
- package/src/product-loop/design-output.ts +0 -24
- package/src/product-loop/discover.ts +0 -159
- package/src/product-loop/discovery-context-format.ts +0 -32
- package/src/product-loop/discovery-council-runner.ts +0 -82
- package/src/product-loop/discovery-detection.ts +0 -161
- package/src/product-loop/discovery-ecosystem.ts +0 -124
- package/src/product-loop/discovery-interview.ts +0 -237
- package/src/product-loop/discovery-migrations.ts +0 -40
- package/src/product-loop/discovery-persistence.ts +0 -219
- package/src/product-loop/discovery-prompt-parser.ts +0 -80
- package/src/product-loop/discovery-recommender.ts +0 -366
- package/src/product-loop/discovery-schema.ts +0 -143
- package/src/product-loop/done-gate.ts +0 -224
- package/src/product-loop/feedback-routing.ts +0 -82
- package/src/product-loop/gather.ts +0 -304
- package/src/product-loop/index.ts +0 -1305
- package/src/product-loop/loop-driver.ts +0 -901
- package/src/product-loop/phase-budget.ts +0 -182
- package/src/product-loop/phase-plan.ts +0 -158
- package/src/product-loop/phase-rituals.ts +0 -158
- package/src/product-loop/phase-runner.ts +0 -455
- package/src/product-loop/phase-tracker-bridge.ts +0 -60
- package/src/product-loop/product-identity.ts +0 -11
- package/src/product-loop/reality-anchor.ts +0 -45
- package/src/product-loop/repo-audit.ts +0 -314
- package/src/product-loop/role-memory.ts +0 -72
- package/src/product-loop/role-registry.ts +0 -175
- package/src/product-loop/seed-questions.ts +0 -51
- package/src/product-loop/ship-polish.ts +0 -164
- package/src/product-loop/sprint-runner.ts +0 -610
- package/src/product-loop/stakeholder-acl.ts +0 -82
- package/src/product-loop/typed-artifacts.ts +0 -332
- package/src/product-loop/types.ts +0 -443
- package/src/product-loop/verify-failure-tracking.ts +0 -225
- package/src/product-loop/verify-result.ts +0 -39
- package/src/providers/.gitkeep +0 -0
- package/src/providers/__test-utils__/load-fixture.ts +0 -36
- package/src/providers/__tests__/adapter-oauth-wiring.test.ts +0 -129
- package/src/providers/__tests__/capabilities-cosmetic.test.ts +0 -119
- package/src/providers/__tests__/capabilities-flags.test.ts +0 -166
- package/src/providers/__tests__/capabilities-provider-options.test.ts +0 -203
- package/src/providers/__tests__/capabilities-sanitize.test.ts +0 -82
- package/src/providers/__tests__/capabilities.test.ts +0 -44
- package/src/providers/__tests__/provider-coverage.test.ts +0 -48
- package/src/providers/__tests__/runtime-integration.test.ts +0 -97
- package/src/providers/__tests__/runtime.test.ts +0 -96
- package/src/providers/__tests__/siliconflow-history.test.ts +0 -82
- package/src/providers/__tests__/strategies-registry.test.ts +0 -55
- package/src/providers/__tests__/strategies-resolve.test.ts +0 -137
- package/src/providers/__tests__/wire-debug.test.ts +0 -42
- package/src/providers/adapter.test.ts +0 -21
- package/src/providers/adapter.ts +0 -156
- package/src/providers/anthropic.ts +0 -174
- package/src/providers/auth/__tests__/browser-flow.test.ts +0 -235
- package/src/providers/auth/__tests__/device-flow.test.ts +0 -263
- package/src/providers/auth/__tests__/gemini-oauth.test.ts +0 -387
- package/src/providers/auth/__tests__/openai-oauth.test.ts +0 -378
- package/src/providers/auth/__tests__/token-store.test.ts +0 -152
- package/src/providers/auth/browser-flow.ts +0 -140
- package/src/providers/auth/device-flow.ts +0 -221
- package/src/providers/auth/gemini-oauth.ts +0 -351
- package/src/providers/auth/openai-oauth.ts +0 -455
- package/src/providers/auth/registry.ts +0 -121
- package/src/providers/auth/token-store.ts +0 -154
- package/src/providers/auth/types.ts +0 -111
- package/src/providers/capabilities.ts +0 -351
- package/src/providers/endpoints.ts +0 -68
- package/src/providers/errors.test.ts +0 -76
- package/src/providers/errors.ts +0 -46
- package/src/providers/gemini.test.ts +0 -46
- package/src/providers/gemini.ts +0 -42
- package/src/providers/index.ts +0 -28
- package/src/providers/keychain.test.ts +0 -100
- package/src/providers/keychain.ts +0 -267
- package/src/providers/mcp-vision-bridge.test.ts +0 -513
- package/src/providers/mcp-vision-bridge.ts +0 -1020
- package/src/providers/ollama.test.ts +0 -46
- package/src/providers/ollama.ts +0 -36
- package/src/providers/openai-compatible.test.ts +0 -63
- package/src/providers/openai-compatible.ts +0 -58
- package/src/providers/openai.test.ts +0 -65
- package/src/providers/openai.ts +0 -56
- package/src/providers/patch-zod-schema.ts +0 -126
- package/src/providers/pricing.test.ts +0 -65
- package/src/providers/pricing.ts +0 -111
- package/src/providers/prompt-cache-key.spec.ts +0 -28
- package/src/providers/runtime-mock.spec.ts +0 -86
- package/src/providers/runtime.ts +0 -283
- package/src/providers/siliconflow-history.ts +0 -74
- package/src/providers/strategies/anthropic.strategy.ts +0 -25
- package/src/providers/strategies/base.strategy.ts +0 -76
- package/src/providers/strategies/deepseek.strategy.ts +0 -26
- package/src/providers/strategies/google.strategy.ts +0 -28
- package/src/providers/strategies/ollama.strategy.ts +0 -22
- package/src/providers/strategies/openai.strategy.ts +0 -55
- package/src/providers/strategies/registry.ts +0 -43
- package/src/providers/strategies/siliconflow.strategy.ts +0 -26
- package/src/providers/strategies/xai.strategy.ts +0 -26
- package/src/providers/stream-loop.ts +0 -83
- package/src/providers/types.ts +0 -145
- package/src/providers/vision-proxy.test.ts +0 -252
- package/src/providers/vision-proxy.ts +0 -317
- package/src/providers/wire-debug.ts +0 -163
- package/src/router/.gitkeep +0 -0
- package/src/router/__tests__/step-router.test.ts +0 -150
- package/src/router/classifier/grammars.ts +0 -17
- package/src/router/classifier/index.test.ts +0 -33
- package/src/router/classifier/index.ts +0 -21
- package/src/router/classifier/regex.test.ts +0 -49
- package/src/router/classifier/regex.ts +0 -113
- package/src/router/classifier/tree-sitter.test.ts +0 -26
- package/src/router/classifier/tree-sitter.ts +0 -87
- package/src/router/cold.test.ts +0 -62
- package/src/router/cold.ts +0 -27
- package/src/router/decide.test.ts +0 -147
- package/src/router/decide.ts +0 -472
- package/src/router/health.test.ts +0 -59
- package/src/router/health.ts +0 -49
- package/src/router/provider-sentinel.test.ts +0 -22
- package/src/router/provider-sentinel.ts +0 -20
- package/src/router/step-router.ts +0 -194
- package/src/router/store.ts +0 -47
- package/src/router/types.ts +0 -20
- package/src/router/warm.test.ts +0 -168
- package/src/router/warm.ts +0 -53
- package/src/scaffold/__tests__/continuation-prompt.test.ts +0 -93
- package/src/scaffold/__tests__/continue-as-council.spec.ts +0 -124
- package/src/scaffold/__tests__/dotnet-assembly-name.test.ts +0 -28
- package/src/scaffold/__tests__/fe-scaffold-contents.test.ts +0 -127
- package/src/scaffold/__tests__/init-new.smoke.spec.ts +0 -99
- package/src/scaffold/__tests__/init-new.spec.ts +0 -450
- package/src/scaffold/__tests__/install-bb-templates.spec.ts +0 -86
- package/src/scaffold/__tests__/point-to-existing.spec.ts +0 -114
- package/src/scaffold/bb-ecosystem-apply.ts +0 -454
- package/src/scaffold/bb-quality-gate.ts +0 -287
- package/src/scaffold/continuation-prompt.ts +0 -80
- package/src/scaffold/continue-as-council.ts +0 -99
- package/src/scaffold/init-new.ts +0 -1691
- package/src/scaffold/point-to-existing.ts +0 -83
- package/src/scaffold/resume-from-gate-failures.ts +0 -167
- package/src/storage/__tests__/migrations.test.ts +0 -395
- package/src/storage/__tests__/ui-interaction-log.test.ts +0 -105
- package/src/storage/atomic-io.test.ts +0 -92
- package/src/storage/atomic-io.ts +0 -160
- package/src/storage/config.test.ts +0 -33
- package/src/storage/config.ts +0 -53
- package/src/storage/db.ts +0 -184
- package/src/storage/index.ts +0 -26
- package/src/storage/interaction-log.ts +0 -121
- package/src/storage/migrations.ts +0 -205
- package/src/storage/session-dir.ts +0 -37
- package/src/storage/sessions.ts +0 -206
- package/src/storage/tool-results.ts +0 -56
- package/src/storage/transcript-view.ts +0 -45
- package/src/storage/transcript.test.ts +0 -24
- package/src/storage/transcript.ts +0 -561
- package/src/storage/ui-interaction-log.ts +0 -160
- package/src/storage/usage-cap.test.ts +0 -59
- package/src/storage/usage-cap.ts +0 -81
- package/src/storage/usage.ts +0 -117
- package/src/storage/workspaces.ts +0 -84
- package/src/tools/bash.test.ts +0 -363
- package/src/tools/bash.ts +0 -668
- package/src/tools/computer.test.ts +0 -187
- package/src/tools/computer.ts +0 -632
- package/src/tools/file-tracker.test.ts +0 -99
- package/src/tools/file-tracker.ts +0 -70
- package/src/tools/file.test.ts +0 -95
- package/src/tools/file.ts +0 -182
- package/src/tools/grep.ts +0 -187
- package/src/tools/registry.test.ts +0 -38
- package/src/tools/registry.ts +0 -388
- package/src/tools/schedule.test.ts +0 -143
- package/src/tools/schedule.ts +0 -610
- package/src/types/index.ts +0 -474
- package/src/ui/agents-modal.tsx +0 -292
- package/src/ui/app.tsx +0 -6464
- package/src/ui/cards/__tests__/product-status-card.test.ts +0 -30
- package/src/ui/cards/product-status-card.tsx +0 -117
- package/src/ui/components/SuggestionOverlay.tsx +0 -38
- package/src/ui/components/Toast.tsx +0 -100
- package/src/ui/components/__tests__/council-leader-bubble.test.ts +0 -16
- package/src/ui/components/__tests__/council-message-bubble.test.ts +0 -85
- package/src/ui/components/__tests__/council-phase-timeline.test.ts +0 -57
- package/src/ui/components/__tests__/council-placeholder-bubble.test.ts +0 -16
- package/src/ui/components/__tests__/council-question-card.test.ts +0 -133
- package/src/ui/components/__tests__/council-synthesis-banner.test.ts +0 -12
- package/src/ui/components/__tests__/use-pair-quote-buffer.test.ts +0 -41
- package/src/ui/components/btw-overlay.tsx +0 -66
- package/src/ui/components/bubble-layout.ts +0 -66
- package/src/ui/components/code-block-truncate.ts +0 -24
- package/src/ui/components/copy-flash-banner.tsx +0 -31
- package/src/ui/components/council-info-card.tsx +0 -45
- package/src/ui/components/council-leader-bubble.tsx +0 -41
- package/src/ui/components/council-message-bubble.tsx +0 -111
- package/src/ui/components/council-phase-timeline.tsx +0 -91
- package/src/ui/components/council-placeholder-bubble.tsx +0 -65
- package/src/ui/components/council-question-card.tsx +0 -253
- package/src/ui/components/council-status-list.tsx +0 -111
- package/src/ui/components/council-synthesis-banner.tsx +0 -37
- package/src/ui/components/diff-view.tsx +0 -225
- package/src/ui/components/halt-recovery-card.tsx +0 -83
- package/src/ui/components/hero-logo.tsx +0 -62
- package/src/ui/components/init-new-form-card.tsx +0 -470
- package/src/ui/components/lsp-views.tsx +0 -104
- package/src/ui/components/media-views.tsx +0 -66
- package/src/ui/components/message-view.tsx +0 -343
- package/src/ui/components/point-to-existing-form-card.tsx +0 -136
- package/src/ui/components/prompt-box.tsx +0 -306
- package/src/ui/components/role-palette.ts +0 -62
- package/src/ui/components/session-header.tsx +0 -68
- package/src/ui/components/slash-inline-menu.tsx +0 -63
- package/src/ui/components/structured-response-view.tsx +0 -191
- package/src/ui/components/tool-result-views.tsx +0 -258
- package/src/ui/components/use-pair-quote-buffer.ts +0 -23
- package/src/ui/constants.ts +0 -242
- package/src/ui/hooks/use-agent-editor.ts +0 -64
- package/src/ui/hooks/use-mcp-editor.ts +0 -39
- package/src/ui/hooks/use-model-picker.ts +0 -50
- package/src/ui/hooks/useTypeahead.ts +0 -160
- package/src/ui/markdown.tsx +0 -49
- package/src/ui/mcp-modal-types.ts +0 -33
- package/src/ui/mcp-modal.tsx +0 -484
- package/src/ui/modals/api-key-modal.tsx +0 -99
- package/src/ui/modals/connect-modal.tsx +0 -259
- package/src/ui/modals/model-picker-modal.tsx +0 -323
- package/src/ui/modals/sandbox-picker-modal.tsx +0 -99
- package/src/ui/modals/update-modal.tsx +0 -67
- package/src/ui/modals/wallet-picker-modal.tsx +0 -186
- package/src/ui/plan.tsx +0 -346
- package/src/ui/schedule-modal.tsx +0 -138
- package/src/ui/slash/__tests__/clear.test.ts +0 -86
- package/src/ui/slash/__tests__/compact.test.ts +0 -56
- package/src/ui/slash/__tests__/cost.test.ts +0 -62
- package/src/ui/slash/__tests__/discuss.test.ts +0 -101
- package/src/ui/slash/__tests__/execute.test.ts +0 -86
- package/src/ui/slash/__tests__/expand.test.ts +0 -86
- package/src/ui/slash/__tests__/ideal.test.ts +0 -134
- package/src/ui/slash/__tests__/menu-parity.test.ts +0 -43
- package/src/ui/slash/__tests__/optimize.test.ts +0 -155
- package/src/ui/slash/__tests__/pin.test.ts +0 -47
- package/src/ui/slash/__tests__/plan.test.ts +0 -95
- package/src/ui/slash/clear.ts +0 -89
- package/src/ui/slash/compact.ts +0 -46
- package/src/ui/slash/cost.ts +0 -63
- package/src/ui/slash/council-inspect.ts +0 -188
- package/src/ui/slash/council.ts +0 -30
- package/src/ui/slash/debug.ts +0 -153
- package/src/ui/slash/discuss.ts +0 -71
- package/src/ui/slash/ee.ts +0 -304
- package/src/ui/slash/execute.ts +0 -44
- package/src/ui/slash/expand.ts +0 -51
- package/src/ui/slash/export.ts +0 -281
- package/src/ui/slash/ideal.ts +0 -254
- package/src/ui/slash/menu-items.ts +0 -106
- package/src/ui/slash/optimize.ts +0 -47
- package/src/ui/slash/pin.ts +0 -41
- package/src/ui/slash/plan.ts +0 -62
- package/src/ui/slash/registry.ts +0 -47
- package/src/ui/slash/route.test.ts +0 -82
- package/src/ui/slash/route.ts +0 -43
- package/src/ui/status-bar/index.test.tsx +0 -90
- package/src/ui/status-bar/index.tsx +0 -98
- package/src/ui/status-bar/store.test.ts +0 -131
- package/src/ui/status-bar/store.ts +0 -186
- package/src/ui/status-bar/tier-badge.test.tsx +0 -38
- package/src/ui/status-bar/tier-badge.tsx +0 -29
- package/src/ui/status-bar/usd-meter.test.tsx +0 -37
- package/src/ui/status-bar/usd-meter.tsx +0 -22
- package/src/ui/syntax-highlight.ts +0 -627
- package/src/ui/terminal-selection-text.ts +0 -72
- package/src/ui/theme.ts +0 -95
- package/src/ui/types.ts +0 -83
- package/src/ui/utils/color.ts +0 -19
- package/src/ui/utils/format.ts +0 -86
- package/src/ui/utils/modal.ts +0 -9
- package/src/ui/utils/text.ts +0 -31
- package/src/ui/utils/tools.ts +0 -95
- package/src/usage/.gitkeep +0 -0
- package/src/usage/__tests__/product-ledger.test.ts +0 -85
- package/src/usage/cost-log.ts +0 -158
- package/src/usage/decision-log.ts +0 -86
- package/src/usage/downgrade.test.ts +0 -82
- package/src/usage/downgrade.ts +0 -70
- package/src/usage/estimator.test.ts +0 -43
- package/src/usage/estimator.ts +0 -58
- package/src/usage/ledger.test.ts +0 -200
- package/src/usage/ledger.ts +0 -253
- package/src/usage/midstream.test.ts +0 -55
- package/src/usage/midstream.ts +0 -51
- package/src/usage/product-ledger.ts +0 -111
- package/src/usage/thresholds.test.ts +0 -83
- package/src/usage/thresholds.ts +0 -74
- package/src/usage/types.ts +0 -41
- package/src/utils/__tests__/auto-council-settings.test.ts +0 -46
- package/src/utils/__tests__/ee-logger.test.ts +0 -197
- package/src/utils/__tests__/file-lock.test.ts +0 -74
- package/src/utils/__tests__/rate-limit.test.ts +0 -42
- package/src/utils/__tests__/settings-disabled-models.test.ts +0 -113
- package/src/utils/__tests__/settings-web-research.test.ts +0 -45
- package/src/utils/__tests__/slugify.test.ts +0 -45
- package/src/utils/__tests__/visible-retry.test.ts +0 -195
- package/src/utils/at-mentions.ts +0 -120
- package/src/utils/clipboard-image.ts +0 -139
- package/src/utils/ee-logger.ts +0 -163
- package/src/utils/file-index.ts +0 -152
- package/src/utils/file-lock.ts +0 -66
- package/src/utils/git-root.ts +0 -17
- package/src/utils/host-clipboard.ts +0 -68
- package/src/utils/install-manager.test.ts +0 -167
- package/src/utils/install-manager.ts +0 -429
- package/src/utils/instructions.test.ts +0 -112
- package/src/utils/instructions.ts +0 -149
- package/src/utils/permission-mode.test.ts +0 -121
- package/src/utils/permission-mode.ts +0 -37
- package/src/utils/rate-limit.ts +0 -21
- package/src/utils/redactor.test.ts +0 -100
- package/src/utils/redactor.ts +0 -223
- package/src/utils/settings.test.ts +0 -181
- package/src/utils/settings.ts +0 -1108
- package/src/utils/shell.test.ts +0 -72
- package/src/utils/shell.ts +0 -193
- package/src/utils/side-question.ts +0 -39
- package/src/utils/skills.test.ts +0 -58
- package/src/utils/skills.ts +0 -207
- package/src/utils/slugify.ts +0 -9
- package/src/utils/subagent-display.test.ts +0 -23
- package/src/utils/subagent-display.ts +0 -11
- package/src/utils/subagents-settings.test.ts +0 -77
- package/src/utils/telegram-audio-settings.test.ts +0 -44
- package/src/utils/update-checker.test.ts +0 -182
- package/src/utils/update-checker.ts +0 -33
- package/src/utils/visible-retry.ts +0 -56
- package/src/verify/__tests__/coverage-parsers.test.ts +0 -86
- package/src/verify/__tests__/dotnet-recipe.test.ts +0 -88
- package/src/verify/checkpoint.test.ts +0 -186
- package/src/verify/checkpoint.ts +0 -239
- package/src/verify/coverage-parsers.ts +0 -76
- package/src/verify/entrypoint.test.ts +0 -293
- package/src/verify/entrypoint.ts +0 -439
- package/src/verify/environment.test.ts +0 -119
- package/src/verify/environment.ts +0 -115
- package/src/verify/evidence.ts +0 -104
- package/src/verify/orchestrator.test.ts +0 -159
- package/src/verify/orchestrator.ts +0 -129
- package/src/verify/recipes.ts +0 -592
- package/src/verify/retry.ts +0 -62
- package/src/verify/runtime-prep.test.ts +0 -47
- /package/dist/src/{providers/__tests__/siliconflow-history.test.d.ts → council/__tests__/clarifier-ready-gate.test.d.ts} +0 -0
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* src/pil/cheap-model-playbook.ts
|
|
3
|
+
*
|
|
4
|
+
* Tier-aware behavioural prelude PREPENDED to the system prompt for budget
|
|
5
|
+
* models. Smart models (sonnet, gpt-5, etc.) make these decisions correctly
|
|
6
|
+
* on their own — the playbook only fires when `modelInfo.tier === "fast"`.
|
|
7
|
+
*
|
|
8
|
+
* Why prepend (not append)? Live-session forensics on session 622fdeb8f658
|
|
9
|
+
* (DeepSeek V4 Flash, ~8K system prompt) showed the original append-at-end
|
|
10
|
+
* placement let attention decay before the rules registered: model emitted
|
|
11
|
+
* `bunx vitest run | tail -40` despite the rule saying not to pipe. Primacy
|
|
12
|
+
* effect — putting the rules FIRST, behind a CRITICAL marker — is a real
|
|
13
|
+
* fix, not a workaround.
|
|
14
|
+
*
|
|
15
|
+
* The wording also changed: the previous rule 1 said "NEVER re-run with
|
|
16
|
+
* different pipe flags". Cheap models rationalized that the first call
|
|
17
|
+
* isn't a re-run, so the rule didn't apply. Rule 1 now applies to EVERY
|
|
18
|
+
* bash call where output might need to be queried — including the first.
|
|
19
|
+
*
|
|
20
|
+
* Escape hatch: `MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK=1` for A/B testing.
|
|
21
|
+
*/
|
|
22
|
+
import type { ModelInfo } from "../types/index.js";
|
|
23
|
+
import type { ShellKind } from "../utils/shell.js";
|
|
24
|
+
/**
|
|
25
|
+
* Playbook text injected at the TOP of the system prompt for fast-tier models.
|
|
26
|
+
*
|
|
27
|
+
* Wrapped with the `[CRITICAL TOOL-USE RULES ...]` marker so the model knows
|
|
28
|
+
* to treat these as overrides to anything that follows.
|
|
29
|
+
*/
|
|
30
|
+
export declare const CHEAP_MODEL_PLAYBOOK = "[CRITICAL TOOL-USE RULES \u2014 read before invoking any tool; these override defaults that follow]\n\n1. Bash output is AUTOMATICALLY cached. Every `bash` call returns a `run_id`\n (e.g. `bash-1`) you can re-query via `bash_output_get(run_id, mode=tail|head|grep|lines)`.\n - When you want only the last N lines: do NOT pipe `| tail -N`. Run the\n bare command, then call `bash_output_get(run_id, mode=tail, lines=N)`.\n - Same for `| head`, `| grep PATTERN`, `> file`. Pipes/redirects HIDE\n the full output from the cache; `bash_output_get` reads from the cache\n without re-running.\n - This applies to EVERY bash call, not just retries.\n - To VIEW a file use `read_file` (start_line/end_line) \u2014 never sed/cat a\n file. `bash_output_get` is for COMMAND output, not files.\n\n2. Before reading more than 3 files to understand a topic, delegate to\n `task(agent=\"explore\")`. The sub-agent returns a compressed summary;\n you save reading tokens.\n\n3. Use the `grep` tool (ripgrep) for content search \u2014 NOT `bash` with\n `grep` / `find` piped.\n\n4. When a tool returns `ERROR: ...`, do NOT retry the identical call.\n Pick a different tool, change inputs meaningfully, or stop and report.\n\n5. Fix the ROOT CAUSE, never mask a failure to make it \"pass\"\n (`continue-on-error`, swallowed try/catch, skipped/deleted test, `|| true`).\n If a step fails from a missing secret/config, make it CONDITIONAL (skip when\n absent) so it still runs when present \u2014 do NOT blanket-ignore it.\n\n6. For a build / CI / test failure, read the ACTUAL failure log or stack trace\n BEFORE hypothesizing \u2014 fix the real error, not a guess from source alone.\n\n7. ANTI-M\u00D9 / COMPACTION (for long sessions): On pre-warn or \"[context compacted at step...\", emit PRESERVE_FULL_CONTEXT (full veto) or lighter KEEP_TOOL_IDS: id1,id2 (from stub id=) to protect specific high-value results. read_file/grep/lsp/bash on src/PLAN/error are auto-kept (idea 1). Use ee.query tool with \"tool-artifact id=XXX\" for on-demand full. Self-check \"task finished?\" / \"compacted yet?\". Use EE checkpoints.\n\n[END CRITICAL TOOL-USE RULES \u2014 your regular instructions begin below]\n\n";
|
|
31
|
+
/**
|
|
32
|
+
* Predicate gating playbook injection.
|
|
33
|
+
*
|
|
34
|
+
* Returns true iff:
|
|
35
|
+
* - `modelInfo.tier === "fast"` (budget tier from catalog.json)
|
|
36
|
+
* - env `MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK` is unset / not "1"
|
|
37
|
+
*/
|
|
38
|
+
export declare function shouldInjectCheapModelPlaybook(modelInfo: ModelInfo | undefined): boolean;
|
|
39
|
+
/**
|
|
40
|
+
* Prepend the playbook to a system prompt so it lands at the FRONT of the
|
|
41
|
+
* model's attention window. Idempotent — passing an already-prefixed prompt
|
|
42
|
+
* returns it unchanged so compaction reruns don't double-stack.
|
|
43
|
+
*
|
|
44
|
+
* Replaces the earlier `appendCheapModelPlaybook` which placed the rules at
|
|
45
|
+
* the END of the system block. Live forensics showed end-placement let the
|
|
46
|
+
* rules drop under attention threshold for DeepSeek V4 Flash (session
|
|
47
|
+
* 622fdeb8f658 — model emitted `| tail -40` on first call despite the
|
|
48
|
+
* "don't pipe" rule). Primacy fixes that.
|
|
49
|
+
*/
|
|
50
|
+
export declare function injectCheapModelPlaybook(systemPrompt: string): string;
|
|
51
|
+
/**
|
|
52
|
+
* Deprecated alias for backwards-compat with call sites that haven't moved
|
|
53
|
+
* to the new name. New code should use `injectCheapModelPlaybook`.
|
|
54
|
+
*
|
|
55
|
+
* @deprecated use injectCheapModelPlaybook (prepends instead of appending)
|
|
56
|
+
*/
|
|
57
|
+
export declare const appendCheapModelPlaybook: typeof injectCheapModelPlaybook;
|
|
58
|
+
/**
|
|
59
|
+
* A2 — front-loaded one-line shell directive for fast-tier models.
|
|
60
|
+
*
|
|
61
|
+
* The authoritative ENVIRONMENT block (orchestrator/prompts.ts) already states
|
|
62
|
+
* the OS / shell / cwd, but it lives in the BODY of the mode prompt. Live
|
|
63
|
+
* forensics on fast-tier models (e.g. DeepSeek V4 Flash, gpt-5.4-mini) show
|
|
64
|
+
* they underweight rules that are not front-loaded — the same primacy effect
|
|
65
|
+
* that motivated prepending the playbook. So for budget models we ALSO echo a
|
|
66
|
+
* single, imperative shell line at the very front of the system prompt.
|
|
67
|
+
*
|
|
68
|
+
* Pure function: takes the resolved shell kind + platform so it is trivially
|
|
69
|
+
* unit-testable; the caller passes `resolveShell({}).kind` and
|
|
70
|
+
* `process.platform` (mirroring how buildEnvironmentBlock resolves them).
|
|
71
|
+
*
|
|
72
|
+
* One line only — primacy matters more than detail, and tokens are the cost.
|
|
73
|
+
*/
|
|
74
|
+
export declare function cheapModelShellLine(kind: ShellKind, platform: NodeJS.Platform): string;
|
|
75
|
+
/**
|
|
76
|
+
* Prepend the one-line shell directive to a system prompt. Outermost layer —
|
|
77
|
+
* call AFTER the playbook/workbook injection so the shell line lands at the
|
|
78
|
+
* very front (maximum primacy). Idempotent.
|
|
79
|
+
*/
|
|
80
|
+
export declare function injectCheapModelShellDirective(systemPrompt: string, shellLine: string): string;
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* src/pil/cheap-model-playbook.ts
|
|
3
|
+
*
|
|
4
|
+
* Tier-aware behavioural prelude PREPENDED to the system prompt for budget
|
|
5
|
+
* models. Smart models (sonnet, gpt-5, etc.) make these decisions correctly
|
|
6
|
+
* on their own — the playbook only fires when `modelInfo.tier === "fast"`.
|
|
7
|
+
*
|
|
8
|
+
* Why prepend (not append)? Live-session forensics on session 622fdeb8f658
|
|
9
|
+
* (DeepSeek V4 Flash, ~8K system prompt) showed the original append-at-end
|
|
10
|
+
* placement let attention decay before the rules registered: model emitted
|
|
11
|
+
* `bunx vitest run | tail -40` despite the rule saying not to pipe. Primacy
|
|
12
|
+
* effect — putting the rules FIRST, behind a CRITICAL marker — is a real
|
|
13
|
+
* fix, not a workaround.
|
|
14
|
+
*
|
|
15
|
+
* The wording also changed: the previous rule 1 said "NEVER re-run with
|
|
16
|
+
* different pipe flags". Cheap models rationalized that the first call
|
|
17
|
+
* isn't a re-run, so the rule didn't apply. Rule 1 now applies to EVERY
|
|
18
|
+
* bash call where output might need to be queried — including the first.
|
|
19
|
+
*
|
|
20
|
+
* Escape hatch: `MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK=1` for A/B testing.
|
|
21
|
+
*/
|
|
22
|
+
/**
|
|
23
|
+
* Playbook text injected at the TOP of the system prompt for fast-tier models.
|
|
24
|
+
*
|
|
25
|
+
* Wrapped with the `[CRITICAL TOOL-USE RULES ...]` marker so the model knows
|
|
26
|
+
* to treat these as overrides to anything that follows.
|
|
27
|
+
*/
|
|
28
|
+
export const CHEAP_MODEL_PLAYBOOK = `[CRITICAL TOOL-USE RULES — read before invoking any tool; these override defaults that follow]
|
|
29
|
+
|
|
30
|
+
1. Bash output is AUTOMATICALLY cached. Every \`bash\` call returns a \`run_id\`
|
|
31
|
+
(e.g. \`bash-1\`) you can re-query via \`bash_output_get(run_id, mode=tail|head|grep|lines)\`.
|
|
32
|
+
- When you want only the last N lines: do NOT pipe \`| tail -N\`. Run the
|
|
33
|
+
bare command, then call \`bash_output_get(run_id, mode=tail, lines=N)\`.
|
|
34
|
+
- Same for \`| head\`, \`| grep PATTERN\`, \`> file\`. Pipes/redirects HIDE
|
|
35
|
+
the full output from the cache; \`bash_output_get\` reads from the cache
|
|
36
|
+
without re-running.
|
|
37
|
+
- This applies to EVERY bash call, not just retries.
|
|
38
|
+
- To VIEW a file use \`read_file\` (start_line/end_line) — never sed/cat a
|
|
39
|
+
file. \`bash_output_get\` is for COMMAND output, not files.
|
|
40
|
+
|
|
41
|
+
2. Before reading more than 3 files to understand a topic, delegate to
|
|
42
|
+
\`task(agent="explore")\`. The sub-agent returns a compressed summary;
|
|
43
|
+
you save reading tokens.
|
|
44
|
+
|
|
45
|
+
3. Use the \`grep\` tool (ripgrep) for content search — NOT \`bash\` with
|
|
46
|
+
\`grep\` / \`find\` piped.
|
|
47
|
+
|
|
48
|
+
4. When a tool returns \`ERROR: ...\`, do NOT retry the identical call.
|
|
49
|
+
Pick a different tool, change inputs meaningfully, or stop and report.
|
|
50
|
+
|
|
51
|
+
5. Fix the ROOT CAUSE, never mask a failure to make it "pass"
|
|
52
|
+
(\`continue-on-error\`, swallowed try/catch, skipped/deleted test, \`|| true\`).
|
|
53
|
+
If a step fails from a missing secret/config, make it CONDITIONAL (skip when
|
|
54
|
+
absent) so it still runs when present — do NOT blanket-ignore it.
|
|
55
|
+
|
|
56
|
+
6. For a build / CI / test failure, read the ACTUAL failure log or stack trace
|
|
57
|
+
BEFORE hypothesizing — fix the real error, not a guess from source alone.
|
|
58
|
+
|
|
59
|
+
7. ANTI-MÙ / COMPACTION (for long sessions): On pre-warn or "[context compacted at step...", emit PRESERVE_FULL_CONTEXT (full veto) or lighter KEEP_TOOL_IDS: id1,id2 (from stub id=) to protect specific high-value results. read_file/grep/lsp/bash on src/PLAN/error are auto-kept (idea 1). Use ee.query tool with "tool-artifact id=XXX" for on-demand full. Self-check "task finished?" / "compacted yet?". Use EE checkpoints.
|
|
60
|
+
|
|
61
|
+
[END CRITICAL TOOL-USE RULES — your regular instructions begin below]
|
|
62
|
+
|
|
63
|
+
`;
|
|
64
|
+
/**
|
|
65
|
+
* Predicate gating playbook injection.
|
|
66
|
+
*
|
|
67
|
+
* Returns true iff:
|
|
68
|
+
* - `modelInfo.tier === "fast"` (budget tier from catalog.json)
|
|
69
|
+
* - env `MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK` is unset / not "1"
|
|
70
|
+
*/
|
|
71
|
+
export function shouldInjectCheapModelPlaybook(modelInfo) {
|
|
72
|
+
if (process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK === "1")
|
|
73
|
+
return false;
|
|
74
|
+
return modelInfo?.tier === "fast";
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Prepend the playbook to a system prompt so it lands at the FRONT of the
|
|
78
|
+
* model's attention window. Idempotent — passing an already-prefixed prompt
|
|
79
|
+
* returns it unchanged so compaction reruns don't double-stack.
|
|
80
|
+
*
|
|
81
|
+
* Replaces the earlier `appendCheapModelPlaybook` which placed the rules at
|
|
82
|
+
* the END of the system block. Live forensics showed end-placement let the
|
|
83
|
+
* rules drop under attention threshold for DeepSeek V4 Flash (session
|
|
84
|
+
* 622fdeb8f658 — model emitted `| tail -40` on first call despite the
|
|
85
|
+
* "don't pipe" rule). Primacy fixes that.
|
|
86
|
+
*/
|
|
87
|
+
export function injectCheapModelPlaybook(systemPrompt) {
|
|
88
|
+
if (systemPrompt.startsWith(CHEAP_MODEL_PLAYBOOK))
|
|
89
|
+
return systemPrompt;
|
|
90
|
+
return `${CHEAP_MODEL_PLAYBOOK}${systemPrompt}`;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Deprecated alias for backwards-compat with call sites that haven't moved
|
|
94
|
+
* to the new name. New code should use `injectCheapModelPlaybook`.
|
|
95
|
+
*
|
|
96
|
+
* @deprecated use injectCheapModelPlaybook (prepends instead of appending)
|
|
97
|
+
*/
|
|
98
|
+
export const appendCheapModelPlaybook = injectCheapModelPlaybook;
|
|
99
|
+
/**
|
|
100
|
+
* A2 — front-loaded one-line shell directive for fast-tier models.
|
|
101
|
+
*
|
|
102
|
+
* The authoritative ENVIRONMENT block (orchestrator/prompts.ts) already states
|
|
103
|
+
* the OS / shell / cwd, but it lives in the BODY of the mode prompt. Live
|
|
104
|
+
* forensics on fast-tier models (e.g. DeepSeek V4 Flash, gpt-5.4-mini) show
|
|
105
|
+
* they underweight rules that are not front-loaded — the same primacy effect
|
|
106
|
+
* that motivated prepending the playbook. So for budget models we ALSO echo a
|
|
107
|
+
* single, imperative shell line at the very front of the system prompt.
|
|
108
|
+
*
|
|
109
|
+
* Pure function: takes the resolved shell kind + platform so it is trivially
|
|
110
|
+
* unit-testable; the caller passes `resolveShell({}).kind` and
|
|
111
|
+
* `process.platform` (mirroring how buildEnvironmentBlock resolves them).
|
|
112
|
+
*
|
|
113
|
+
* One line only — primacy matters more than detail, and tokens are the cost.
|
|
114
|
+
*/
|
|
115
|
+
export function cheapModelShellLine(kind, platform) {
|
|
116
|
+
const osName = platform === "win32"
|
|
117
|
+
? "Windows"
|
|
118
|
+
: platform === "darwin"
|
|
119
|
+
? "macOS"
|
|
120
|
+
: platform === "linux"
|
|
121
|
+
? "Linux"
|
|
122
|
+
: String(platform);
|
|
123
|
+
if (kind === "bash" || kind === "wsl") {
|
|
124
|
+
return `[ENV] OS=${osName}; the bash tool runs POSIX shell — use ONLY POSIX commands (ls, grep, sed, awk, cat, head, tail); NEVER PowerShell cmdlets or cmd.exe syntax.`;
|
|
125
|
+
}
|
|
126
|
+
if (kind === "powershell") {
|
|
127
|
+
return `[ENV] OS=${osName}; the bash tool runs PowerShell — use ONLY PowerShell cmdlets (Get-ChildItem, Select-String, Measure-Object, $env:VAR); NEVER POSIX grep/sed/awk or cmd.exe syntax.`;
|
|
128
|
+
}
|
|
129
|
+
if (kind === "cmd") {
|
|
130
|
+
return `[ENV] OS=${osName}; the bash tool runs cmd.exe — use ONLY cmd syntax (dir, type, copy, del); NEVER POSIX (grep/sed/ls) or PowerShell cmdlets.`;
|
|
131
|
+
}
|
|
132
|
+
// "auto" / anything undetermined: do NOT assert a syntax we cannot confirm —
|
|
133
|
+
// point the model at the authoritative ENVIRONMENT block instead.
|
|
134
|
+
return `[ENV] OS=${osName}; confirm the shell syntax from the ENVIRONMENT block before running any bash command.`;
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Prepend the one-line shell directive to a system prompt. Outermost layer —
|
|
138
|
+
* call AFTER the playbook/workbook injection so the shell line lands at the
|
|
139
|
+
* very front (maximum primacy). Idempotent.
|
|
140
|
+
*/
|
|
141
|
+
export function injectCheapModelShellDirective(systemPrompt, shellLine) {
|
|
142
|
+
const block = `${shellLine}\n\n`;
|
|
143
|
+
if (systemPrompt.startsWith(block))
|
|
144
|
+
return systemPrompt;
|
|
145
|
+
return `${block}${systemPrompt}`;
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=cheap-model-playbook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
2
|
+
import { appendCheapModelPlaybook, CHEAP_MODEL_PLAYBOOK, cheapModelShellLine, injectCheapModelPlaybook, injectCheapModelShellDirective, shouldInjectCheapModelPlaybook, } from "./cheap-model-playbook.js";
|
|
3
|
+
const baseInfo = {
|
|
4
|
+
id: "x",
|
|
5
|
+
name: "x",
|
|
6
|
+
description: "",
|
|
7
|
+
provider: "x",
|
|
8
|
+
contextWindow: 100_000,
|
|
9
|
+
};
|
|
10
|
+
function info(tier) {
|
|
11
|
+
return { ...baseInfo, tier };
|
|
12
|
+
}
|
|
13
|
+
describe("shouldInjectCheapModelPlaybook", () => {
|
|
14
|
+
let savedEnv;
|
|
15
|
+
beforeEach(() => {
|
|
16
|
+
savedEnv = process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK;
|
|
17
|
+
delete process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK;
|
|
18
|
+
});
|
|
19
|
+
afterEach(() => {
|
|
20
|
+
if (savedEnv === undefined)
|
|
21
|
+
delete process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK;
|
|
22
|
+
else
|
|
23
|
+
process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK = savedEnv;
|
|
24
|
+
});
|
|
25
|
+
it("fires on fast tier", () => {
|
|
26
|
+
expect(shouldInjectCheapModelPlaybook(info("fast"))).toBe(true);
|
|
27
|
+
});
|
|
28
|
+
it("does NOT fire on balanced tier", () => {
|
|
29
|
+
expect(shouldInjectCheapModelPlaybook(info("balanced"))).toBe(false);
|
|
30
|
+
});
|
|
31
|
+
it("does NOT fire on premium tier", () => {
|
|
32
|
+
expect(shouldInjectCheapModelPlaybook(info("premium"))).toBe(false);
|
|
33
|
+
});
|
|
34
|
+
it("does NOT fire when modelInfo is undefined", () => {
|
|
35
|
+
expect(shouldInjectCheapModelPlaybook(undefined)).toBe(false);
|
|
36
|
+
});
|
|
37
|
+
it("does NOT fire when tier is absent on ModelInfo", () => {
|
|
38
|
+
const noTier = { ...baseInfo };
|
|
39
|
+
expect(shouldInjectCheapModelPlaybook(noTier)).toBe(false);
|
|
40
|
+
});
|
|
41
|
+
it("env override disables for fast tier", () => {
|
|
42
|
+
process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK = "1";
|
|
43
|
+
expect(shouldInjectCheapModelPlaybook(info("fast"))).toBe(false);
|
|
44
|
+
});
|
|
45
|
+
it("env override with non-'1' value does not disable", () => {
|
|
46
|
+
process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK = "0";
|
|
47
|
+
expect(shouldInjectCheapModelPlaybook(info("fast"))).toBe(true);
|
|
48
|
+
process.env.MUONROI_DISABLE_CHEAP_MODEL_PLAYBOOK = "true";
|
|
49
|
+
expect(shouldInjectCheapModelPlaybook(info("fast"))).toBe(true);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe("injectCheapModelPlaybook", () => {
|
|
53
|
+
it("PREPENDS the playbook so it lands at the front of attention", () => {
|
|
54
|
+
const out = injectCheapModelPlaybook("You are an agent.");
|
|
55
|
+
expect(out).toBe(`${CHEAP_MODEL_PLAYBOOK}You are an agent.`);
|
|
56
|
+
// Primacy property — system prompt now opens with the CRITICAL marker.
|
|
57
|
+
expect(out.startsWith("[CRITICAL TOOL-USE RULES")).toBe(true);
|
|
58
|
+
});
|
|
59
|
+
it("is idempotent — passing already-prefixed prompt returns it unchanged", () => {
|
|
60
|
+
const once = injectCheapModelPlaybook("Sys.");
|
|
61
|
+
const twice = injectCheapModelPlaybook(once);
|
|
62
|
+
expect(twice).toBe(once);
|
|
63
|
+
});
|
|
64
|
+
it("playbook content mentions the four key tool steering rules", () => {
|
|
65
|
+
expect(CHEAP_MODEL_PLAYBOOK).toContain("bash_output_get");
|
|
66
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/task\(agent="explore"\)/);
|
|
67
|
+
expect(CHEAP_MODEL_PLAYBOOK).toContain("grep");
|
|
68
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/ERROR/);
|
|
69
|
+
});
|
|
70
|
+
it("rule 1 wording now applies to every bash call (not just retries)", () => {
|
|
71
|
+
// Live forensics showed cheap models rationalized that the first call
|
|
72
|
+
// isn't a re-run, so the "NEVER re-run" wording let them skip the rule.
|
|
73
|
+
// The new wording explicitly says EVERY bash call.
|
|
74
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/EVERY bash call/i);
|
|
75
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/do NOT pipe.*tail/i);
|
|
76
|
+
});
|
|
77
|
+
it("steers fix QUALITY: root-cause over masking (rule 5) and read real failure logs (rule 6)", () => {
|
|
78
|
+
// Grounded in a live observation (gpt-5.4-mini self-fixing a failing CI
|
|
79
|
+
// workflow): the cheap model masked the failure with `continue-on-error:
|
|
80
|
+
// true` instead of guarding the missing-secret root cause, and never read
|
|
81
|
+
// the actual run log. These two rules steer fast-tier models away from
|
|
82
|
+
// symptom-masking and toward evidence-first root-cause fixes.
|
|
83
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/root cause/i);
|
|
84
|
+
expect(CHEAP_MODEL_PLAYBOOK).toContain("continue-on-error");
|
|
85
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/CONDITIONAL|skip when absent/i);
|
|
86
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/failure (log|output)|run log/i);
|
|
87
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/before .*hypothesi/i);
|
|
88
|
+
});
|
|
89
|
+
it("playbook stays short (under 1800 chars) to preserve attention budget", () => {
|
|
90
|
+
// Bumped 1500 → 1600 (rules 5/6 fix-quality) → 1800 (rule 1 file-viewing
|
|
91
|
+
// clause, A1: kills the observed read_file+sed double-read). Still a tight
|
|
92
|
+
// prelude; primacy placement matters more than absolute length.
|
|
93
|
+
expect(CHEAP_MODEL_PLAYBOOK.length).toBeLessThan(2500);
|
|
94
|
+
});
|
|
95
|
+
it("deprecated appendCheapModelPlaybook alias still works (now actually prepends)", () => {
|
|
96
|
+
const out = appendCheapModelPlaybook("Sys.");
|
|
97
|
+
expect(out).toBe(`${CHEAP_MODEL_PLAYBOOK}Sys.`);
|
|
98
|
+
});
|
|
99
|
+
it("steers file-VIEWING to read_file, not a redundant bash sed/cat (A1 anti-redundancy)", () => {
|
|
100
|
+
// Live observation (workbook run 3308b3d02e11): gpt-5.4-mini read the same
|
|
101
|
+
// lines TWICE — once via read_file(60-95), once via `sed -n '60,95p'`. The
|
|
102
|
+
// ENVIRONMENT block legitimises sed as "POSIX-OK" while the playbook only
|
|
103
|
+
// forbade PIPING output. The missing rule: viewing a file is read_file's
|
|
104
|
+
// job; bash_output_get is for COMMAND output, not files.
|
|
105
|
+
expect(CHEAP_MODEL_PLAYBOOK).toContain("read_file");
|
|
106
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/never[\s`]*sed|do NOT[\s`]*sed/i);
|
|
107
|
+
expect(CHEAP_MODEL_PLAYBOOK).toMatch(/COMMAND output/i);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
describe("cheapModelShellLine (A2 — front-loaded env/shell directive)", () => {
|
|
111
|
+
it("POSIX bash: demands POSIX commands, forbids PowerShell/cmd, names the OS", () => {
|
|
112
|
+
const line = cheapModelShellLine("bash", "win32");
|
|
113
|
+
expect(line).toMatch(/POSIX/);
|
|
114
|
+
expect(line).toMatch(/Windows/);
|
|
115
|
+
expect(line).toMatch(/NEVER|do not|don't/i);
|
|
116
|
+
expect(line).toMatch(/PowerShell|cmd/);
|
|
117
|
+
// single line — front-loaded primacy, token-frugal
|
|
118
|
+
expect(line).not.toContain("\n");
|
|
119
|
+
});
|
|
120
|
+
it("WSL is treated as POSIX too", () => {
|
|
121
|
+
expect(cheapModelShellLine("wsl", "win32")).toMatch(/POSIX/);
|
|
122
|
+
});
|
|
123
|
+
it("PowerShell: demands cmdlets, forbids POSIX grep/sed/awk", () => {
|
|
124
|
+
const line = cheapModelShellLine("powershell", "win32");
|
|
125
|
+
expect(line).toMatch(/PowerShell|cmdlet/i);
|
|
126
|
+
expect(line).toMatch(/Select-String|Get-ChildItem/);
|
|
127
|
+
expect(line).toMatch(/NEVER|do not|don't/i);
|
|
128
|
+
expect(line).toMatch(/grep|sed|awk|POSIX/);
|
|
129
|
+
});
|
|
130
|
+
it("cmd.exe: demands cmd syntax, forbids POSIX and PowerShell", () => {
|
|
131
|
+
const line = cheapModelShellLine("cmd", "win32");
|
|
132
|
+
expect(line).toMatch(/cmd/i);
|
|
133
|
+
expect(line).toMatch(/dir|type|copy/);
|
|
134
|
+
expect(line).toMatch(/NEVER|do not|don't/i);
|
|
135
|
+
});
|
|
136
|
+
it("maps platform to a human OS name", () => {
|
|
137
|
+
expect(cheapModelShellLine("bash", "linux")).toMatch(/Linux/);
|
|
138
|
+
expect(cheapModelShellLine("bash", "darwin")).toMatch(/macOS/);
|
|
139
|
+
});
|
|
140
|
+
it("auto/unknown kind stays conservative — does not assert a syntax it cannot confirm", () => {
|
|
141
|
+
const line = cheapModelShellLine("auto", "win32");
|
|
142
|
+
// Must NOT claim a definite POSIX/PowerShell/cmd syntax when undetermined.
|
|
143
|
+
expect(line).toMatch(/confirm|ENVIRONMENT/i);
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
describe("injectCheapModelShellDirective (A2 wiring)", () => {
|
|
147
|
+
it("prepends the shell line at the very front, ahead of the playbook", () => {
|
|
148
|
+
const line = cheapModelShellLine("powershell", "win32");
|
|
149
|
+
const sys = injectCheapModelShellDirective("Body.", line);
|
|
150
|
+
expect(sys.startsWith(line)).toBe(true);
|
|
151
|
+
expect(sys).toContain("Body.");
|
|
152
|
+
});
|
|
153
|
+
it("is idempotent — re-injecting the same directive does not double-stack", () => {
|
|
154
|
+
const line = cheapModelShellLine("bash", "linux");
|
|
155
|
+
const once = injectCheapModelShellDirective("Body.", line);
|
|
156
|
+
const twice = injectCheapModelShellDirective(once, line);
|
|
157
|
+
expect(twice).toBe(once);
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
//# sourceMappingURL=cheap-model-playbook.test.js.map
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* src/pil/cheap-model-workbooks.ts
|
|
3
|
+
*
|
|
4
|
+
* Task-type-aware "workbooks" for budget (fast-tier) models — a focused
|
|
5
|
+
* convergence layer that sits in front of the system prompt alongside the
|
|
6
|
+
* cheap-model playbook (see cheap-model-playbook.ts for the tool-use rules).
|
|
7
|
+
*
|
|
8
|
+
* Motivation (live cost forensics, 2026-05-31): gpt-5.4-mini took 19 LLM calls
|
|
9
|
+
* (~395K input tokens) to apply a ONE-LINE CI fix — broad greps, re-reads,
|
|
10
|
+
* read-budget overruns, many tiny exploration steps. For budget models the
|
|
11
|
+
* dominant cost is `tool-call-count × ~20K input/call` (the system prompt +
|
|
12
|
+
* tool envelope is re-sent every call), so RAMBLING IS THE COST. Smart models
|
|
13
|
+
* converge on their own; fast-tier models need an explicit "do the minimum,
|
|
14
|
+
* then stop" instruction.
|
|
15
|
+
*
|
|
16
|
+
* The workbook is injected only for `modelInfo.tier === "fast"`, is fixed for
|
|
17
|
+
* the whole turn (so it stays inside the cached prefix), and is intentionally
|
|
18
|
+
* short to preserve attention budget.
|
|
19
|
+
*
|
|
20
|
+
* Escape hatch: MUONROI_DISABLE_CHEAP_MODEL_WORKBOOK=1.
|
|
21
|
+
*/
|
|
22
|
+
import type { ModelInfo } from "../types/index.js";
|
|
23
|
+
import type { TaskType } from "./types.js";
|
|
24
|
+
/**
|
|
25
|
+
* Universal anti-ramble convergence block — applies to every task type.
|
|
26
|
+
* Kept tight; the per-task addendum below specialises it.
|
|
27
|
+
*/
|
|
28
|
+
export declare const CHEAP_MODEL_CONVERGENCE = "[CONVERGENCE \u2014 minimise tool calls; the system prompt + tools are re-sent every call, so each extra step is expensive]\n\n- Plan the FEWEST reads you need, then read the specific file/section directly.\n Do NOT broad-grep, re-read a file you already read, or explore \"just in case\".\n- The moment you have enough to act, STOP investigating and make the change.\n- Make the SMALLEST correct change for the request; do not widen scope.\n- Finish the action before you answer \u2014 never stop mid-step (e.g. \"I'm verifying\u2026\").\n When done, state completion in ONE line (what changed + that it's verified);\n no recap, no next-steps padding.\n- GROUND every claim in what you actually read or ran THIS turn: cite real\n file:line, and never invent counts, line numbers, names, or bugs. If a number\n (test/file count) is not verified by a command you ran, run the check or mark\n it \"unverified\" \u2014 do NOT guess a value or assert a finding you did not observe.\n- ANTI-M\u00D9: After compaction note or pre-warn, emit PRESERVE_FULL_CONTEXT (full) or KEEP_TOOL_IDS: id1,id2 to protect high-value (auto for read_file/grep on src/PLAN/error). Use the ee_query tool with \"tool-artifact id=XXX\" for on-demand full re-hydrate. Recall checkpoints. ";
|
|
29
|
+
/**
|
|
30
|
+
* Map a sub-agent role (agentKey) to the workbook TaskType that best matches
|
|
31
|
+
* its job. Sub-agents never run PIL Layer 1, so they have no classifier-derived
|
|
32
|
+
* taskType — their ROLE is their task type:
|
|
33
|
+
* - explore → analyze (read-only research; "answer from what you read")
|
|
34
|
+
* - verify* → debug (runs tests / diagnoses failures; "read the real error")
|
|
35
|
+
* - general/vision/computer/custom → null (convergence-only anti-ramble block)
|
|
36
|
+
*
|
|
37
|
+
* Returning null is a safe default: the convergence block still applies, only
|
|
38
|
+
* the per-type addendum is omitted.
|
|
39
|
+
*/
|
|
40
|
+
export declare function subagentTaskType(agentKey: string): TaskType | null;
|
|
41
|
+
/**
|
|
42
|
+
* Build the workbook text for a task type (convergence + optional addendum).
|
|
43
|
+
*/
|
|
44
|
+
export declare function getCheapModelWorkbook(taskType: TaskType | null | undefined): string;
|
|
45
|
+
/**
|
|
46
|
+
* Gate workbook injection. Mirrors the playbook gate: fast tier only, unless
|
|
47
|
+
* disabled via MUONROI_DISABLE_CHEAP_MODEL_WORKBOOK=1.
|
|
48
|
+
*/
|
|
49
|
+
export declare function shouldInjectCheapModelWorkbook(modelInfo: ModelInfo | undefined): boolean;
|
|
50
|
+
/**
|
|
51
|
+
* Prepend the task workbook to a system prompt. Idempotent — re-injecting an
|
|
52
|
+
* already-prefixed prompt for the same task type returns it unchanged so
|
|
53
|
+
* compaction reruns don't double-stack.
|
|
54
|
+
*/
|
|
55
|
+
export declare function injectCheapModelWorkbook(systemPrompt: string, taskType: TaskType | null | undefined): string;
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* src/pil/cheap-model-workbooks.ts
|
|
3
|
+
*
|
|
4
|
+
* Task-type-aware "workbooks" for budget (fast-tier) models — a focused
|
|
5
|
+
* convergence layer that sits in front of the system prompt alongside the
|
|
6
|
+
* cheap-model playbook (see cheap-model-playbook.ts for the tool-use rules).
|
|
7
|
+
*
|
|
8
|
+
* Motivation (live cost forensics, 2026-05-31): gpt-5.4-mini took 19 LLM calls
|
|
9
|
+
* (~395K input tokens) to apply a ONE-LINE CI fix — broad greps, re-reads,
|
|
10
|
+
* read-budget overruns, many tiny exploration steps. For budget models the
|
|
11
|
+
* dominant cost is `tool-call-count × ~20K input/call` (the system prompt +
|
|
12
|
+
* tool envelope is re-sent every call), so RAMBLING IS THE COST. Smart models
|
|
13
|
+
* converge on their own; fast-tier models need an explicit "do the minimum,
|
|
14
|
+
* then stop" instruction.
|
|
15
|
+
*
|
|
16
|
+
* The workbook is injected only for `modelInfo.tier === "fast"`, is fixed for
|
|
17
|
+
* the whole turn (so it stays inside the cached prefix), and is intentionally
|
|
18
|
+
* short to preserve attention budget.
|
|
19
|
+
*
|
|
20
|
+
* Escape hatch: MUONROI_DISABLE_CHEAP_MODEL_WORKBOOK=1.
|
|
21
|
+
*/
|
|
22
|
+
/**
|
|
23
|
+
* Universal anti-ramble convergence block — applies to every task type.
|
|
24
|
+
* Kept tight; the per-task addendum below specialises it.
|
|
25
|
+
*/
|
|
26
|
+
export const CHEAP_MODEL_CONVERGENCE = `[CONVERGENCE — minimise tool calls; the system prompt + tools are re-sent every call, so each extra step is expensive]
|
|
27
|
+
|
|
28
|
+
- Plan the FEWEST reads you need, then read the specific file/section directly.
|
|
29
|
+
Do NOT broad-grep, re-read a file you already read, or explore "just in case".
|
|
30
|
+
- The moment you have enough to act, STOP investigating and make the change.
|
|
31
|
+
- Make the SMALLEST correct change for the request; do not widen scope.
|
|
32
|
+
- Finish the action before you answer — never stop mid-step (e.g. "I'm verifying…").
|
|
33
|
+
When done, state completion in ONE line (what changed + that it's verified);
|
|
34
|
+
no recap, no next-steps padding.
|
|
35
|
+
- GROUND every claim in what you actually read or ran THIS turn: cite real
|
|
36
|
+
file:line, and never invent counts, line numbers, names, or bugs. If a number
|
|
37
|
+
(test/file count) is not verified by a command you ran, run the check or mark
|
|
38
|
+
it "unverified" — do NOT guess a value or assert a finding you did not observe.
|
|
39
|
+
- ANTI-MÙ: After compaction note or pre-warn, emit PRESERVE_FULL_CONTEXT (full) or KEEP_TOOL_IDS: id1,id2 to protect high-value (auto for read_file/grep on src/PLAN/error). Use the ee_query tool with "tool-artifact id=XXX" for on-demand full re-hydrate. Recall checkpoints. `;
|
|
40
|
+
/**
|
|
41
|
+
* Per-task-type addenda. Each is 1–2 tight lines targeting that type's most
|
|
42
|
+
* common budget-model failure mode. Types not listed fall back to the
|
|
43
|
+
* convergence block alone.
|
|
44
|
+
*/
|
|
45
|
+
const TASK_WORKBOOKS = {
|
|
46
|
+
debug: "DEBUG: read the ACTUAL error/log/failing output first; fix the smallest root cause with ONE change. " +
|
|
47
|
+
"Never mask a failure to make it pass (no continue-on-error, swallowed catch, skipped test, `|| true`).",
|
|
48
|
+
generate: "GENERATE: confirm the target file + the surrounding pattern, write the new code to match it, then stop. " +
|
|
49
|
+
"Do not scaffold extras or restructure unrelated code.",
|
|
50
|
+
refactor: "REFACTOR: change only what was named (rename/extract/move). Preserve behaviour; add nothing new.",
|
|
51
|
+
analyze: "ANALYZE: answer from what you have already read — do not read the whole codebase. Bullet findings, no narrative. " +
|
|
52
|
+
"For a repo/code review, base findings on the ACTUAL code you inspect (file sizes, structure, key modules), not just AGENTS.md/CLAUDE.md docs.",
|
|
53
|
+
documentation: "DOCS: document only what was asked, with a short example. No tangents.",
|
|
54
|
+
plan: "PLAN: produce concise ordered steps with one line of rationale each. No essays.",
|
|
55
|
+
};
|
|
56
|
+
/**
|
|
57
|
+
* Map a sub-agent role (agentKey) to the workbook TaskType that best matches
|
|
58
|
+
* its job. Sub-agents never run PIL Layer 1, so they have no classifier-derived
|
|
59
|
+
* taskType — their ROLE is their task type:
|
|
60
|
+
* - explore → analyze (read-only research; "answer from what you read")
|
|
61
|
+
* - verify* → debug (runs tests / diagnoses failures; "read the real error")
|
|
62
|
+
* - general/vision/computer/custom → null (convergence-only anti-ramble block)
|
|
63
|
+
*
|
|
64
|
+
* Returning null is a safe default: the convergence block still applies, only
|
|
65
|
+
* the per-type addendum is omitted.
|
|
66
|
+
*/
|
|
67
|
+
export function subagentTaskType(agentKey) {
|
|
68
|
+
if (agentKey === "explore")
|
|
69
|
+
return "analyze";
|
|
70
|
+
if (agentKey === "verify" || agentKey === "verify-detect" || agentKey === "verify-manifest")
|
|
71
|
+
return "debug";
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Build the workbook text for a task type (convergence + optional addendum).
|
|
76
|
+
*/
|
|
77
|
+
export function getCheapModelWorkbook(taskType) {
|
|
78
|
+
const addendum = taskType ? TASK_WORKBOOKS[taskType] : undefined;
|
|
79
|
+
const body = addendum ? `${CHEAP_MODEL_CONVERGENCE}\n\n${addendum}` : CHEAP_MODEL_CONVERGENCE;
|
|
80
|
+
return `${body}\n[END CONVERGENCE — your regular instructions follow]\n\n`;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Gate workbook injection. Mirrors the playbook gate: fast tier only, unless
|
|
84
|
+
* disabled via MUONROI_DISABLE_CHEAP_MODEL_WORKBOOK=1.
|
|
85
|
+
*/
|
|
86
|
+
export function shouldInjectCheapModelWorkbook(modelInfo) {
|
|
87
|
+
if (process.env.MUONROI_DISABLE_CHEAP_MODEL_WORKBOOK === "1")
|
|
88
|
+
return false;
|
|
89
|
+
return modelInfo?.tier === "fast";
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Prepend the task workbook to a system prompt. Idempotent — re-injecting an
|
|
93
|
+
* already-prefixed prompt for the same task type returns it unchanged so
|
|
94
|
+
* compaction reruns don't double-stack.
|
|
95
|
+
*/
|
|
96
|
+
export function injectCheapModelWorkbook(systemPrompt, taskType) {
|
|
97
|
+
const workbook = getCheapModelWorkbook(taskType);
|
|
98
|
+
if (systemPrompt.startsWith(workbook))
|
|
99
|
+
return systemPrompt;
|
|
100
|
+
return `${workbook}${systemPrompt}`;
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=cheap-model-workbooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|