@opengsd/gsd-pi 1.2.0-dev.5457a158 → 1.2.0-dev.6ccd27b3
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/dist/cli-model-override.d.ts +15 -0
- package/dist/cli-model-override.js +21 -0
- package/dist/cli.js +1 -18
- package/dist/headless-events.js +7 -5
- package/dist/loader.js +6 -4
- package/dist/mcp-server.js +2 -1
- package/dist/register-agent-bundles.d.ts +11 -2
- package/dist/register-agent-bundles.js +18 -4
- package/dist/resource-loader.d.ts +10 -5
- package/dist/resource-loader.js +121 -6
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/GSD-WORKFLOW.md +5 -4
- package/dist/resources/extensions/ask-user-questions.js +3 -2
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
- package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
- package/dist/resources/extensions/async-jobs/index.js +65 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
- package/dist/resources/extensions/bg-shell/overlay.js +9 -6
- package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
- package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
- package/dist/resources/extensions/browser-tools/engine/managed-gsd-browser.js +209 -88
- package/dist/resources/extensions/browser-tools/engine/selection.js +73 -5
- package/dist/resources/extensions/browser-tools/index.js +69 -12
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +450 -217
- package/dist/resources/extensions/claude-code-cli/turn-assembler.js +33 -1
- package/dist/resources/extensions/gsd/auto/closeout.js +215 -0
- package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
- package/dist/resources/extensions/gsd/auto/dispatch-history.js +120 -0
- package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
- package/dist/resources/extensions/gsd/auto/dispatch.js +365 -0
- package/dist/resources/extensions/gsd/auto/finalize.js +347 -0
- package/dist/resources/extensions/gsd/auto/loop.js +7 -1
- package/dist/resources/extensions/gsd/auto/milestone-lease-reclaim.js +56 -0
- package/dist/resources/extensions/gsd/auto/orchestrator.js +174 -69
- package/dist/resources/extensions/gsd/auto/phase-helpers.js +146 -0
- package/dist/resources/extensions/gsd/auto/phases.js +17 -2329
- package/dist/resources/extensions/gsd/auto/pre-dispatch.js +534 -0
- package/dist/resources/extensions/gsd/auto/session.js +3 -0
- package/dist/resources/extensions/gsd/auto/unit-phase.js +694 -0
- package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +1 -1
- package/dist/resources/extensions/gsd/auto/worktree-safety-phase.js +125 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +11 -34
- package/dist/resources/extensions/gsd/auto-dispatch.js +50 -58
- package/dist/resources/extensions/gsd/auto-model-selection.js +36 -13
- package/dist/resources/extensions/gsd/auto-post-unit.js +30 -12
- package/dist/resources/extensions/gsd/auto-prompts.js +78 -19
- package/dist/resources/extensions/gsd/auto-start.js +35 -15
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
- package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +5 -4
- package/dist/resources/extensions/gsd/auto-verification.js +23 -30
- package/dist/resources/extensions/gsd/auto-worktree.js +15 -2
- package/dist/resources/extensions/gsd/auto.js +41 -2
- package/dist/resources/extensions/gsd/blocked-models.js +28 -0
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +26 -6
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +60 -13
- package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +172 -59
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +302 -80
- package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
- package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
- package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
- package/dist/resources/extensions/gsd/commands/context.js +16 -2
- package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
- package/dist/resources/extensions/gsd/commands-mcp-status.js +2 -2
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +9 -2
- package/dist/resources/extensions/gsd/consent-question.js +353 -0
- package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
- package/dist/resources/extensions/gsd/constants.js +0 -2
- package/dist/resources/extensions/gsd/crash-recovery.js +8 -3
- package/dist/resources/extensions/gsd/db/queries.js +56 -0
- package/dist/resources/extensions/gsd/db-writer.js +8 -17
- package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
- package/dist/resources/extensions/gsd/doctor-engine-checks.js +5 -5
- package/dist/resources/extensions/gsd/doctor-environment.js +256 -125
- package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
- package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
- package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
- package/dist/resources/extensions/gsd/files.js +33 -19
- package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
- package/dist/resources/extensions/gsd/gsd-db.js +2 -1
- package/dist/resources/extensions/gsd/guidance.js +60 -0
- package/dist/resources/extensions/gsd/guided-flow.js +93 -4
- package/dist/resources/extensions/gsd/health-widget.js +87 -28
- package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
- package/dist/resources/extensions/gsd/mcp-bridge.js +10 -0
- package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
- package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
- package/dist/resources/extensions/gsd/milestone-planning-persistence.js +2 -2
- package/dist/resources/extensions/gsd/milestone-reopen-events.js +3 -5
- package/dist/resources/extensions/gsd/milestone-settlement.js +2 -2
- package/dist/resources/extensions/gsd/notifications.js +12 -7
- package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
- package/dist/resources/extensions/gsd/preferences-models.js +2 -2
- package/dist/resources/extensions/gsd/projection-flush.js +7 -0
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +4 -4
- package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
- package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
- package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
- package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/research-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
- package/dist/resources/extensions/gsd/prompts/run-uat.md +9 -5
- package/dist/resources/extensions/gsd/prompts/system.md +5 -2
- package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
- package/dist/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/workflow-start.md +2 -1
- package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
- package/dist/resources/extensions/gsd/roadmap-slices.js +25 -3
- package/dist/resources/extensions/gsd/safety/destructive-confirmation.js +108 -0
- package/dist/resources/extensions/gsd/session-lock.js +1 -1
- package/dist/resources/extensions/gsd/skill-activation.js +3 -6
- package/dist/resources/extensions/gsd/state.js +11 -2
- package/dist/resources/extensions/gsd/tool-contract.js +14 -3
- package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
- package/dist/resources/extensions/gsd/tool-surface-readiness.js +83 -31
- package/dist/resources/extensions/gsd/tools/complete-milestone.js +3 -2
- package/dist/resources/extensions/gsd/tools/complete-slice.js +22 -12
- package/dist/resources/extensions/gsd/tools/complete-task.js +65 -2
- package/dist/resources/extensions/gsd/tools/exec-tool.js +5 -0
- package/dist/resources/extensions/gsd/tools/plan-slice.js +2 -2
- package/dist/resources/extensions/gsd/tools/plan-task.js +2 -2
- package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +2 -2
- package/dist/resources/extensions/gsd/tools/reopen-milestone.js +2 -2
- package/dist/resources/extensions/gsd/tools/reopen-slice.js +2 -2
- package/dist/resources/extensions/gsd/tools/reopen-task.js +2 -2
- package/dist/resources/extensions/gsd/tools/replan-slice.js +2 -2
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +67 -2
- package/dist/resources/extensions/gsd/uat-policy.js +42 -16
- package/dist/resources/extensions/gsd/unit-context-composer.js +65 -0
- package/dist/resources/extensions/gsd/unit-registry.js +41 -24
- package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
- package/dist/resources/extensions/gsd/verification-verdict.js +2 -1
- package/dist/resources/extensions/gsd/web-app-uat.js +45 -8
- package/dist/resources/extensions/gsd/workflow-event-ledger.js +91 -0
- package/dist/resources/extensions/gsd/workflow-event-vocabulary.js +46 -0
- package/dist/resources/extensions/gsd/workflow-events.js +6 -18
- package/dist/resources/extensions/gsd/workflow-mcp-auto-prep.js +2 -0
- package/dist/resources/extensions/gsd/workflow-mcp-readiness-cache.js +105 -0
- package/dist/resources/extensions/gsd/workflow-reconcile.js +21 -56
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +3 -2
- package/dist/resources/extensions/gsd/worktree-manager.js +7 -1
- package/dist/resources/extensions/gsd/worktree-safety.js +28 -26
- package/dist/resources/extensions/gsd/worktree.js +8 -1
- package/dist/resources/extensions/mcp-client/manager.js +6 -1
- package/dist/resources/extensions/search-the-web/native-search.js +5 -3
- package/dist/resources/extensions/shared/browser-contract.js +59 -0
- package/dist/resources/extensions/shared/gsd-browser-cli.js +116 -6
- package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
- package/dist/resources/shared/package-manager-detection.js +1 -1
- package/dist/resources/shared/package.json +3 -0
- package/dist/resources/skills/create-skill/SKILL.md +3 -0
- package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
- package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
- package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/runtime-checks.d.ts +10 -0
- package/dist/runtime-checks.js +27 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/update-check.d.ts +2 -0
- package/dist/update-check.js +24 -1
- package/dist/update-cmd.js +20 -3
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +12 -12
- package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/static/chunks/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
- package/dist/web/standalone/package.json +1 -1
- package/package.json +3 -3
- package/packages/cloud-mcp-gateway/package.json +2 -2
- package/packages/contracts/dist/rpc.d.ts +1 -0
- package/packages/contracts/dist/rpc.d.ts.map +1 -1
- package/packages/contracts/dist/rpc.js.map +1 -1
- package/packages/contracts/package.json +1 -1
- package/packages/daemon/package.json +4 -4
- package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -1
- package/packages/gsd-agent-core/dist/sdk.js +6 -4
- package/packages/gsd-agent-core/dist/sdk.js.map +1 -1
- package/packages/gsd-agent-core/package.json +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +10 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +13 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +55 -6
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js +34 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +12 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js +4 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
- package/packages/gsd-agent-modes/package.json +7 -7
- package/packages/mcp-server/README.md +12 -3
- package/packages/mcp-server/dist/cli-runner.d.ts +40 -0
- package/packages/mcp-server/dist/cli-runner.d.ts.map +1 -0
- package/packages/mcp-server/dist/cli-runner.js +137 -0
- package/packages/mcp-server/dist/cli-runner.js.map +1 -0
- package/packages/mcp-server/dist/cli.js +2 -53
- package/packages/mcp-server/dist/cli.js.map +1 -1
- package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
- package/packages/mcp-server/dist/pid-registry.d.ts +46 -0
- package/packages/mcp-server/dist/pid-registry.d.ts.map +1 -0
- package/packages/mcp-server/dist/pid-registry.js +452 -0
- package/packages/mcp-server/dist/pid-registry.js.map +1 -0
- package/packages/mcp-server/dist/probe-mode.d.ts +4 -0
- package/packages/mcp-server/dist/probe-mode.d.ts.map +1 -0
- package/packages/mcp-server/dist/probe-mode.js +10 -0
- package/packages/mcp-server/dist/probe-mode.js.map +1 -0
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +4 -0
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/dist/stdio-watchdog.d.ts +8 -0
- package/packages/mcp-server/dist/stdio-watchdog.d.ts.map +1 -0
- package/packages/mcp-server/dist/stdio-watchdog.js +40 -0
- package/packages/mcp-server/dist/stdio-watchdog.js.map +1 -0
- package/packages/mcp-server/dist/workflow-tools.d.ts +18 -18
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +161 -81
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +5 -4
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/dist/agent-loop.js +43 -2
- package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
- package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
- package/packages/pi-agent-core/dist/index.d.ts +1 -0
- package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/index.js +3 -0
- package/packages/pi-agent-core/dist/index.js.map +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-ai/README.md +1 -0
- package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
- package/packages/pi-ai/dist/image-models.generated.js +6 -6
- package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
- package/packages/pi-ai/dist/index.d.ts +2 -0
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +2 -0
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/models.generated.d.ts +239 -153
- package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.js +256 -145
- package/packages/pi-ai/dist/models.generated.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +12 -7
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
- package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.js +12 -3
- package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
- package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
- package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
- package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
- package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
- package/packages/pi-ai/package.json +3 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
- package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
- package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.js +11 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
- package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/theme/theme.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/theme/theme.js +45 -17
- package/packages/pi-coding-agent/dist/theme/theme.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
- package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
- package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
- package/packages/pi-coding-agent/package.json +7 -7
- package/packages/pi-tui/dist/index.d.ts +1 -1
- package/packages/pi-tui/dist/index.d.ts.map +1 -1
- package/packages/pi-tui/dist/index.js +1 -1
- package/packages/pi-tui/dist/index.js.map +1 -1
- package/packages/pi-tui/dist/terminal-image.d.ts +33 -0
- package/packages/pi-tui/dist/terminal-image.d.ts.map +1 -1
- package/packages/pi-tui/dist/terminal-image.js +54 -2
- package/packages/pi-tui/dist/terminal-image.js.map +1 -1
- package/packages/pi-tui/dist/tui.d.ts +8 -0
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +72 -18
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/dist/utils.d.ts.map +1 -1
- package/packages/pi-tui/dist/utils.js +110 -36
- package/packages/pi-tui/dist/utils.js.map +1 -1
- package/packages/pi-tui/package.json +2 -2
- package/packages/rpc-client/package.json +2 -2
- package/pkg/dist/theme/theme.d.ts.map +1 -1
- package/pkg/dist/theme/theme.js +45 -17
- package/pkg/dist/theme/theme.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/GSD-WORKFLOW.md +5 -4
- package/src/resources/extensions/ask-user-questions.ts +7 -2
- package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
- package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
- package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
- package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
- package/src/resources/extensions/async-jobs/index.ts +79 -0
- package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
- package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
- package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
- package/src/resources/extensions/bg-shell/overlay.ts +9 -5
- package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
- package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
- package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
- package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
- package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
- package/src/resources/extensions/browser-tools/index.ts +71 -13
- package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
- package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +40 -1
- package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +534 -228
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +672 -7
- package/src/resources/extensions/claude-code-cli/turn-assembler.ts +38 -1
- package/src/resources/extensions/gsd/auto/closeout.ts +309 -0
- package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
- package/src/resources/extensions/gsd/auto/dispatch-history.ts +168 -0
- package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
- package/src/resources/extensions/gsd/auto/dispatch.ts +449 -0
- package/src/resources/extensions/gsd/auto/finalize.ts +445 -0
- package/src/resources/extensions/gsd/auto/loop.ts +7 -1
- package/src/resources/extensions/gsd/auto/milestone-lease-reclaim.ts +74 -0
- package/src/resources/extensions/gsd/auto/orchestrator.ts +193 -71
- package/src/resources/extensions/gsd/auto/phase-helpers.ts +199 -0
- package/src/resources/extensions/gsd/auto/phases.ts +58 -3022
- package/src/resources/extensions/gsd/auto/pre-dispatch.ts +704 -0
- package/src/resources/extensions/gsd/auto/session.ts +3 -0
- package/src/resources/extensions/gsd/auto/unit-phase.ts +910 -0
- package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +1 -1
- package/src/resources/extensions/gsd/auto/worktree-safety-phase.ts +149 -0
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +18 -48
- package/src/resources/extensions/gsd/auto-dispatch.ts +48 -61
- package/src/resources/extensions/gsd/auto-model-selection.ts +41 -12
- package/src/resources/extensions/gsd/auto-post-unit.ts +33 -12
- package/src/resources/extensions/gsd/auto-prompts.ts +115 -35
- package/src/resources/extensions/gsd/auto-start.ts +36 -18
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
- package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +4 -4
- package/src/resources/extensions/gsd/auto-verification.ts +26 -28
- package/src/resources/extensions/gsd/auto-worktree.ts +15 -2
- package/src/resources/extensions/gsd/auto.ts +49 -2
- package/src/resources/extensions/gsd/blocked-models.ts +49 -0
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -5
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +79 -12
- package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +211 -59
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +350 -86
- package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
- package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
- package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
- package/src/resources/extensions/gsd/commands/context.ts +16 -2
- package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
- package/src/resources/extensions/gsd/commands-mcp-status.ts +2 -2
- package/src/resources/extensions/gsd/commands-workflow-templates.ts +11 -4
- package/src/resources/extensions/gsd/consent-question.ts +431 -0
- package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
- package/src/resources/extensions/gsd/constants.ts +0 -3
- package/src/resources/extensions/gsd/crash-recovery.ts +10 -2
- package/src/resources/extensions/gsd/db/queries.ts +66 -0
- package/src/resources/extensions/gsd/db-writer.ts +11 -19
- package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
- package/src/resources/extensions/gsd/doctor-engine-checks.ts +5 -4
- package/src/resources/extensions/gsd/doctor-environment.ts +267 -142
- package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
- package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
- package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
- package/src/resources/extensions/gsd/files.ts +33 -12
- package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
- package/src/resources/extensions/gsd/gsd-db.ts +4 -3
- package/src/resources/extensions/gsd/guidance.ts +78 -0
- package/src/resources/extensions/gsd/guided-flow.ts +145 -24
- package/src/resources/extensions/gsd/health-widget.ts +91 -27
- package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
- package/src/resources/extensions/gsd/mcp-bridge.ts +39 -0
- package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
- package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
- package/src/resources/extensions/gsd/milestone-planning-persistence.ts +2 -2
- package/src/resources/extensions/gsd/milestone-reopen-events.ts +3 -6
- package/src/resources/extensions/gsd/milestone-settlement.ts +2 -2
- package/src/resources/extensions/gsd/notifications.ts +13 -6
- package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
- package/src/resources/extensions/gsd/preferences-models.ts +2 -1
- package/src/resources/extensions/gsd/projection-flush.ts +20 -0
- package/src/resources/extensions/gsd/prompts/complete-slice.md +4 -4
- package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
- package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
- package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
- package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/research-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/research-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
- package/src/resources/extensions/gsd/prompts/run-uat.md +9 -5
- package/src/resources/extensions/gsd/prompts/system.md +5 -2
- package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
- package/src/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/workflow-start.md +2 -1
- package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
- package/src/resources/extensions/gsd/roadmap-slices.ts +28 -3
- package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
- package/src/resources/extensions/gsd/session-lock.ts +1 -1
- package/src/resources/extensions/gsd/skill-activation.ts +3 -6
- package/src/resources/extensions/gsd/state.ts +12 -1
- package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-blocked-remediation-message.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +206 -22
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +97 -1
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +273 -37
- package/src/resources/extensions/gsd/tests/auto-pause-double-entry-guard.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +51 -0
- package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/auto-remote-session-lock-cleanup.test.ts +65 -3
- package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
- package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +169 -1
- package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
- package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
- package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +141 -5
- package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
- package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
- package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +12 -11
- package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
- package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
- package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +328 -0
- package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/dist-redirect.mjs +8 -0
- package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
- package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
- package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
- package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +117 -91
- package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
- package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
- package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
- package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
- package/src/resources/extensions/gsd/tests/guidance.test.ts +23 -0
- package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +18 -6
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +7 -11
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +35 -58
- package/src/resources/extensions/gsd/tests/integration/doctor-environment-async.test.ts +104 -0
- package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +217 -0
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +47 -16
- package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/mcp-readiness-preflight.test.ts +205 -0
- package/src/resources/extensions/gsd/tests/mcp-status.test.ts +6 -5
- package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
- package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/milestone-settlement.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/notifications.test.ts +64 -9
- package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
- package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +143 -0
- package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
- package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +10 -2
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +2 -4
- package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +31 -81
- package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +26 -2
- package/src/resources/extensions/gsd/tests/skill-activation.test.ts +20 -17
- package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +80 -2
- package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +184 -10
- package/src/resources/extensions/gsd/tests/tool-unavailable-retry.test.ts +33 -0
- package/src/resources/extensions/gsd/tests/transport-gate-double-complete.test.ts +139 -0
- package/src/resources/extensions/gsd/tests/uat-policy.test.ts +112 -29
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +2 -0
- package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +44 -1
- package/src/resources/extensions/gsd/tests/workflow-events.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp-readiness-cache.test.ts +119 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +65 -2
- package/src/resources/extensions/gsd/tests/workflow-phase-contract-matrix.test.ts +332 -0
- package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
- package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +273 -38
- package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-safety-phase.test.ts +100 -0
- package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +72 -0
- package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +67 -1
- package/src/resources/extensions/gsd/tool-contract.ts +38 -3
- package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
- package/src/resources/extensions/gsd/tool-surface-readiness.ts +126 -19
- package/src/resources/extensions/gsd/tools/complete-milestone.ts +3 -2
- package/src/resources/extensions/gsd/tools/complete-slice.ts +22 -12
- package/src/resources/extensions/gsd/tools/complete-task.ts +90 -2
- package/src/resources/extensions/gsd/tools/exec-tool.ts +4 -0
- package/src/resources/extensions/gsd/tools/plan-slice.ts +2 -2
- package/src/resources/extensions/gsd/tools/plan-task.ts +2 -2
- package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +2 -2
- package/src/resources/extensions/gsd/tools/reopen-milestone.ts +2 -2
- package/src/resources/extensions/gsd/tools/reopen-slice.ts +2 -2
- package/src/resources/extensions/gsd/tools/reopen-task.ts +2 -2
- package/src/resources/extensions/gsd/tools/replan-slice.ts +2 -2
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
- package/src/resources/extensions/gsd/uat-policy.ts +62 -16
- package/src/resources/extensions/gsd/unit-context-composer.ts +99 -0
- package/src/resources/extensions/gsd/unit-registry.ts +41 -24
- package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
- package/src/resources/extensions/gsd/verification-verdict.ts +4 -2
- package/src/resources/extensions/gsd/web-app-uat.ts +51 -8
- package/src/resources/extensions/gsd/workflow-event-ledger.ts +131 -0
- package/src/resources/extensions/gsd/workflow-event-vocabulary.ts +59 -0
- package/src/resources/extensions/gsd/workflow-events.ts +12 -20
- package/src/resources/extensions/gsd/workflow-mcp-auto-prep.ts +2 -0
- package/src/resources/extensions/gsd/workflow-mcp-readiness-cache.ts +150 -0
- package/src/resources/extensions/gsd/workflow-reconcile.ts +29 -62
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +3 -8
- package/src/resources/extensions/gsd/worktree-manager.ts +6 -1
- package/src/resources/extensions/gsd/worktree-safety.ts +41 -39
- package/src/resources/extensions/gsd/worktree.ts +7 -1
- package/src/resources/extensions/mcp-client/manager.ts +7 -1
- package/src/resources/extensions/search-the-web/native-search.ts +5 -3
- package/src/resources/extensions/shared/browser-contract.ts +66 -0
- package/src/resources/extensions/shared/gsd-browser-cli.ts +141 -6
- package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
- package/src/resources/shared/package-manager-detection.ts +1 -1
- package/src/resources/shared/package.json +3 -0
- package/src/resources/skills/create-skill/SKILL.md +3 -0
- package/src/resources/skills/create-skill/references/executable-code.md +1 -1
- package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
- package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
- package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
- package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
- package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
- package/src/resources/skills/gsd-browser/SKILL.md +0 -41
- /package/dist/web/standalone/.next/static/{2p9Rv9pQflAxCBbGVI2vb → avEtvPrImYTq2gGe-hVNp}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{2p9Rv9pQflAxCBbGVI2vb → avEtvPrImYTq2gGe-hVNp}/_ssgManifest.js +0 -0
|
@@ -32,6 +32,7 @@ import {
|
|
|
32
32
|
buildFinalAssistantContent,
|
|
33
33
|
extractToolResultsFromSdkUserMessage,
|
|
34
34
|
handleClaudeCodePartialStreamEvent,
|
|
35
|
+
shouldSuppressDuplicateToolUnavailableBlock,
|
|
35
36
|
} from "./turn-assembler.js";
|
|
36
37
|
import type {
|
|
37
38
|
ExternalToolResultPayload,
|
|
@@ -59,7 +60,21 @@ import {
|
|
|
59
60
|
computeMcpDisallowedTools,
|
|
60
61
|
} from "../gsd/mcp-filter.js";
|
|
61
62
|
import { RUN_UAT_CLAUDE_NATIVE_TOOL_NAMES, RUN_UAT_FORBIDDEN_TOOL_NAMES, RUN_UAT_WORKFLOW_TOOL_NAMES, resolveToolPresentationPlan } from "../gsd/tool-presentation-plan.js";
|
|
62
|
-
import {
|
|
63
|
+
import { getUnitToolSurfaceContract } from "../gsd/unit-tool-contracts.js";
|
|
64
|
+
import {
|
|
65
|
+
awaitWorkflowMcpToolRegistration,
|
|
66
|
+
getToolSurfaceReadinessError,
|
|
67
|
+
POST_PREFLIGHT_READINESS_RETRY_DELAYS_MS,
|
|
68
|
+
POST_PREFLIGHT_SDK_SETTLE_MS,
|
|
69
|
+
TOOL_SURFACE_NOT_READY,
|
|
70
|
+
type LiveToolSurfaceObservation,
|
|
71
|
+
} from "../gsd/tool-surface-readiness.js";
|
|
72
|
+
import {
|
|
73
|
+
beginWorkflowMcpSdkSession,
|
|
74
|
+
endWorkflowMcpSdkSession,
|
|
75
|
+
} from "../gsd/workflow-mcp-readiness-cache.js";
|
|
76
|
+
import { getGuidedUnitContext } from "../gsd/guided-unit-context.js";
|
|
77
|
+
import { hasBrowserContractPrefix } from "../shared/browser-contract.js";
|
|
63
78
|
import { showInterviewRound, type Question, type RoundResult } from "../shared/tui.js";
|
|
64
79
|
import type {
|
|
65
80
|
SDKAssistantMessage,
|
|
@@ -74,6 +89,7 @@ export {
|
|
|
74
89
|
extractToolResultsFromSdkUserMessage,
|
|
75
90
|
handleClaudeCodePartialStreamEvent,
|
|
76
91
|
mergePendingToolCalls,
|
|
92
|
+
shouldSuppressDuplicateToolUnavailableBlock,
|
|
77
93
|
} from "./turn-assembler.js";
|
|
78
94
|
export type {
|
|
79
95
|
ExternalToolResultContentBlock,
|
|
@@ -91,6 +107,11 @@ interface ClaudeCodeStreamOptions extends SimpleStreamOptions {
|
|
|
91
107
|
extensionUIContext?: ExtensionUIContext;
|
|
92
108
|
onExternalToolCall?: (toolCall: ToolCall) => Promise<void> | void;
|
|
93
109
|
onExternalToolResult?: (event: { toolCall: ToolCall; result: ExternalToolResultPayload }) => Promise<void> | void;
|
|
110
|
+
_sdkQueryForTest?: (args: {
|
|
111
|
+
prompt: string | AsyncIterable<unknown>;
|
|
112
|
+
options?: Record<string, unknown>;
|
|
113
|
+
}) => AsyncIterable<SDKMessage>;
|
|
114
|
+
_skipWorkflowMcpPreflightForTest?: boolean;
|
|
94
115
|
}
|
|
95
116
|
|
|
96
117
|
export function serverToolUseToToolCallLike(block: {
|
|
@@ -351,13 +372,18 @@ const GSD_PHASE_PATTERNS: Array<[string, RegExp]> = [
|
|
|
351
372
|
["reassess-roadmap", /\b(?:UNIT:\s*Reassess Roadmap|reassess-roadmap)\b/i],
|
|
352
373
|
["complete-slice", /\b(?:UNIT:\s*Complete Slice|complete-slice)\b/i],
|
|
353
374
|
["replan-slice", /\b(?:UNIT:\s*Replan Slice|replan-slice)\b/i],
|
|
375
|
+
["refine-slice", /\b(?:UNIT:\s*Refine Slice|refine-slice)\b/i],
|
|
354
376
|
["plan-slice", /\b(?:UNIT:\s*Plan Slice|plan-slice|gsd_plan_slice)\b/i],
|
|
355
377
|
["plan-milestone", /\b(?:UNIT:\s*Plan Milestone|plan-milestone|gsd_plan_milestone)\b/i],
|
|
356
378
|
["execute-task", /\b(?:UNIT:\s*Execute Task|execute-task|execute-task-simple|reactive-execute)\b/i],
|
|
357
379
|
["gate-evaluate", /\b(?:UNIT:\s*Gate Evaluate|gate-evaluate|gsd_save_gate_result)\b/i],
|
|
358
380
|
["research-milestone", /\b(?:UNIT:\s*Research Milestone|research-milestone)\b/i],
|
|
359
381
|
["research-slice", /\b(?:UNIT:\s*Research Slice|research-slice)\b/i],
|
|
382
|
+
["research-decision", /\b(?:research decision|research-decision)\b/i],
|
|
360
383
|
["discuss-milestone", /\b(?:Discuss milestone|discuss-milestone)\b/i],
|
|
384
|
+
["discuss-slice", /\b(?:Discuss slice|discuss-slice)\b/i],
|
|
385
|
+
["discuss-project", /\b(?:discuss-project|Discuss project)\b/i],
|
|
386
|
+
["discuss-requirements", /\b(?:discuss-requirements|Discuss requirements)\b/i],
|
|
361
387
|
];
|
|
362
388
|
|
|
363
389
|
export function inferGsdPhaseFromContext(context: Context): string | undefined {
|
|
@@ -371,6 +397,26 @@ export function inferGsdPhaseFromContext(context: Context): string | undefined {
|
|
|
371
397
|
return undefined;
|
|
372
398
|
}
|
|
373
399
|
|
|
400
|
+
/**
|
|
401
|
+
* Resolve the GSD unit phase for Claude Code SDK sessions. Guided-flow
|
|
402
|
+
* dispatch records the authoritative unit type before the turn is queued;
|
|
403
|
+
* prefer that over regex inference from prompt text.
|
|
404
|
+
*/
|
|
405
|
+
export function resolveGsdPhaseForSdk(context: Context, projectRoot: string): string | undefined {
|
|
406
|
+
const resolvedRoot = resolveWorkflowMcpProjectRoot(projectRoot);
|
|
407
|
+
const guided =
|
|
408
|
+
getGuidedUnitContext(resolvedRoot)
|
|
409
|
+
?? getGuidedUnitContext(projectRoot)
|
|
410
|
+
?? getGuidedUnitContext();
|
|
411
|
+
if (guided?.unitType) {
|
|
412
|
+
const guidedRoot = resolveWorkflowMcpProjectRoot(guided.basePath);
|
|
413
|
+
if (guidedRoot === resolvedRoot) {
|
|
414
|
+
return guided.unitType;
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
return inferGsdPhaseFromContext(context);
|
|
418
|
+
}
|
|
419
|
+
|
|
374
420
|
/**
|
|
375
421
|
* Build a full conversational prompt from GSD's context messages.
|
|
376
422
|
*
|
|
@@ -396,10 +442,15 @@ export function buildPromptFromContext(context: Context, toolContext: PromptTool
|
|
|
396
442
|
const workflowToolLine = toolContext.workflowMcpServerName
|
|
397
443
|
? "- GSD workflow tools (gsd_exec, gsd_slice_complete, gsd_task_complete, gsd_plan_slice, gsd_save_gate_result, etc.) " +
|
|
398
444
|
`are MCP tools — call them as mcp__${toolContext.workflowMcpServerName}__<tool_name> ` +
|
|
399
|
-
`(e.g. mcp__${toolContext.workflowMcpServerName}__gsd_exec, mcp__${toolContext.workflowMcpServerName}__gsd_save_gate_result)\n`
|
|
445
|
+
`(e.g. mcp__${toolContext.workflowMcpServerName}__gsd_exec, mcp__${toolContext.workflowMcpServerName}__gsd_save_gate_result)\n` +
|
|
446
|
+
`- Structured user input: call mcp__${toolContext.workflowMcpServerName}__ask_user_questions. ` +
|
|
447
|
+
"Do not call bare ask_user_questions. Do not call native AskUserQuestion.\n"
|
|
400
448
|
: "- GSD workflow MCP tools are unavailable in this Claude Code run.\n";
|
|
401
449
|
const toolSearchLine = toolContext.workflowMcpServerName
|
|
402
|
-
? "- ToolSearch is
|
|
450
|
+
? "- ToolSearch is available only for Claude Code deferred workflow MCP hydration. " +
|
|
451
|
+
`If mcp__${toolContext.workflowMcpServerName}__<tool_name> is missing or Claude Code reports the server is still connecting, ` +
|
|
452
|
+
`use ToolSearch with select:mcp__${toolContext.workflowMcpServerName}__<tool_name> or the base tool name, then call the returned MCP tool directly. ` +
|
|
453
|
+
"Do not use ToolSearch for browser_* tools or general discovery.\n"
|
|
403
454
|
: "- ToolSearch is NOT available — never use it to discover tools\n";
|
|
404
455
|
const browserToolLine = toolContext.browserMcpServerName
|
|
405
456
|
? "- Browser verification uses gsd-browser MCP by default — call browser tools as " +
|
|
@@ -510,9 +561,11 @@ export function buildSdkQueryPrompt(
|
|
|
510
561
|
parent_tool_use_id: null,
|
|
511
562
|
};
|
|
512
563
|
|
|
513
|
-
return
|
|
514
|
-
|
|
515
|
-
|
|
564
|
+
return {
|
|
565
|
+
async *[Symbol.asyncIterator]() {
|
|
566
|
+
yield sdkMessage;
|
|
567
|
+
},
|
|
568
|
+
};
|
|
516
569
|
}
|
|
517
570
|
|
|
518
571
|
// ---------------------------------------------------------------------------
|
|
@@ -534,6 +587,59 @@ function makeErrorMessage(model: string, errorMsg: string): AssistantMessage {
|
|
|
534
587
|
};
|
|
535
588
|
}
|
|
536
589
|
|
|
590
|
+
export interface WorkflowMcpReadinessProgressState {
|
|
591
|
+
contentIndex?: number;
|
|
592
|
+
}
|
|
593
|
+
|
|
594
|
+
export function buildWorkflowMcpReadinessProgressMessage(input: {
|
|
595
|
+
unitType: string;
|
|
596
|
+
workflowServerName: string;
|
|
597
|
+
stage: "preflight" | "retry";
|
|
598
|
+
attempt?: number;
|
|
599
|
+
delayMs?: number;
|
|
600
|
+
}): string {
|
|
601
|
+
const { unitType, workflowServerName, stage } = input;
|
|
602
|
+
if (stage === "preflight") {
|
|
603
|
+
return `Starting ${workflowServerName} MCP for ${unitType}; waiting for workflow tools to register...`;
|
|
604
|
+
}
|
|
605
|
+
|
|
606
|
+
const attempt = input.attempt === undefined ? "" : ` attempt ${input.attempt}`;
|
|
607
|
+
const delay = input.delayMs === undefined ? "" : ` Retrying in ${formatReadinessDelay(input.delayMs)}.`;
|
|
608
|
+
return `Still waiting for ${workflowServerName} MCP tools for ${unitType}${attempt}.${delay}`;
|
|
609
|
+
}
|
|
610
|
+
|
|
611
|
+
function formatReadinessDelay(delayMs: number): string {
|
|
612
|
+
if (delayMs < 1_000) return `${delayMs}ms`;
|
|
613
|
+
const seconds = delayMs / 1_000;
|
|
614
|
+
return Number.isInteger(seconds) ? `${seconds}s` : `${seconds.toFixed(1)}s`;
|
|
615
|
+
}
|
|
616
|
+
|
|
617
|
+
export function pushWorkflowMcpReadinessProgressEvent(input: {
|
|
618
|
+
stream: Pick<AssistantMessageEventStream, "push">;
|
|
619
|
+
partial: AssistantMessage;
|
|
620
|
+
state: WorkflowMcpReadinessProgressState;
|
|
621
|
+
message: string;
|
|
622
|
+
}): void {
|
|
623
|
+
const { stream, partial, state, message } = input;
|
|
624
|
+
if (!message) return;
|
|
625
|
+
|
|
626
|
+
let contentIndex = state.contentIndex;
|
|
627
|
+
const existing = contentIndex === undefined ? undefined : partial.content[contentIndex];
|
|
628
|
+
if (contentIndex === undefined || existing?.type !== "text") {
|
|
629
|
+
contentIndex = partial.content.length;
|
|
630
|
+
state.contentIndex = contentIndex;
|
|
631
|
+
partial.content.push({ type: "text", text: "" });
|
|
632
|
+
stream.push({ type: "text_start", contentIndex, partial });
|
|
633
|
+
}
|
|
634
|
+
|
|
635
|
+
const block = partial.content[contentIndex];
|
|
636
|
+
if (block.type !== "text") return;
|
|
637
|
+
|
|
638
|
+
const delta = block.text.length === 0 ? message : `\n${message}`;
|
|
639
|
+
block.text += delta;
|
|
640
|
+
stream.push({ type: "text_delta", contentIndex, delta, partial });
|
|
641
|
+
}
|
|
642
|
+
|
|
537
643
|
export function isClaudeCodeAbortErrorMessage(message: string | undefined | null): boolean {
|
|
538
644
|
if (!message) return false;
|
|
539
645
|
return /\b(?:claude code process aborted by user|request aborted by user|process aborted by user|aborterror)\b/i.test(message);
|
|
@@ -1591,7 +1697,7 @@ function browserMcpServerNameFromAllowedTools(allowedTools: unknown): string | u
|
|
|
1591
1697
|
if (typeof toolName !== "string") continue;
|
|
1592
1698
|
const parsed = parseAllowedMcpToolName(toolName);
|
|
1593
1699
|
if (!parsed) continue;
|
|
1594
|
-
if (parsed.server === "gsd-browser" || parsed.tool
|
|
1700
|
+
if (parsed.server === "gsd-browser" || hasBrowserContractPrefix(parsed.tool)) {
|
|
1595
1701
|
return parsed.server;
|
|
1596
1702
|
}
|
|
1597
1703
|
}
|
|
@@ -1604,7 +1710,7 @@ function workflowMcpServerNameFromAllowedTools(allowedTools: unknown): string |
|
|
|
1604
1710
|
for (const toolName of allowedTools) {
|
|
1605
1711
|
if (typeof toolName !== "string") continue;
|
|
1606
1712
|
const parsed = parseAllowedMcpToolName(toolName);
|
|
1607
|
-
if (!parsed || parsed.server === browserServerName || parsed.tool
|
|
1713
|
+
if (!parsed || parsed.server === browserServerName || hasBrowserContractPrefix(parsed.tool)) continue;
|
|
1608
1714
|
return parsed.server;
|
|
1609
1715
|
}
|
|
1610
1716
|
return undefined;
|
|
@@ -1662,11 +1768,15 @@ function resolveExactWorkflowMcpToolsForPhase(
|
|
|
1662
1768
|
workflowExplicitlyBlocked: boolean,
|
|
1663
1769
|
): string[] {
|
|
1664
1770
|
if (!gsdPhase || !workflowServerName || workflowExplicitlyBlocked) return [];
|
|
1665
|
-
const
|
|
1771
|
+
const requestedTools = gsdPhase === "run-uat"
|
|
1666
1772
|
? [...RUN_UAT_WORKFLOW_TOOL_NAMES]
|
|
1667
|
-
:
|
|
1668
|
-
|
|
1669
|
-
|
|
1773
|
+
: [
|
|
1774
|
+
...(getUnitToolSurfaceContract(gsdPhase)?.allowedGsdTools ?? []),
|
|
1775
|
+
...getRequiredWorkflowToolsForAutoUnit(gsdPhase),
|
|
1776
|
+
];
|
|
1777
|
+
const requestedToolNames = [...new Set(
|
|
1778
|
+
requestedTools.filter((toolName) => toolName.startsWith("gsd_") || toolName === "ask_user_questions"),
|
|
1779
|
+
)];
|
|
1670
1780
|
if (requestedToolNames.length === 0) return [];
|
|
1671
1781
|
return resolveToolPresentationPlan({
|
|
1672
1782
|
phase: gsdPhase,
|
|
@@ -1676,6 +1786,25 @@ function resolveExactWorkflowMcpToolsForPhase(
|
|
|
1676
1786
|
}).presentedToolNames;
|
|
1677
1787
|
}
|
|
1678
1788
|
|
|
1789
|
+
function resolveClaudeNativeToolsForPhase(gsdPhase: string | undefined): string[] {
|
|
1790
|
+
const standardClaudeTools = [
|
|
1791
|
+
"Read",
|
|
1792
|
+
"Write",
|
|
1793
|
+
"Edit",
|
|
1794
|
+
"Glob",
|
|
1795
|
+
"Grep",
|
|
1796
|
+
"Bash",
|
|
1797
|
+
"Agent",
|
|
1798
|
+
"WebFetch",
|
|
1799
|
+
"WebSearch",
|
|
1800
|
+
];
|
|
1801
|
+
if (!gsdPhase) return standardClaudeTools;
|
|
1802
|
+
if (gsdPhase === "run-uat" || gsdPhase === "complete-slice") {
|
|
1803
|
+
return [...RUN_UAT_CLAUDE_NATIVE_TOOL_NAMES];
|
|
1804
|
+
}
|
|
1805
|
+
return standardClaudeTools;
|
|
1806
|
+
}
|
|
1807
|
+
|
|
1679
1808
|
export function autoInitClaudeCodeWorkflowMcp(cwd: string): void {
|
|
1680
1809
|
const projectRoot = resolveWorkflowMcpProjectRoot(cwd);
|
|
1681
1810
|
try {
|
|
@@ -1689,6 +1818,70 @@ export function autoInitClaudeCodeWorkflowMcp(cwd: string): void {
|
|
|
1689
1818
|
}
|
|
1690
1819
|
}
|
|
1691
1820
|
|
|
1821
|
+
export function resolveClaudeCodeToolSurfaceReadinessError(input: {
|
|
1822
|
+
unitType: string | undefined;
|
|
1823
|
+
workflowServerName: string | undefined;
|
|
1824
|
+
observation: LiveToolSurfaceObservation;
|
|
1825
|
+
projectRoot?: string | undefined;
|
|
1826
|
+
allowPendingToolSearchHydration?: boolean | undefined;
|
|
1827
|
+
}): Promise<string | null> {
|
|
1828
|
+
const error = getToolSurfaceReadinessError(input);
|
|
1829
|
+
if (
|
|
1830
|
+
error
|
|
1831
|
+
&& input.allowPendingToolSearchHydration
|
|
1832
|
+
&& input.workflowServerName
|
|
1833
|
+
&& input.observation.mcpServers.some(
|
|
1834
|
+
(server) => server.name === input.workflowServerName && server.status === "pending",
|
|
1835
|
+
)
|
|
1836
|
+
) {
|
|
1837
|
+
return Promise.resolve(null);
|
|
1838
|
+
}
|
|
1839
|
+
return Promise.resolve(error);
|
|
1840
|
+
}
|
|
1841
|
+
|
|
1842
|
+
export { awaitWorkflowMcpToolRegistration } from "../gsd/tool-surface-readiness.js";
|
|
1843
|
+
|
|
1844
|
+
const TOOL_SURFACE_READINESS_RETRY_DELAYS_MS = [500, 1_000, 2_000, 4_000, 8_000, 15_000, 15_000, 15_000] as const;
|
|
1845
|
+
|
|
1846
|
+
export function shouldRetryClaudeCodeToolSurfaceReadiness(error: string | null): boolean {
|
|
1847
|
+
if (!error) return false;
|
|
1848
|
+
return error.includes(TOOL_SURFACE_NOT_READY) && !/\bterminal\b/i.test(error);
|
|
1849
|
+
}
|
|
1850
|
+
|
|
1851
|
+
export function resolveClaudeCodeToolSurfaceReadinessRetryDelayMs(
|
|
1852
|
+
error: string | null,
|
|
1853
|
+
attempt: number,
|
|
1854
|
+
preflightVerified = false,
|
|
1855
|
+
): number | null {
|
|
1856
|
+
if (!shouldRetryClaudeCodeToolSurfaceReadiness(error)) return null;
|
|
1857
|
+
const delays = preflightVerified
|
|
1858
|
+
? POST_PREFLIGHT_READINESS_RETRY_DELAYS_MS
|
|
1859
|
+
: TOOL_SURFACE_READINESS_RETRY_DELAYS_MS;
|
|
1860
|
+
return delays[attempt] ?? null;
|
|
1861
|
+
}
|
|
1862
|
+
|
|
1863
|
+
function makeAbortError(): Error {
|
|
1864
|
+
const error = new Error("AbortError: The operation was aborted");
|
|
1865
|
+
error.name = "AbortError";
|
|
1866
|
+
return error;
|
|
1867
|
+
}
|
|
1868
|
+
|
|
1869
|
+
function delay(ms: number, signal?: AbortSignal): Promise<void> {
|
|
1870
|
+
if (signal?.aborted) return Promise.reject(makeAbortError());
|
|
1871
|
+
|
|
1872
|
+
return new Promise((resolve, reject) => {
|
|
1873
|
+
const timeout = setTimeout(() => {
|
|
1874
|
+
signal?.removeEventListener("abort", onAbort);
|
|
1875
|
+
resolve();
|
|
1876
|
+
}, ms);
|
|
1877
|
+
const onAbort = (): void => {
|
|
1878
|
+
clearTimeout(timeout);
|
|
1879
|
+
reject(makeAbortError());
|
|
1880
|
+
};
|
|
1881
|
+
signal?.addEventListener("abort", onAbort, { once: true });
|
|
1882
|
+
});
|
|
1883
|
+
}
|
|
1884
|
+
|
|
1692
1885
|
/**
|
|
1693
1886
|
* Build the options object passed to the Claude Agent SDK's `query()` call.
|
|
1694
1887
|
*
|
|
@@ -1839,34 +2032,27 @@ export function buildSdkOptions(
|
|
|
1839
2032
|
`mcp__${workflowServerName}__gsd_save_gate_result`,
|
|
1840
2033
|
]
|
|
1841
2034
|
: [];
|
|
2035
|
+
const allowToolSearchForWorkflowMcp = workflowMcpTools.length > 0 || exactWorkflowMcpTools.length > 0;
|
|
1842
2036
|
const disallowedTools: string[] = [...new Set([
|
|
1843
|
-
"ToolSearch",
|
|
2037
|
+
...(allowToolSearchForWorkflowMcp ? [] : ["ToolSearch"]),
|
|
2038
|
+
...(gsdPhase ? ["Skill"] : []),
|
|
1844
2039
|
...(workflowMcpTools.length > 0 || exactWorkflowMcpTools.length > 0 ? ["AskUserQuestion"] : []),
|
|
1845
2040
|
...questionToolSurface.disallowedTools,
|
|
1846
2041
|
...runUatDisallowedTools,
|
|
1847
2042
|
...extraDisallowedTools,
|
|
1848
2043
|
])];
|
|
1849
|
-
const
|
|
1850
|
-
"Read",
|
|
1851
|
-
"Write",
|
|
1852
|
-
"Edit",
|
|
1853
|
-
"Glob",
|
|
1854
|
-
"Grep",
|
|
1855
|
-
"Bash",
|
|
1856
|
-
"Agent",
|
|
1857
|
-
"WebFetch",
|
|
1858
|
-
"WebSearch",
|
|
1859
|
-
];
|
|
2044
|
+
const nativeTools = resolveClaudeNativeToolsForPhase(gsdPhase);
|
|
1860
2045
|
const allowedTools = gsdPhase === "run-uat"
|
|
1861
2046
|
? [
|
|
1862
|
-
...
|
|
2047
|
+
...nativeTools,
|
|
1863
2048
|
...(exactWorkflowMcpTools.length > 0 ? exactWorkflowMcpTools : []),
|
|
1864
2049
|
...allowedBrowserMcpTools,
|
|
1865
2050
|
]
|
|
1866
2051
|
: [
|
|
1867
|
-
...
|
|
2052
|
+
...nativeTools,
|
|
1868
2053
|
...exactWorkflowMcpTools,
|
|
1869
|
-
...(workflowMcpTools.length > 0 ? workflowMcpTools : [
|
|
2054
|
+
...(!gsdPhase && workflowMcpTools.length > 0 ? workflowMcpTools : []),
|
|
2055
|
+
...(workflowMcpTools.length === 0 && exactWorkflowMcpTools.length === 0 ? ["AskUserQuestion"] : []),
|
|
1870
2056
|
...allowedBrowserMcpTools,
|
|
1871
2057
|
];
|
|
1872
2058
|
const supportsAdaptive = modelSupportsAdaptiveThinking(modelId);
|
|
@@ -1937,6 +2123,20 @@ export function streamViaClaudeCode(
|
|
|
1937
2123
|
return stream;
|
|
1938
2124
|
}
|
|
1939
2125
|
|
|
2126
|
+
interface SdkAttemptMessageState {
|
|
2127
|
+
builder: PartialMessageBuilder | null;
|
|
2128
|
+
intermediateToolBlocks: AssistantMessage["content"];
|
|
2129
|
+
toolResultsById: Map<string, ExternalToolResultPayload>;
|
|
2130
|
+
}
|
|
2131
|
+
|
|
2132
|
+
function createSdkAttemptMessageState(): SdkAttemptMessageState {
|
|
2133
|
+
return {
|
|
2134
|
+
builder: null,
|
|
2135
|
+
intermediateToolBlocks: [],
|
|
2136
|
+
toolResultsById: new Map<string, ExternalToolResultPayload>(),
|
|
2137
|
+
};
|
|
2138
|
+
}
|
|
2139
|
+
|
|
1940
2140
|
/** Async pump that drives the Claude Agent SDK's async-iterable message stream and pushes events into `stream`. */
|
|
1941
2141
|
async function pumpSdkMessages(
|
|
1942
2142
|
model: Model<any>,
|
|
@@ -1945,38 +2145,30 @@ async function pumpSdkMessages(
|
|
|
1945
2145
|
stream: AssistantMessageEventStream,
|
|
1946
2146
|
): Promise<void> {
|
|
1947
2147
|
const modelId = model.id;
|
|
1948
|
-
let builder: PartialMessageBuilder | null = null;
|
|
1949
2148
|
/** Track the last text content seen across all assistant turns for the final message. */
|
|
1950
2149
|
let lastTextContent = "";
|
|
1951
2150
|
let lastThinkingContent = "";
|
|
1952
|
-
/** Collect tool blocks from intermediate SDK turns for tool execution rendering. */
|
|
1953
|
-
const intermediateToolBlocks: AssistantMessage["content"] = [];
|
|
1954
|
-
/** Preserve real external tool results from Claude Code's synthetic user messages. */
|
|
1955
|
-
const toolResultsById = new Map<string, ExternalToolResultPayload>();
|
|
1956
2151
|
|
|
1957
2152
|
try {
|
|
1958
|
-
// Dynamic import — the SDK is an optional dependency.
|
|
1959
|
-
const sdkModule = "@anthropic-ai/claude-agent-sdk";
|
|
1960
|
-
const sdk = (await import(/* webpackIgnore: true */ sdkModule)) as {
|
|
1961
|
-
query: (args: {
|
|
1962
|
-
prompt: string | AsyncIterable<unknown>;
|
|
1963
|
-
options?: Record<string, unknown>;
|
|
1964
|
-
}) => AsyncIterable<SDKMessage>;
|
|
1965
|
-
};
|
|
1966
|
-
|
|
1967
|
-
// Bridge GSD's AbortSignal to SDK's AbortController
|
|
1968
|
-
const controller = new AbortController();
|
|
1969
|
-
if (options?.signal) {
|
|
1970
|
-
options.signal.addEventListener("abort", () => controller.abort(), { once: true });
|
|
1971
|
-
}
|
|
1972
|
-
|
|
1973
2153
|
const permissionMode = await resolveClaudePermissionMode();
|
|
1974
|
-
const
|
|
1975
|
-
const
|
|
1976
|
-
const
|
|
2154
|
+
const claudeOptions = options as ClaudeCodeStreamOptions | undefined;
|
|
2155
|
+
const uiContext = claudeOptions?.extensionUIContext;
|
|
2156
|
+
const onExternalToolCall = claudeOptions?.onExternalToolCall;
|
|
2157
|
+
const onExternalToolResult = claudeOptions?.onExternalToolResult;
|
|
2158
|
+
const sdkQueryForTest = claudeOptions?._sdkQueryForTest;
|
|
2159
|
+
const query = sdkQueryForTest ?? (
|
|
2160
|
+
// Dynamic import — the SDK is an optional dependency.
|
|
2161
|
+
(await import(/* webpackIgnore: true */ "@anthropic-ai/claude-agent-sdk")) as {
|
|
2162
|
+
query: (args: {
|
|
2163
|
+
prompt: string | AsyncIterable<unknown>;
|
|
2164
|
+
options?: Record<string, unknown>;
|
|
2165
|
+
}) => AsyncIterable<SDKMessage>;
|
|
2166
|
+
}
|
|
2167
|
+
).query;
|
|
1977
2168
|
const cwd = resolveClaudeCodeCwd(options);
|
|
2169
|
+
const projectRoot = resolveWorkflowMcpProjectRoot(cwd);
|
|
1978
2170
|
autoInitClaudeCodeWorkflowMcp(cwd);
|
|
1979
|
-
const gsdPhase =
|
|
2171
|
+
const gsdPhase = resolveGsdPhaseForSdk(context, projectRoot);
|
|
1980
2172
|
const canUseToolHandler = createClaudeCodeCanUseToolHandler(uiContext);
|
|
1981
2173
|
// When no UI is available (headless / auto-mode), auto-approve all
|
|
1982
2174
|
// tool requests. This replaces the old bypassPermissions workaround.
|
|
@@ -2000,20 +2192,15 @@ async function pumpSdkMessages(
|
|
|
2000
2192
|
},
|
|
2001
2193
|
);
|
|
2002
2194
|
const workflowMcpServerName = workflowMcpServerNameFromAllowedTools(sdkOpts.allowedTools);
|
|
2195
|
+
const allowPendingToolSearchHydration =
|
|
2196
|
+
Boolean(workflowMcpServerName && gsdPhase)
|
|
2197
|
+
&& !(sdkOpts.disallowedTools as string[] | undefined)?.includes("ToolSearch");
|
|
2003
2198
|
const prompt = buildPromptFromContext(context, {
|
|
2004
2199
|
workflowMcpServerName,
|
|
2005
2200
|
browserMcpServerName: browserMcpServerNameFromAllowedTools(sdkOpts.allowedTools),
|
|
2006
2201
|
});
|
|
2007
2202
|
const queryPrompt = buildSdkQueryPrompt(context, prompt);
|
|
2008
2203
|
|
|
2009
|
-
const queryResult = sdk.query({
|
|
2010
|
-
prompt: queryPrompt,
|
|
2011
|
-
options: {
|
|
2012
|
-
...sdkOpts,
|
|
2013
|
-
abortController: controller,
|
|
2014
|
-
},
|
|
2015
|
-
});
|
|
2016
|
-
|
|
2017
2204
|
// Emit start with an empty partial
|
|
2018
2205
|
const initialPartial: AssistantMessage = {
|
|
2019
2206
|
role: "assistant",
|
|
@@ -2026,201 +2213,320 @@ async function pumpSdkMessages(
|
|
|
2026
2213
|
timestamp: Date.now(),
|
|
2027
2214
|
};
|
|
2028
2215
|
stream.push({ type: "start", partial: initialPartial });
|
|
2216
|
+
const readinessProgressState: WorkflowMcpReadinessProgressState = {};
|
|
2029
2217
|
|
|
2030
|
-
|
|
2031
|
-
|
|
2032
|
-
|
|
2033
|
-
|
|
2034
|
-
|
|
2035
|
-
|
|
2036
|
-
|
|
2037
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
2040
|
-
|
|
2218
|
+
const trackWorkflowMcpSdk = Boolean(workflowMcpServerName && gsdPhase);
|
|
2219
|
+
if (trackWorkflowMcpSdk) beginWorkflowMcpSdkSession();
|
|
2220
|
+
try {
|
|
2221
|
+
let workflowMcpPreflightVerified = false;
|
|
2222
|
+
const shouldRunWorkflowMcpPreflight =
|
|
2223
|
+
workflowMcpServerName && gsdPhase && !claudeOptions?._skipWorkflowMcpPreflightForTest;
|
|
2224
|
+
if (shouldRunWorkflowMcpPreflight) {
|
|
2225
|
+
try {
|
|
2226
|
+
const progressMessage = buildWorkflowMcpReadinessProgressMessage({
|
|
2227
|
+
unitType: gsdPhase,
|
|
2228
|
+
workflowServerName: workflowMcpServerName,
|
|
2229
|
+
stage: "preflight",
|
|
2230
|
+
});
|
|
2231
|
+
pushWorkflowMcpReadinessProgressEvent({
|
|
2232
|
+
stream,
|
|
2233
|
+
partial: initialPartial,
|
|
2234
|
+
state: readinessProgressState,
|
|
2235
|
+
message: progressMessage,
|
|
2236
|
+
});
|
|
2237
|
+
uiContext?.setStatus?.("gsd-step", progressMessage);
|
|
2238
|
+
const preflightError = await awaitWorkflowMcpToolRegistration({
|
|
2239
|
+
unitType: gsdPhase,
|
|
2240
|
+
workflowServerName: workflowMcpServerName,
|
|
2241
|
+
projectRoot,
|
|
2242
|
+
signal: options?.signal,
|
|
2243
|
+
});
|
|
2244
|
+
if (preflightError) {
|
|
2245
|
+
stream.push({
|
|
2246
|
+
type: "error",
|
|
2247
|
+
reason: "error",
|
|
2248
|
+
error: makeErrorMessage(modelId, preflightError),
|
|
2249
|
+
});
|
|
2250
|
+
return;
|
|
2251
|
+
}
|
|
2252
|
+
workflowMcpPreflightVerified = true;
|
|
2253
|
+
} finally {
|
|
2254
|
+
uiContext?.setStatus?.("gsd-step", "");
|
|
2255
|
+
}
|
|
2256
|
+
if (workflowMcpPreflightVerified) {
|
|
2257
|
+
await delay(POST_PREFLIGHT_SDK_SETTLE_MS, options?.signal);
|
|
2258
|
+
}
|
|
2041
2259
|
}
|
|
2042
2260
|
|
|
2043
|
-
|
|
2044
|
-
|
|
2045
|
-
|
|
2046
|
-
|
|
2047
|
-
|
|
2048
|
-
|
|
2049
|
-
|
|
2050
|
-
|
|
2051
|
-
|
|
2052
|
-
|
|
2053
|
-
|
|
2054
|
-
|
|
2055
|
-
|
|
2056
|
-
|
|
2057
|
-
}
|
|
2058
|
-
|
|
2059
|
-
|
|
2060
|
-
|
|
2061
|
-
|
|
2062
|
-
|
|
2261
|
+
sdkAttemptLoop:
|
|
2262
|
+
for (let readinessAttempt = 0; ; readinessAttempt++) {
|
|
2263
|
+
let { builder, intermediateToolBlocks, toolResultsById } = createSdkAttemptMessageState();
|
|
2264
|
+
const controller = new AbortController();
|
|
2265
|
+
const forwardAbort = (): void => controller.abort();
|
|
2266
|
+
if (options?.signal) {
|
|
2267
|
+
options.signal.addEventListener("abort", forwardAbort, { once: true });
|
|
2268
|
+
}
|
|
2269
|
+
|
|
2270
|
+
const queryResult = query({
|
|
2271
|
+
prompt: queryPrompt,
|
|
2272
|
+
options: {
|
|
2273
|
+
...sdkOpts,
|
|
2274
|
+
abortController: controller,
|
|
2275
|
+
},
|
|
2276
|
+
});
|
|
2277
|
+
|
|
2278
|
+
try {
|
|
2279
|
+
for await (const msg of queryResult as AsyncIterable<SDKMessage>) {
|
|
2280
|
+
if (options?.signal?.aborted) {
|
|
2281
|
+
// User-initiated cancel — emit an aborted error so the agent
|
|
2282
|
+
// loop classifies this as a deliberate stop, not a transient
|
|
2283
|
+
// provider failure that should be retried.
|
|
2284
|
+
stream.push({
|
|
2285
|
+
type: "error",
|
|
2286
|
+
reason: "aborted",
|
|
2287
|
+
error: makeAbortedMessage(modelId, lastTextContent),
|
|
2063
2288
|
});
|
|
2064
|
-
|
|
2065
|
-
controller.abort();
|
|
2066
|
-
stream.push({
|
|
2067
|
-
type: "error",
|
|
2068
|
-
reason: "error",
|
|
2069
|
-
error: makeErrorMessage(modelId, readinessError),
|
|
2070
|
-
});
|
|
2071
|
-
return;
|
|
2072
|
-
}
|
|
2289
|
+
return;
|
|
2073
2290
|
}
|
|
2074
|
-
break;
|
|
2075
|
-
}
|
|
2076
2291
|
|
|
2077
|
-
|
|
2078
|
-
|
|
2079
|
-
|
|
2080
|
-
|
|
2081
|
-
|
|
2082
|
-
|
|
2083
|
-
|
|
2084
|
-
|
|
2085
|
-
|
|
2086
|
-
|
|
2087
|
-
|
|
2088
|
-
|
|
2089
|
-
|
|
2090
|
-
|
|
2091
|
-
|
|
2092
|
-
|
|
2093
|
-
|
|
2094
|
-
|
|
2292
|
+
switch (msg.type) {
|
|
2293
|
+
// -- Init --
|
|
2294
|
+
case "system": {
|
|
2295
|
+
// Tool Surface Readiness gate: the init message is the first (and
|
|
2296
|
+
// only) point where the session reports its live tool surface and
|
|
2297
|
+
// MCP server statuses. If the workflow server failed or has not
|
|
2298
|
+
// registered this Unit's required tools, abort before the first
|
|
2299
|
+
// model turn with a transient, recovery-classifiable error
|
|
2300
|
+
// (tool-unavailable → retry) instead of letting the model hit
|
|
2301
|
+
// "No such tool available" mid-Unit and improvise around it.
|
|
2302
|
+
const init = msg as unknown as {
|
|
2303
|
+
subtype?: string;
|
|
2304
|
+
tools?: string[];
|
|
2305
|
+
mcp_servers?: { name: string; status: string }[];
|
|
2306
|
+
};
|
|
2307
|
+
if (init.subtype === "init") {
|
|
2308
|
+
const readinessError = await resolveClaudeCodeToolSurfaceReadinessError({
|
|
2309
|
+
unitType: gsdPhase,
|
|
2310
|
+
workflowServerName: workflowMcpServerName,
|
|
2311
|
+
projectRoot,
|
|
2312
|
+
observation: { tools: init.tools ?? [], mcpServers: init.mcp_servers ?? [] },
|
|
2313
|
+
allowPendingToolSearchHydration,
|
|
2314
|
+
});
|
|
2315
|
+
if (readinessError) {
|
|
2316
|
+
const retryDelayMs = resolveClaudeCodeToolSurfaceReadinessRetryDelayMs(
|
|
2317
|
+
readinessError,
|
|
2318
|
+
readinessAttempt,
|
|
2319
|
+
workflowMcpPreflightVerified,
|
|
2320
|
+
);
|
|
2321
|
+
if (retryDelayMs !== null && !options?.signal?.aborted) {
|
|
2322
|
+
controller.abort();
|
|
2323
|
+
const progressMessage = buildWorkflowMcpReadinessProgressMessage({
|
|
2324
|
+
unitType: gsdPhase ?? "workflow unit",
|
|
2325
|
+
workflowServerName: workflowMcpServerName ?? "workflow",
|
|
2326
|
+
stage: "retry",
|
|
2327
|
+
attempt: readinessAttempt + 1,
|
|
2328
|
+
delayMs: retryDelayMs,
|
|
2329
|
+
});
|
|
2330
|
+
pushWorkflowMcpReadinessProgressEvent({
|
|
2331
|
+
stream,
|
|
2332
|
+
partial: initialPartial,
|
|
2333
|
+
state: readinessProgressState,
|
|
2334
|
+
message: progressMessage,
|
|
2335
|
+
});
|
|
2336
|
+
uiContext?.setStatus?.("gsd-step", progressMessage);
|
|
2337
|
+
await delay(retryDelayMs, options?.signal);
|
|
2338
|
+
uiContext?.setStatus?.("gsd-step", "");
|
|
2339
|
+
continue sdkAttemptLoop;
|
|
2340
|
+
}
|
|
2341
|
+
controller.abort();
|
|
2342
|
+
stream.push({
|
|
2343
|
+
type: "error",
|
|
2344
|
+
reason: "error",
|
|
2345
|
+
error: makeErrorMessage(modelId, readinessError),
|
|
2346
|
+
});
|
|
2347
|
+
return;
|
|
2095
2348
|
}
|
|
2096
2349
|
}
|
|
2350
|
+
break;
|
|
2097
2351
|
}
|
|
2098
|
-
}
|
|
2099
|
-
break;
|
|
2100
|
-
}
|
|
2101
2352
|
|
|
2102
|
-
|
|
2103
|
-
|
|
2104
|
-
|
|
2105
|
-
|
|
2106
|
-
|
|
2107
|
-
|
|
2108
|
-
|
|
2109
|
-
|
|
2110
|
-
|
|
2111
|
-
|
|
2353
|
+
// -- Streaming partial messages --
|
|
2354
|
+
case "stream_event": {
|
|
2355
|
+
const partial = msg as SDKPartialAssistantMessage;
|
|
2356
|
+
|
|
2357
|
+
const event = partial.event;
|
|
2358
|
+
|
|
2359
|
+
const result = handleClaudeCodePartialStreamEvent(builder, event, modelId);
|
|
2360
|
+
builder = result.builder;
|
|
2361
|
+
const assistantEvent = result.assistantEvent;
|
|
2362
|
+
if (assistantEvent) {
|
|
2363
|
+
stream.push(assistantEvent);
|
|
2364
|
+
if (assistantEvent.type === "toolcall_start") {
|
|
2365
|
+
const toolBlock = assistantEvent.partial.content[assistantEvent.contentIndex];
|
|
2366
|
+
if (toolBlock?.type === "toolCall") {
|
|
2367
|
+
try {
|
|
2368
|
+
await onExternalToolCall?.(toolBlock);
|
|
2369
|
+
} catch (error) {
|
|
2370
|
+
console.warn("[claude-code] onExternalToolCall callback failed:", error);
|
|
2371
|
+
}
|
|
2372
|
+
}
|
|
2373
|
+
}
|
|
2374
|
+
}
|
|
2375
|
+
break;
|
|
2112
2376
|
}
|
|
2113
|
-
}
|
|
2114
|
-
break;
|
|
2115
|
-
}
|
|
2116
2377
|
|
|
2117
|
-
|
|
2118
|
-
|
|
2119
|
-
|
|
2120
|
-
|
|
2121
|
-
|
|
2122
|
-
|
|
2123
|
-
|
|
2124
|
-
|
|
2125
|
-
|
|
2126
|
-
|
|
2127
|
-
|
|
2128
|
-
intermediateToolBlocks.push(block);
|
|
2378
|
+
// -- Complete assistant message (non-streaming fallback) --
|
|
2379
|
+
case "assistant": {
|
|
2380
|
+
const sdkAssistant = msg as SDKAssistantMessage;
|
|
2381
|
+
|
|
2382
|
+
// Capture text content from complete messages
|
|
2383
|
+
for (const block of sdkAssistant.message.content) {
|
|
2384
|
+
if (block.type === "text") {
|
|
2385
|
+
lastTextContent = block.text;
|
|
2386
|
+
} else if (block.type === "thinking") {
|
|
2387
|
+
lastThinkingContent = block.thinking;
|
|
2388
|
+
}
|
|
2129
2389
|
}
|
|
2390
|
+
break;
|
|
2130
2391
|
}
|
|
2131
|
-
}
|
|
2132
2392
|
|
|
2133
|
-
|
|
2134
|
-
|
|
2135
|
-
|
|
2136
|
-
|
|
2137
|
-
|
|
2138
|
-
|
|
2139
|
-
|
|
2140
|
-
|
|
2141
|
-
|
|
2142
|
-
|
|
2143
|
-
|
|
2144
|
-
|
|
2145
|
-
|
|
2146
|
-
if (!extResult) continue;
|
|
2147
|
-
const contentIndex = builder.message.content.indexOf(block);
|
|
2148
|
-
if (contentIndex < 0) continue;
|
|
2149
|
-
// Push synthetic completion events with result attached so the
|
|
2150
|
-
// chat-controller can update pending ToolExecutionComponents.
|
|
2151
|
-
if (block.type === "toolCall") {
|
|
2152
|
-
try {
|
|
2153
|
-
await onExternalToolResult?.({
|
|
2154
|
-
toolCall: block,
|
|
2155
|
-
result: extResult,
|
|
2156
|
-
});
|
|
2157
|
-
} catch (error) {
|
|
2158
|
-
console.warn("[claude-code] onExternalToolResult callback failed:", error);
|
|
2393
|
+
// -- User message (synthetic tool result — signals turn boundary) --
|
|
2394
|
+
case "user": {
|
|
2395
|
+
// Capture content from the completed turn before resetting
|
|
2396
|
+
if (builder) {
|
|
2397
|
+
for (const block of builder.message.content) {
|
|
2398
|
+
if (block.type === "text" && block.text) {
|
|
2399
|
+
lastTextContent = block.text;
|
|
2400
|
+
} else if (block.type === "thinking" && block.thinking) {
|
|
2401
|
+
lastThinkingContent = block.thinking;
|
|
2402
|
+
} else if (block.type === "toolCall" || block.type === "serverToolUse") {
|
|
2403
|
+
// Collect tool blocks for externalToolExecution rendering
|
|
2404
|
+
intermediateToolBlocks.push(block);
|
|
2405
|
+
}
|
|
2159
2406
|
}
|
|
2160
|
-
|
|
2161
|
-
|
|
2162
|
-
|
|
2163
|
-
|
|
2164
|
-
|
|
2165
|
-
|
|
2166
|
-
}
|
|
2167
|
-
|
|
2168
|
-
|
|
2169
|
-
|
|
2170
|
-
|
|
2171
|
-
|
|
2172
|
-
|
|
2173
|
-
|
|
2407
|
+
}
|
|
2408
|
+
|
|
2409
|
+
// Extract tool results from the SDK's synthetic user message
|
|
2410
|
+
// and attach to corresponding tool call blocks immediately.
|
|
2411
|
+
for (const { toolUseId, result } of extractToolResultsFromSdkUserMessage(msg as SDKUserMessage)) {
|
|
2412
|
+
toolResultsById.set(toolUseId, result);
|
|
2413
|
+
}
|
|
2414
|
+
attachExternalResultsToToolBlocks(intermediateToolBlocks, toolResultsById);
|
|
2415
|
+
|
|
2416
|
+
// Push a synthetic toolcall_end for each tool call from this turn
|
|
2417
|
+
// so the TUI can render tool results in real-time during the SDK
|
|
2418
|
+
// session instead of waiting until the entire session completes.
|
|
2419
|
+
if (builder) {
|
|
2420
|
+
for (const block of builder.message.content) {
|
|
2421
|
+
const extResult = (block as ToolCallWithExternalResult).externalResult;
|
|
2422
|
+
if (!extResult) continue;
|
|
2423
|
+
const contentIndex = builder.message.content.indexOf(block);
|
|
2424
|
+
if (contentIndex < 0) continue;
|
|
2425
|
+
const suppressDuplicateUnavailable = shouldSuppressDuplicateToolUnavailableBlock(
|
|
2426
|
+
block,
|
|
2427
|
+
builder.message.content,
|
|
2428
|
+
);
|
|
2429
|
+
// Push synthetic completion events with result attached so the
|
|
2430
|
+
// chat-controller can update pending ToolExecutionComponents.
|
|
2431
|
+
if (block.type === "toolCall") {
|
|
2432
|
+
if (suppressDuplicateUnavailable) {
|
|
2433
|
+
delete (block as ToolCallWithExternalResult).externalResult;
|
|
2434
|
+
stream.push({
|
|
2435
|
+
type: "toolcall_end",
|
|
2436
|
+
contentIndex,
|
|
2437
|
+
toolCall: block,
|
|
2438
|
+
partial: builder.message,
|
|
2439
|
+
});
|
|
2440
|
+
(block as ToolCallWithExternalResult).externalResult = extResult;
|
|
2441
|
+
continue;
|
|
2442
|
+
}
|
|
2443
|
+
try {
|
|
2444
|
+
await onExternalToolResult?.({
|
|
2445
|
+
toolCall: block,
|
|
2446
|
+
result: extResult,
|
|
2447
|
+
});
|
|
2448
|
+
} catch (error) {
|
|
2449
|
+
console.warn("[claude-code] onExternalToolResult callback failed:", error);
|
|
2450
|
+
}
|
|
2451
|
+
stream.push({
|
|
2452
|
+
type: "toolcall_end",
|
|
2453
|
+
contentIndex,
|
|
2454
|
+
toolCall: block,
|
|
2455
|
+
partial: builder.message,
|
|
2456
|
+
});
|
|
2457
|
+
} else if (block.type === "serverToolUse") {
|
|
2458
|
+
try {
|
|
2459
|
+
await onExternalToolResult?.({
|
|
2460
|
+
toolCall: serverToolUseToToolCallLike(block),
|
|
2461
|
+
result: extResult,
|
|
2462
|
+
});
|
|
2463
|
+
} catch (error) {
|
|
2464
|
+
console.warn("[claude-code] onExternalToolResult callback failed:", error);
|
|
2465
|
+
}
|
|
2466
|
+
stream.push({
|
|
2467
|
+
type: "server_tool_use",
|
|
2468
|
+
contentIndex,
|
|
2469
|
+
partial: builder.message,
|
|
2470
|
+
});
|
|
2471
|
+
}
|
|
2174
2472
|
}
|
|
2175
|
-
stream.push({
|
|
2176
|
-
type: "server_tool_use",
|
|
2177
|
-
contentIndex,
|
|
2178
|
-
partial: builder.message,
|
|
2179
|
-
});
|
|
2180
2473
|
}
|
|
2474
|
+
|
|
2475
|
+
builder = null;
|
|
2476
|
+
break;
|
|
2181
2477
|
}
|
|
2182
|
-
}
|
|
2183
2478
|
|
|
2184
|
-
|
|
2185
|
-
|
|
2186
|
-
|
|
2479
|
+
// -- Result (terminal) --
|
|
2480
|
+
case "result": {
|
|
2481
|
+
const result = msg as SDKResultMessage;
|
|
2482
|
+
const finalContent = buildFinalAssistantContent({
|
|
2483
|
+
intermediateToolBlocks,
|
|
2484
|
+
pendingContent: builder?.message.content,
|
|
2485
|
+
toolResultsById,
|
|
2486
|
+
lastThinkingContent,
|
|
2487
|
+
lastTextContent,
|
|
2488
|
+
fallbackResultText:
|
|
2489
|
+
result.subtype === "success" && result.result ? result.result : undefined,
|
|
2490
|
+
});
|
|
2187
2491
|
|
|
2188
|
-
|
|
2189
|
-
|
|
2190
|
-
|
|
2191
|
-
|
|
2192
|
-
|
|
2193
|
-
|
|
2194
|
-
|
|
2195
|
-
|
|
2196
|
-
|
|
2197
|
-
|
|
2198
|
-
result.subtype === "success" && result.result ? result.result : undefined,
|
|
2199
|
-
});
|
|
2492
|
+
const finalMessage: AssistantMessage = {
|
|
2493
|
+
role: "assistant",
|
|
2494
|
+
content: finalContent,
|
|
2495
|
+
api: "anthropic-messages",
|
|
2496
|
+
provider: "claude-code",
|
|
2497
|
+
model: modelId,
|
|
2498
|
+
usage: mapUsage(result.usage, result.total_cost_usd),
|
|
2499
|
+
stopReason: result.is_error ? "error" : "stop",
|
|
2500
|
+
timestamp: Date.now(),
|
|
2501
|
+
};
|
|
2200
2502
|
|
|
2201
|
-
|
|
2202
|
-
|
|
2203
|
-
|
|
2204
|
-
|
|
2205
|
-
|
|
2206
|
-
|
|
2207
|
-
|
|
2208
|
-
|
|
2209
|
-
|
|
2210
|
-
|
|
2211
|
-
|
|
2212
|
-
if (result.is_error) {
|
|
2213
|
-
finalMessage.errorMessage = getResultErrorMessage(result);
|
|
2214
|
-
stream.push({ type: "error", reason: "error", error: finalMessage });
|
|
2215
|
-
} else {
|
|
2216
|
-
stream.push({ type: "done", reason: "stop", message: finalMessage });
|
|
2503
|
+
if (result.is_error) {
|
|
2504
|
+
finalMessage.errorMessage = getResultErrorMessage(result);
|
|
2505
|
+
stream.push({ type: "error", reason: "error", error: finalMessage });
|
|
2506
|
+
} else {
|
|
2507
|
+
stream.push({ type: "done", reason: "stop", message: finalMessage });
|
|
2508
|
+
}
|
|
2509
|
+
return;
|
|
2510
|
+
}
|
|
2511
|
+
|
|
2512
|
+
default:
|
|
2513
|
+
break;
|
|
2217
2514
|
}
|
|
2218
|
-
|
|
2515
|
+
}
|
|
2516
|
+
} finally {
|
|
2517
|
+
options?.signal?.removeEventListener("abort", forwardAbort);
|
|
2219
2518
|
}
|
|
2220
2519
|
|
|
2221
|
-
|
|
2222
|
-
|
|
2520
|
+
// The SDK stream ended without a terminal `result` message and
|
|
2521
|
+
// without a readiness retry (the only restart path, via
|
|
2522
|
+
// `continue sdkAttemptLoop`). Break out so the post-loop
|
|
2523
|
+
// exhaustion handler emits a transient stream-exhausted error,
|
|
2524
|
+
// instead of silently starting another SDK session and looping
|
|
2525
|
+
// forever.
|
|
2526
|
+
break sdkAttemptLoop;
|
|
2223
2527
|
}
|
|
2528
|
+
} finally {
|
|
2529
|
+
if (trackWorkflowMcpSdk) endWorkflowMcpSdkSession();
|
|
2224
2530
|
}
|
|
2225
2531
|
|
|
2226
2532
|
// Generator exhaustion without a terminal result is a stream interruption,
|