@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.
Files changed (651) hide show
  1. package/dist/cli-model-override.d.ts +15 -0
  2. package/dist/cli-model-override.js +21 -0
  3. package/dist/cli.js +1 -18
  4. package/dist/headless-events.js +7 -5
  5. package/dist/loader.js +6 -4
  6. package/dist/mcp-server.js +2 -1
  7. package/dist/register-agent-bundles.d.ts +11 -2
  8. package/dist/register-agent-bundles.js +18 -4
  9. package/dist/resource-loader.d.ts +10 -5
  10. package/dist/resource-loader.js +121 -6
  11. package/dist/resources/.managed-resources-content-hash +1 -1
  12. package/dist/resources/GSD-WORKFLOW.md +5 -4
  13. package/dist/resources/extensions/ask-user-questions.js +3 -2
  14. package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
  15. package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
  16. package/dist/resources/extensions/async-jobs/index.js +65 -0
  17. package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
  18. package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
  19. package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
  20. package/dist/resources/extensions/bg-shell/overlay.js +9 -6
  21. package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
  22. package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
  23. package/dist/resources/extensions/browser-tools/engine/managed-gsd-browser.js +209 -88
  24. package/dist/resources/extensions/browser-tools/engine/selection.js +73 -5
  25. package/dist/resources/extensions/browser-tools/index.js +69 -12
  26. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +450 -217
  27. package/dist/resources/extensions/claude-code-cli/turn-assembler.js +33 -1
  28. package/dist/resources/extensions/gsd/auto/closeout.js +215 -0
  29. package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
  30. package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
  31. package/dist/resources/extensions/gsd/auto/dispatch-history.js +120 -0
  32. package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
  33. package/dist/resources/extensions/gsd/auto/dispatch.js +365 -0
  34. package/dist/resources/extensions/gsd/auto/finalize.js +347 -0
  35. package/dist/resources/extensions/gsd/auto/loop.js +7 -1
  36. package/dist/resources/extensions/gsd/auto/milestone-lease-reclaim.js +56 -0
  37. package/dist/resources/extensions/gsd/auto/orchestrator.js +174 -69
  38. package/dist/resources/extensions/gsd/auto/phase-helpers.js +146 -0
  39. package/dist/resources/extensions/gsd/auto/phases.js +17 -2329
  40. package/dist/resources/extensions/gsd/auto/pre-dispatch.js +534 -0
  41. package/dist/resources/extensions/gsd/auto/session.js +3 -0
  42. package/dist/resources/extensions/gsd/auto/unit-phase.js +694 -0
  43. package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +1 -1
  44. package/dist/resources/extensions/gsd/auto/worktree-safety-phase.js +125 -0
  45. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +11 -34
  46. package/dist/resources/extensions/gsd/auto-dispatch.js +50 -58
  47. package/dist/resources/extensions/gsd/auto-model-selection.js +36 -13
  48. package/dist/resources/extensions/gsd/auto-post-unit.js +30 -12
  49. package/dist/resources/extensions/gsd/auto-prompts.js +78 -19
  50. package/dist/resources/extensions/gsd/auto-start.js +35 -15
  51. package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
  52. package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +5 -4
  53. package/dist/resources/extensions/gsd/auto-verification.js +23 -30
  54. package/dist/resources/extensions/gsd/auto-worktree.js +15 -2
  55. package/dist/resources/extensions/gsd/auto.js +41 -2
  56. package/dist/resources/extensions/gsd/blocked-models.js +28 -0
  57. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +26 -6
  58. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +60 -13
  59. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
  60. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
  61. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +172 -59
  62. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +302 -80
  63. package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
  64. package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
  65. package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
  66. package/dist/resources/extensions/gsd/commands/context.js +16 -2
  67. package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
  68. package/dist/resources/extensions/gsd/commands-mcp-status.js +2 -2
  69. package/dist/resources/extensions/gsd/commands-workflow-templates.js +9 -2
  70. package/dist/resources/extensions/gsd/consent-question.js +353 -0
  71. package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
  72. package/dist/resources/extensions/gsd/constants.js +0 -2
  73. package/dist/resources/extensions/gsd/crash-recovery.js +8 -3
  74. package/dist/resources/extensions/gsd/db/queries.js +56 -0
  75. package/dist/resources/extensions/gsd/db-writer.js +8 -17
  76. package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
  77. package/dist/resources/extensions/gsd/doctor-engine-checks.js +5 -5
  78. package/dist/resources/extensions/gsd/doctor-environment.js +256 -125
  79. package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
  80. package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
  81. package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
  82. package/dist/resources/extensions/gsd/files.js +33 -19
  83. package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
  84. package/dist/resources/extensions/gsd/gsd-db.js +2 -1
  85. package/dist/resources/extensions/gsd/guidance.js +60 -0
  86. package/dist/resources/extensions/gsd/guided-flow.js +93 -4
  87. package/dist/resources/extensions/gsd/health-widget.js +87 -28
  88. package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
  89. package/dist/resources/extensions/gsd/mcp-bridge.js +10 -0
  90. package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
  91. package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
  92. package/dist/resources/extensions/gsd/milestone-planning-persistence.js +2 -2
  93. package/dist/resources/extensions/gsd/milestone-reopen-events.js +3 -5
  94. package/dist/resources/extensions/gsd/milestone-settlement.js +2 -2
  95. package/dist/resources/extensions/gsd/notifications.js +12 -7
  96. package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
  97. package/dist/resources/extensions/gsd/preferences-models.js +2 -2
  98. package/dist/resources/extensions/gsd/projection-flush.js +7 -0
  99. package/dist/resources/extensions/gsd/prompts/complete-slice.md +4 -4
  100. package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
  101. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  102. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  103. package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
  104. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  105. package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
  106. package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  107. package/dist/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  108. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -1
  109. package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  110. package/dist/resources/extensions/gsd/prompts/run-uat.md +9 -5
  111. package/dist/resources/extensions/gsd/prompts/system.md +5 -2
  112. package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  113. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  114. package/dist/resources/extensions/gsd/prompts/workflow-start.md +2 -1
  115. package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
  116. package/dist/resources/extensions/gsd/roadmap-slices.js +25 -3
  117. package/dist/resources/extensions/gsd/safety/destructive-confirmation.js +108 -0
  118. package/dist/resources/extensions/gsd/session-lock.js +1 -1
  119. package/dist/resources/extensions/gsd/skill-activation.js +3 -6
  120. package/dist/resources/extensions/gsd/state.js +11 -2
  121. package/dist/resources/extensions/gsd/tool-contract.js +14 -3
  122. package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
  123. package/dist/resources/extensions/gsd/tool-surface-readiness.js +83 -31
  124. package/dist/resources/extensions/gsd/tools/complete-milestone.js +3 -2
  125. package/dist/resources/extensions/gsd/tools/complete-slice.js +22 -12
  126. package/dist/resources/extensions/gsd/tools/complete-task.js +65 -2
  127. package/dist/resources/extensions/gsd/tools/exec-tool.js +5 -0
  128. package/dist/resources/extensions/gsd/tools/plan-slice.js +2 -2
  129. package/dist/resources/extensions/gsd/tools/plan-task.js +2 -2
  130. package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +2 -2
  131. package/dist/resources/extensions/gsd/tools/reopen-milestone.js +2 -2
  132. package/dist/resources/extensions/gsd/tools/reopen-slice.js +2 -2
  133. package/dist/resources/extensions/gsd/tools/reopen-task.js +2 -2
  134. package/dist/resources/extensions/gsd/tools/replan-slice.js +2 -2
  135. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +67 -2
  136. package/dist/resources/extensions/gsd/uat-policy.js +42 -16
  137. package/dist/resources/extensions/gsd/unit-context-composer.js +65 -0
  138. package/dist/resources/extensions/gsd/unit-registry.js +41 -24
  139. package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
  140. package/dist/resources/extensions/gsd/verification-verdict.js +2 -1
  141. package/dist/resources/extensions/gsd/web-app-uat.js +45 -8
  142. package/dist/resources/extensions/gsd/workflow-event-ledger.js +91 -0
  143. package/dist/resources/extensions/gsd/workflow-event-vocabulary.js +46 -0
  144. package/dist/resources/extensions/gsd/workflow-events.js +6 -18
  145. package/dist/resources/extensions/gsd/workflow-mcp-auto-prep.js +2 -0
  146. package/dist/resources/extensions/gsd/workflow-mcp-readiness-cache.js +105 -0
  147. package/dist/resources/extensions/gsd/workflow-reconcile.js +21 -56
  148. package/dist/resources/extensions/gsd/worktree-lifecycle.js +3 -2
  149. package/dist/resources/extensions/gsd/worktree-manager.js +7 -1
  150. package/dist/resources/extensions/gsd/worktree-safety.js +28 -26
  151. package/dist/resources/extensions/gsd/worktree.js +8 -1
  152. package/dist/resources/extensions/mcp-client/manager.js +6 -1
  153. package/dist/resources/extensions/search-the-web/native-search.js +5 -3
  154. package/dist/resources/extensions/shared/browser-contract.js +59 -0
  155. package/dist/resources/extensions/shared/gsd-browser-cli.js +116 -6
  156. package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
  157. package/dist/resources/shared/package-manager-detection.js +1 -1
  158. package/dist/resources/shared/package.json +3 -0
  159. package/dist/resources/skills/create-skill/SKILL.md +3 -0
  160. package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
  161. package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
  162. package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
  163. package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
  164. package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
  165. package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
  166. package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
  167. package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
  168. package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
  169. package/dist/runtime-checks.d.ts +10 -0
  170. package/dist/runtime-checks.js +27 -0
  171. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  172. package/dist/update-check.d.ts +2 -0
  173. package/dist/update-check.js +24 -1
  174. package/dist/update-cmd.js +20 -3
  175. package/dist/web/standalone/.next/BUILD_ID +1 -1
  176. package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
  177. package/dist/web/standalone/.next/build-manifest.json +3 -3
  178. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  179. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  180. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  181. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  182. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  183. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  184. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  185. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  186. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  187. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  188. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  189. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  190. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  191. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  192. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  193. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  194. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  195. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  196. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  197. package/dist/web/standalone/.next/server/app/api/update/route.js.nft.json +1 -1
  198. package/dist/web/standalone/.next/server/app/index.html +1 -1
  199. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  200. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  201. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  202. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  203. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  204. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  205. package/dist/web/standalone/.next/server/app-paths-manifest.json +12 -12
  206. package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
  207. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  208. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  209. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  210. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  211. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  212. package/dist/web/standalone/.next/static/chunks/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
  213. package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
  214. package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
  215. package/dist/web/standalone/package.json +1 -1
  216. package/package.json +3 -3
  217. package/packages/cloud-mcp-gateway/package.json +2 -2
  218. package/packages/contracts/dist/rpc.d.ts +1 -0
  219. package/packages/contracts/dist/rpc.d.ts.map +1 -1
  220. package/packages/contracts/dist/rpc.js.map +1 -1
  221. package/packages/contracts/package.json +1 -1
  222. package/packages/daemon/package.json +4 -4
  223. package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -1
  224. package/packages/gsd-agent-core/dist/sdk.js +6 -4
  225. package/packages/gsd-agent-core/dist/sdk.js.map +1 -1
  226. package/packages/gsd-agent-core/package.json +5 -5
  227. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +2 -0
  228. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  229. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +10 -0
  230. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -1
  231. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +13 -0
  232. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  233. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +55 -6
  234. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
  235. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts +2 -0
  236. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts.map +1 -1
  237. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js +34 -5
  238. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js.map +1 -1
  239. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  240. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
  241. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  242. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
  243. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
  244. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
  245. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
  246. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
  247. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
  248. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +1 -0
  249. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  250. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +12 -0
  251. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -1
  252. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
  253. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
  254. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
  255. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.d.ts.map +1 -1
  256. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js +4 -0
  257. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js.map +1 -1
  258. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  259. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
  260. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
  261. package/packages/gsd-agent-modes/package.json +7 -7
  262. package/packages/mcp-server/README.md +12 -3
  263. package/packages/mcp-server/dist/cli-runner.d.ts +40 -0
  264. package/packages/mcp-server/dist/cli-runner.d.ts.map +1 -0
  265. package/packages/mcp-server/dist/cli-runner.js +137 -0
  266. package/packages/mcp-server/dist/cli-runner.js.map +1 -0
  267. package/packages/mcp-server/dist/cli.js +2 -53
  268. package/packages/mcp-server/dist/cli.js.map +1 -1
  269. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
  270. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
  271. package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
  272. package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
  273. package/packages/mcp-server/dist/pid-registry.d.ts +46 -0
  274. package/packages/mcp-server/dist/pid-registry.d.ts.map +1 -0
  275. package/packages/mcp-server/dist/pid-registry.js +452 -0
  276. package/packages/mcp-server/dist/pid-registry.js.map +1 -0
  277. package/packages/mcp-server/dist/probe-mode.d.ts +4 -0
  278. package/packages/mcp-server/dist/probe-mode.d.ts.map +1 -0
  279. package/packages/mcp-server/dist/probe-mode.js +10 -0
  280. package/packages/mcp-server/dist/probe-mode.js.map +1 -0
  281. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  282. package/packages/mcp-server/dist/server.js +4 -0
  283. package/packages/mcp-server/dist/server.js.map +1 -1
  284. package/packages/mcp-server/dist/stdio-watchdog.d.ts +8 -0
  285. package/packages/mcp-server/dist/stdio-watchdog.d.ts.map +1 -0
  286. package/packages/mcp-server/dist/stdio-watchdog.js +40 -0
  287. package/packages/mcp-server/dist/stdio-watchdog.js.map +1 -0
  288. package/packages/mcp-server/dist/workflow-tools.d.ts +18 -18
  289. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  290. package/packages/mcp-server/dist/workflow-tools.js +161 -81
  291. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  292. package/packages/mcp-server/package.json +5 -4
  293. package/packages/native/package.json +1 -1
  294. package/packages/pi-agent-core/dist/agent-loop.js +43 -2
  295. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  296. package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
  297. package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
  298. package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
  299. package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
  300. package/packages/pi-agent-core/dist/index.d.ts +1 -0
  301. package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
  302. package/packages/pi-agent-core/dist/index.js +3 -0
  303. package/packages/pi-agent-core/dist/index.js.map +1 -1
  304. package/packages/pi-agent-core/package.json +1 -1
  305. package/packages/pi-ai/README.md +1 -0
  306. package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
  307. package/packages/pi-ai/dist/image-models.generated.js +6 -6
  308. package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
  309. package/packages/pi-ai/dist/index.d.ts +2 -0
  310. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  311. package/packages/pi-ai/dist/index.js +2 -0
  312. package/packages/pi-ai/dist/index.js.map +1 -1
  313. package/packages/pi-ai/dist/models.generated.d.ts +239 -153
  314. package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
  315. package/packages/pi-ai/dist/models.generated.js +256 -145
  316. package/packages/pi-ai/dist/models.generated.js.map +1 -1
  317. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  318. package/packages/pi-ai/dist/providers/anthropic.js +12 -7
  319. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  320. package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
  321. package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
  322. package/packages/pi-ai/dist/providers/google-shared.js +12 -3
  323. package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
  324. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  325. package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
  326. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  327. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
  328. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
  329. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
  330. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
  331. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  332. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
  333. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  334. package/packages/pi-ai/package.json +3 -2
  335. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
  336. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
  337. package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
  338. package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
  339. package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
  340. package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
  341. package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
  342. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
  343. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  344. package/packages/pi-coding-agent/dist/core/settings-manager.js +11 -0
  345. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  346. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
  347. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
  348. package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
  349. package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
  350. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  351. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  352. package/packages/pi-coding-agent/dist/index.js +1 -1
  353. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  354. package/packages/pi-coding-agent/dist/theme/theme.d.ts.map +1 -1
  355. package/packages/pi-coding-agent/dist/theme/theme.js +45 -17
  356. package/packages/pi-coding-agent/dist/theme/theme.js.map +1 -1
  357. package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
  358. package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
  359. package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
  360. package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
  361. package/packages/pi-coding-agent/package.json +7 -7
  362. package/packages/pi-tui/dist/index.d.ts +1 -1
  363. package/packages/pi-tui/dist/index.d.ts.map +1 -1
  364. package/packages/pi-tui/dist/index.js +1 -1
  365. package/packages/pi-tui/dist/index.js.map +1 -1
  366. package/packages/pi-tui/dist/terminal-image.d.ts +33 -0
  367. package/packages/pi-tui/dist/terminal-image.d.ts.map +1 -1
  368. package/packages/pi-tui/dist/terminal-image.js +54 -2
  369. package/packages/pi-tui/dist/terminal-image.js.map +1 -1
  370. package/packages/pi-tui/dist/tui.d.ts +8 -0
  371. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  372. package/packages/pi-tui/dist/tui.js +72 -18
  373. package/packages/pi-tui/dist/tui.js.map +1 -1
  374. package/packages/pi-tui/dist/utils.d.ts.map +1 -1
  375. package/packages/pi-tui/dist/utils.js +110 -36
  376. package/packages/pi-tui/dist/utils.js.map +1 -1
  377. package/packages/pi-tui/package.json +2 -2
  378. package/packages/rpc-client/package.json +2 -2
  379. package/pkg/dist/theme/theme.d.ts.map +1 -1
  380. package/pkg/dist/theme/theme.js +45 -17
  381. package/pkg/dist/theme/theme.js.map +1 -1
  382. package/pkg/package.json +1 -1
  383. package/src/resources/GSD-WORKFLOW.md +5 -4
  384. package/src/resources/extensions/ask-user-questions.ts +7 -2
  385. package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
  386. package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
  387. package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
  388. package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
  389. package/src/resources/extensions/async-jobs/index.ts +79 -0
  390. package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
  391. package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
  392. package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
  393. package/src/resources/extensions/bg-shell/overlay.ts +9 -5
  394. package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
  395. package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
  396. package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
  397. package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
  398. package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
  399. package/src/resources/extensions/browser-tools/index.ts +71 -13
  400. package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
  401. package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +40 -1
  402. package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
  403. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +534 -228
  404. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +672 -7
  405. package/src/resources/extensions/claude-code-cli/turn-assembler.ts +38 -1
  406. package/src/resources/extensions/gsd/auto/closeout.ts +309 -0
  407. package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
  408. package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
  409. package/src/resources/extensions/gsd/auto/dispatch-history.ts +168 -0
  410. package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
  411. package/src/resources/extensions/gsd/auto/dispatch.ts +449 -0
  412. package/src/resources/extensions/gsd/auto/finalize.ts +445 -0
  413. package/src/resources/extensions/gsd/auto/loop.ts +7 -1
  414. package/src/resources/extensions/gsd/auto/milestone-lease-reclaim.ts +74 -0
  415. package/src/resources/extensions/gsd/auto/orchestrator.ts +193 -71
  416. package/src/resources/extensions/gsd/auto/phase-helpers.ts +199 -0
  417. package/src/resources/extensions/gsd/auto/phases.ts +58 -3022
  418. package/src/resources/extensions/gsd/auto/pre-dispatch.ts +704 -0
  419. package/src/resources/extensions/gsd/auto/session.ts +3 -0
  420. package/src/resources/extensions/gsd/auto/unit-phase.ts +910 -0
  421. package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +1 -1
  422. package/src/resources/extensions/gsd/auto/worktree-safety-phase.ts +149 -0
  423. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +18 -48
  424. package/src/resources/extensions/gsd/auto-dispatch.ts +48 -61
  425. package/src/resources/extensions/gsd/auto-model-selection.ts +41 -12
  426. package/src/resources/extensions/gsd/auto-post-unit.ts +33 -12
  427. package/src/resources/extensions/gsd/auto-prompts.ts +115 -35
  428. package/src/resources/extensions/gsd/auto-start.ts +36 -18
  429. package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
  430. package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +4 -4
  431. package/src/resources/extensions/gsd/auto-verification.ts +26 -28
  432. package/src/resources/extensions/gsd/auto-worktree.ts +15 -2
  433. package/src/resources/extensions/gsd/auto.ts +49 -2
  434. package/src/resources/extensions/gsd/blocked-models.ts +49 -0
  435. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -5
  436. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +79 -12
  437. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
  438. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
  439. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +211 -59
  440. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +350 -86
  441. package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
  442. package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
  443. package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
  444. package/src/resources/extensions/gsd/commands/context.ts +16 -2
  445. package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
  446. package/src/resources/extensions/gsd/commands-mcp-status.ts +2 -2
  447. package/src/resources/extensions/gsd/commands-workflow-templates.ts +11 -4
  448. package/src/resources/extensions/gsd/consent-question.ts +431 -0
  449. package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
  450. package/src/resources/extensions/gsd/constants.ts +0 -3
  451. package/src/resources/extensions/gsd/crash-recovery.ts +10 -2
  452. package/src/resources/extensions/gsd/db/queries.ts +66 -0
  453. package/src/resources/extensions/gsd/db-writer.ts +11 -19
  454. package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
  455. package/src/resources/extensions/gsd/doctor-engine-checks.ts +5 -4
  456. package/src/resources/extensions/gsd/doctor-environment.ts +267 -142
  457. package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
  458. package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
  459. package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
  460. package/src/resources/extensions/gsd/files.ts +33 -12
  461. package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
  462. package/src/resources/extensions/gsd/gsd-db.ts +4 -3
  463. package/src/resources/extensions/gsd/guidance.ts +78 -0
  464. package/src/resources/extensions/gsd/guided-flow.ts +145 -24
  465. package/src/resources/extensions/gsd/health-widget.ts +91 -27
  466. package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
  467. package/src/resources/extensions/gsd/mcp-bridge.ts +39 -0
  468. package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
  469. package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
  470. package/src/resources/extensions/gsd/milestone-planning-persistence.ts +2 -2
  471. package/src/resources/extensions/gsd/milestone-reopen-events.ts +3 -6
  472. package/src/resources/extensions/gsd/milestone-settlement.ts +2 -2
  473. package/src/resources/extensions/gsd/notifications.ts +13 -6
  474. package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
  475. package/src/resources/extensions/gsd/preferences-models.ts +2 -1
  476. package/src/resources/extensions/gsd/projection-flush.ts +20 -0
  477. package/src/resources/extensions/gsd/prompts/complete-slice.md +4 -4
  478. package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
  479. package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  480. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  481. package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
  482. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  483. package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
  484. package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  485. package/src/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  486. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -1
  487. package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  488. package/src/resources/extensions/gsd/prompts/run-uat.md +9 -5
  489. package/src/resources/extensions/gsd/prompts/system.md +5 -2
  490. package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  491. package/src/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  492. package/src/resources/extensions/gsd/prompts/workflow-start.md +2 -1
  493. package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
  494. package/src/resources/extensions/gsd/roadmap-slices.ts +28 -3
  495. package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
  496. package/src/resources/extensions/gsd/session-lock.ts +1 -1
  497. package/src/resources/extensions/gsd/skill-activation.ts +3 -6
  498. package/src/resources/extensions/gsd/state.ts +12 -1
  499. package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +1 -1
  500. package/src/resources/extensions/gsd/tests/auto-blocked-remediation-message.test.ts +1 -1
  501. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +206 -22
  502. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +97 -1
  503. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +273 -37
  504. package/src/resources/extensions/gsd/tests/auto-pause-double-entry-guard.test.ts +1 -1
  505. package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +51 -0
  506. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +2 -1
  507. package/src/resources/extensions/gsd/tests/auto-remote-session-lock-cleanup.test.ts +65 -3
  508. package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
  509. package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +169 -1
  510. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
  511. package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
  512. package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
  513. package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
  514. package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
  515. package/src/resources/extensions/gsd/tests/complete-task.test.ts +141 -5
  516. package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
  517. package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
  518. package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
  519. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +12 -11
  520. package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +36 -0
  521. package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
  522. package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
  523. package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +328 -0
  524. package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
  525. package/src/resources/extensions/gsd/tests/dist-redirect.mjs +8 -0
  526. package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
  527. package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
  528. package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
  529. package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +117 -91
  530. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +113 -0
  531. package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
  532. package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
  533. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
  534. package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
  535. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
  536. package/src/resources/extensions/gsd/tests/guidance.test.ts +23 -0
  537. package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +18 -6
  538. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +7 -11
  539. package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +35 -58
  540. package/src/resources/extensions/gsd/tests/integration/doctor-environment-async.test.ts +104 -0
  541. package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
  542. package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +217 -0
  543. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +47 -16
  544. package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
  545. package/src/resources/extensions/gsd/tests/mcp-readiness-preflight.test.ts +205 -0
  546. package/src/resources/extensions/gsd/tests/mcp-status.test.ts +6 -5
  547. package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
  548. package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +1 -1
  549. package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +1 -1
  550. package/src/resources/extensions/gsd/tests/milestone-settlement.test.ts +92 -0
  551. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +1 -1
  552. package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
  553. package/src/resources/extensions/gsd/tests/notifications.test.ts +64 -9
  554. package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
  555. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
  556. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +2 -2
  557. package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +143 -0
  558. package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +1 -1
  559. package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
  560. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +3 -3
  561. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
  562. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +10 -2
  563. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
  564. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +2 -4
  565. package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +31 -81
  566. package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
  567. package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +26 -2
  568. package/src/resources/extensions/gsd/tests/skill-activation.test.ts +20 -17
  569. package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +7 -3
  570. package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +1 -1
  571. package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
  572. package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +80 -2
  573. package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +184 -10
  574. package/src/resources/extensions/gsd/tests/tool-unavailable-retry.test.ts +33 -0
  575. package/src/resources/extensions/gsd/tests/transport-gate-double-complete.test.ts +139 -0
  576. package/src/resources/extensions/gsd/tests/uat-policy.test.ts +112 -29
  577. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +44 -0
  578. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
  579. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +1 -1
  580. package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +2 -0
  581. package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +44 -1
  582. package/src/resources/extensions/gsd/tests/workflow-events.test.ts +19 -0
  583. package/src/resources/extensions/gsd/tests/workflow-mcp-readiness-cache.test.ts +119 -0
  584. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +65 -2
  585. package/src/resources/extensions/gsd/tests/workflow-phase-contract-matrix.test.ts +332 -0
  586. package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
  587. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +92 -0
  588. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +273 -38
  589. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +1 -1
  590. package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +1 -1
  591. package/src/resources/extensions/gsd/tests/worktree-safety-phase.test.ts +100 -0
  592. package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +72 -0
  593. package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
  594. package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
  595. package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
  596. package/src/resources/extensions/gsd/tests/write-gate.test.ts +67 -1
  597. package/src/resources/extensions/gsd/tool-contract.ts +38 -3
  598. package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
  599. package/src/resources/extensions/gsd/tool-surface-readiness.ts +126 -19
  600. package/src/resources/extensions/gsd/tools/complete-milestone.ts +3 -2
  601. package/src/resources/extensions/gsd/tools/complete-slice.ts +22 -12
  602. package/src/resources/extensions/gsd/tools/complete-task.ts +90 -2
  603. package/src/resources/extensions/gsd/tools/exec-tool.ts +4 -0
  604. package/src/resources/extensions/gsd/tools/plan-slice.ts +2 -2
  605. package/src/resources/extensions/gsd/tools/plan-task.ts +2 -2
  606. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +2 -2
  607. package/src/resources/extensions/gsd/tools/reopen-milestone.ts +2 -2
  608. package/src/resources/extensions/gsd/tools/reopen-slice.ts +2 -2
  609. package/src/resources/extensions/gsd/tools/reopen-task.ts +2 -2
  610. package/src/resources/extensions/gsd/tools/replan-slice.ts +2 -2
  611. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
  612. package/src/resources/extensions/gsd/uat-policy.ts +62 -16
  613. package/src/resources/extensions/gsd/unit-context-composer.ts +99 -0
  614. package/src/resources/extensions/gsd/unit-registry.ts +41 -24
  615. package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
  616. package/src/resources/extensions/gsd/verification-verdict.ts +4 -2
  617. package/src/resources/extensions/gsd/web-app-uat.ts +51 -8
  618. package/src/resources/extensions/gsd/workflow-event-ledger.ts +131 -0
  619. package/src/resources/extensions/gsd/workflow-event-vocabulary.ts +59 -0
  620. package/src/resources/extensions/gsd/workflow-events.ts +12 -20
  621. package/src/resources/extensions/gsd/workflow-mcp-auto-prep.ts +2 -0
  622. package/src/resources/extensions/gsd/workflow-mcp-readiness-cache.ts +150 -0
  623. package/src/resources/extensions/gsd/workflow-reconcile.ts +29 -62
  624. package/src/resources/extensions/gsd/worktree-lifecycle.ts +3 -8
  625. package/src/resources/extensions/gsd/worktree-manager.ts +6 -1
  626. package/src/resources/extensions/gsd/worktree-safety.ts +41 -39
  627. package/src/resources/extensions/gsd/worktree.ts +7 -1
  628. package/src/resources/extensions/mcp-client/manager.ts +7 -1
  629. package/src/resources/extensions/search-the-web/native-search.ts +5 -3
  630. package/src/resources/extensions/shared/browser-contract.ts +66 -0
  631. package/src/resources/extensions/shared/gsd-browser-cli.ts +141 -6
  632. package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
  633. package/src/resources/shared/package-manager-detection.ts +1 -1
  634. package/src/resources/shared/package.json +3 -0
  635. package/src/resources/skills/create-skill/SKILL.md +3 -0
  636. package/src/resources/skills/create-skill/references/executable-code.md +1 -1
  637. package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
  638. package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
  639. package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
  640. package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
  641. package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
  642. package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
  643. package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
  644. package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
  645. package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
  646. package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
  647. package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
  648. package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
  649. package/src/resources/skills/gsd-browser/SKILL.md +0 -41
  650. /package/dist/web/standalone/.next/static/{2p9Rv9pQflAxCBbGVI2vb → avEtvPrImYTq2gGe-hVNp}/_buildManifest.js +0 -0
  651. /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 { getToolSurfaceReadinessError } from "../gsd/tool-surface-readiness.js";
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 NOT available never use it to discover tools; invoke the MCP tool directly\n"
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 (async function* () {
514
- yield sdkMessage;
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.startsWith("browser_")) {
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.startsWith("browser_")) continue;
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 requiredTools = gsdPhase === "run-uat"
1771
+ const requestedTools = gsdPhase === "run-uat"
1666
1772
  ? [...RUN_UAT_WORKFLOW_TOOL_NAMES]
1667
- : getRequiredWorkflowToolsForAutoUnit(gsdPhase);
1668
- const supportTools = gsdPhase === "run-uat" ? [] : ["gsd_milestone_status"];
1669
- const requestedToolNames = [...new Set([...requiredTools, ...supportTools])];
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 standardClaudeTools = [
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
- ...RUN_UAT_CLAUDE_NATIVE_TOOL_NAMES,
2047
+ ...nativeTools,
1863
2048
  ...(exactWorkflowMcpTools.length > 0 ? exactWorkflowMcpTools : []),
1864
2049
  ...allowedBrowserMcpTools,
1865
2050
  ]
1866
2051
  : [
1867
- ...standardClaudeTools,
2052
+ ...nativeTools,
1868
2053
  ...exactWorkflowMcpTools,
1869
- ...(workflowMcpTools.length > 0 ? workflowMcpTools : ["AskUserQuestion"]),
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 uiContext = (options as ClaudeCodeStreamOptions | undefined)?.extensionUIContext;
1975
- const onExternalToolCall = (options as ClaudeCodeStreamOptions | undefined)?.onExternalToolCall;
1976
- const onExternalToolResult = (options as ClaudeCodeStreamOptions | undefined)?.onExternalToolResult;
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 = inferGsdPhaseFromContext(context);
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
- for await (const msg of queryResult as AsyncIterable<SDKMessage>) {
2031
- if (options?.signal?.aborted) {
2032
- // User-initiated cancel — emit an aborted error so the agent
2033
- // loop classifies this as a deliberate stop, not a transient
2034
- // provider failure that should be retried.
2035
- stream.push({
2036
- type: "error",
2037
- reason: "aborted",
2038
- error: makeAbortedMessage(modelId, lastTextContent),
2039
- });
2040
- return;
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
- switch (msg.type) {
2044
- // -- Init --
2045
- case "system": {
2046
- // Tool Surface Readiness gate: the init message is the first (and
2047
- // only) point where the session reports its live tool surface and
2048
- // MCP server statuses. If the workflow server failed or has not
2049
- // registered this Unit's required tools, abort before the first
2050
- // model turn with a transient, recovery-classifiable error
2051
- // (tool-unavailable → retry) instead of letting the model hit
2052
- // "No such tool available" mid-Unit and improvise around it.
2053
- const init = msg as unknown as {
2054
- subtype?: string;
2055
- tools?: string[];
2056
- mcp_servers?: { name: string; status: string }[];
2057
- };
2058
- if (init.subtype === "init") {
2059
- const readinessError = getToolSurfaceReadinessError({
2060
- unitType: gsdPhase,
2061
- workflowServerName: workflowMcpServerName,
2062
- observation: { tools: init.tools ?? [], mcpServers: init.mcp_servers ?? [] },
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
- if (readinessError) {
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
- // -- Streaming partial messages --
2078
- case "stream_event": {
2079
- const partial = msg as SDKPartialAssistantMessage;
2080
-
2081
- const event = partial.event;
2082
-
2083
- const result = handleClaudeCodePartialStreamEvent(builder, event, modelId);
2084
- builder = result.builder;
2085
- const assistantEvent = result.assistantEvent;
2086
- if (assistantEvent) {
2087
- stream.push(assistantEvent);
2088
- if (assistantEvent.type === "toolcall_start") {
2089
- const toolBlock = assistantEvent.partial.content[assistantEvent.contentIndex];
2090
- if (toolBlock?.type === "toolCall") {
2091
- try {
2092
- await onExternalToolCall?.(toolBlock);
2093
- } catch (error) {
2094
- console.warn("[claude-code] onExternalToolCall callback failed:", error);
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
- // -- Complete assistant message (non-streaming fallback) --
2103
- case "assistant": {
2104
- const sdkAssistant = msg as SDKAssistantMessage;
2105
-
2106
- // Capture text content from complete messages
2107
- for (const block of sdkAssistant.message.content) {
2108
- if (block.type === "text") {
2109
- lastTextContent = block.text;
2110
- } else if (block.type === "thinking") {
2111
- lastThinkingContent = block.thinking;
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
- // -- User message (synthetic tool result — signals turn boundary) --
2118
- case "user": {
2119
- // Capture content from the completed turn before resetting
2120
- if (builder) {
2121
- for (const block of builder.message.content) {
2122
- if (block.type === "text" && block.text) {
2123
- lastTextContent = block.text;
2124
- } else if (block.type === "thinking" && block.thinking) {
2125
- lastThinkingContent = block.thinking;
2126
- } else if (block.type === "toolCall" || block.type === "serverToolUse") {
2127
- // Collect tool blocks for externalToolExecution rendering
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
- // Extract tool results from the SDK's synthetic user message
2134
- // and attach to corresponding tool call blocks immediately.
2135
- for (const { toolUseId, result } of extractToolResultsFromSdkUserMessage(msg as SDKUserMessage)) {
2136
- toolResultsById.set(toolUseId, result);
2137
- }
2138
- attachExternalResultsToToolBlocks(intermediateToolBlocks, toolResultsById);
2139
-
2140
- // Push a synthetic toolcall_end for each tool call from this turn
2141
- // so the TUI can render tool results in real-time during the SDK
2142
- // session instead of waiting until the entire session completes.
2143
- if (builder) {
2144
- for (const block of builder.message.content) {
2145
- const extResult = (block as ToolCallWithExternalResult).externalResult;
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
- stream.push({
2161
- type: "toolcall_end",
2162
- contentIndex,
2163
- toolCall: block,
2164
- partial: builder.message,
2165
- });
2166
- } else if (block.type === "serverToolUse") {
2167
- try {
2168
- await onExternalToolResult?.({
2169
- toolCall: serverToolUseToToolCallLike(block),
2170
- result: extResult,
2171
- });
2172
- } catch (error) {
2173
- console.warn("[claude-code] onExternalToolResult callback failed:", error);
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
- builder = null;
2185
- break;
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
- // -- Result (terminal) --
2189
- case "result": {
2190
- const result = msg as SDKResultMessage;
2191
- const finalContent = buildFinalAssistantContent({
2192
- intermediateToolBlocks,
2193
- pendingContent: builder?.message.content,
2194
- toolResultsById,
2195
- lastThinkingContent,
2196
- lastTextContent,
2197
- fallbackResultText:
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
- const finalMessage: AssistantMessage = {
2202
- role: "assistant",
2203
- content: finalContent,
2204
- api: "anthropic-messages",
2205
- provider: "claude-code",
2206
- model: modelId,
2207
- usage: mapUsage(result.usage, result.total_cost_usd),
2208
- stopReason: result.is_error ? "error" : "stop",
2209
- timestamp: Date.now(),
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
- return;
2515
+ }
2516
+ } finally {
2517
+ options?.signal?.removeEventListener("abort", forwardAbort);
2219
2518
  }
2220
2519
 
2221
- default:
2222
- break;
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,