@opengsd/gsd-pi 1.2.0-dev.955e4da0 → 1.2.0-dev.9ad8ae33

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 (575) hide show
  1. package/dist/cli-style.d.ts +17 -0
  2. package/dist/cli-style.js +28 -0
  3. package/dist/cli.js +1 -1
  4. package/dist/headless-events.d.ts +4 -2
  5. package/dist/headless-events.js +14 -34
  6. package/dist/mcp-server.js +2 -1
  7. package/dist/models-resolver.d.ts +3 -13
  8. package/dist/models-resolver.js +3 -22
  9. package/dist/resource-loader.d.ts +10 -5
  10. package/dist/resource-loader.js +123 -20
  11. package/dist/resources/.managed-resources-content-hash +1 -1
  12. package/dist/resources/GSD-WORKFLOW.md +5 -4
  13. package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
  14. package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
  15. package/dist/resources/extensions/async-jobs/index.js +65 -0
  16. package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
  17. package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
  18. package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
  19. package/dist/resources/extensions/bg-shell/overlay.js +9 -6
  20. package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
  21. package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
  22. package/dist/resources/extensions/bg-shell/utilities.js +3 -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 +30 -4
  27. package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
  28. package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
  29. package/dist/resources/extensions/gsd/auto/dispatch-history.js +105 -0
  30. package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
  31. package/dist/resources/extensions/gsd/auto/loop.js +4 -1
  32. package/dist/resources/extensions/gsd/auto/orchestrator.js +89 -54
  33. package/dist/resources/extensions/gsd/auto/phases.js +49 -6
  34. package/dist/resources/extensions/gsd/auto/session.js +3 -0
  35. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +11 -34
  36. package/dist/resources/extensions/gsd/auto-dispatch.js +50 -58
  37. package/dist/resources/extensions/gsd/auto-model-selection.js +36 -13
  38. package/dist/resources/extensions/gsd/auto-post-unit.js +35 -8
  39. package/dist/resources/extensions/gsd/auto-prompts.js +81 -19
  40. package/dist/resources/extensions/gsd/auto-start.js +41 -18
  41. package/dist/resources/extensions/gsd/auto-tool-tracking.js +18 -0
  42. package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
  43. package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +12 -20
  44. package/dist/resources/extensions/gsd/auto-verification.js +23 -30
  45. package/dist/resources/extensions/gsd/auto-worktree.js +44 -91
  46. package/dist/resources/extensions/gsd/auto.js +41 -14
  47. package/dist/resources/extensions/gsd/blocked-models.js +28 -0
  48. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +29 -8
  49. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +23 -6
  50. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
  51. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
  52. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +212 -48
  53. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +303 -77
  54. package/dist/resources/extensions/gsd/branch-patterns.js +2 -0
  55. package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
  56. package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
  57. package/dist/resources/extensions/gsd/captures.js +4 -6
  58. package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
  59. package/dist/resources/extensions/gsd/commands/context.js +16 -2
  60. package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
  61. package/dist/resources/extensions/gsd/consent-question.js +353 -0
  62. package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
  63. package/dist/resources/extensions/gsd/constants.js +0 -2
  64. package/dist/resources/extensions/gsd/crash-recovery.js +12 -15
  65. package/dist/resources/extensions/gsd/db/queries.js +26 -0
  66. package/dist/resources/extensions/gsd/db-writer.js +8 -17
  67. package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
  68. package/dist/resources/extensions/gsd/doctor-engine-checks.js +5 -5
  69. package/dist/resources/extensions/gsd/doctor-environment.js +2 -6
  70. package/dist/resources/extensions/gsd/doctor-format.js +9 -6
  71. package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
  72. package/dist/resources/extensions/gsd/doctor-runtime-checks.js +13 -15
  73. package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
  74. package/dist/resources/extensions/gsd/error-classifier.js +9 -0
  75. package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
  76. package/dist/resources/extensions/gsd/files.js +33 -19
  77. package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
  78. package/dist/resources/extensions/gsd/gsd-db.js +2 -1
  79. package/dist/resources/extensions/gsd/guidance.js +158 -0
  80. package/dist/resources/extensions/gsd/guided-flow.js +23 -5
  81. package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
  82. package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
  83. package/dist/resources/extensions/gsd/mcp-tool-name.js +5 -13
  84. package/dist/resources/extensions/gsd/memory-consolidation-scanner.js +1 -1
  85. package/dist/resources/extensions/gsd/migrate/safety.js +4 -1
  86. package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
  87. package/dist/resources/extensions/gsd/milestone-planning-persistence.js +2 -2
  88. package/dist/resources/extensions/gsd/milestone-reopen-events.js +3 -5
  89. package/dist/resources/extensions/gsd/notification-store.js +11 -4
  90. package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +6 -4
  91. package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
  92. package/dist/resources/extensions/gsd/paths.js +27 -0
  93. package/dist/resources/extensions/gsd/pre-execution-checks.js +91 -3
  94. package/dist/resources/extensions/gsd/preferences-models.js +14 -48
  95. package/dist/resources/extensions/gsd/projection-flush.js +7 -0
  96. package/dist/resources/extensions/gsd/prompts/complete-slice.md +3 -3
  97. package/dist/resources/extensions/gsd/prompts/execute-task.md +1 -1
  98. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  99. package/dist/resources/extensions/gsd/prompts/plan-slice.md +2 -2
  100. package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
  101. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  102. package/dist/resources/extensions/gsd/prompts/refine-slice.md +2 -2
  103. package/dist/resources/extensions/gsd/prompts/replan-slice.md +2 -2
  104. package/dist/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  105. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -1
  106. package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  107. package/dist/resources/extensions/gsd/prompts/run-uat.md +7 -5
  108. package/dist/resources/extensions/gsd/prompts/system.md +5 -2
  109. package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  110. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  111. package/dist/resources/extensions/gsd/provider-error-guidance.js +1 -5
  112. package/dist/resources/extensions/gsd/provider-switch-observer.js +1 -1
  113. package/dist/resources/extensions/gsd/publication.js +87 -0
  114. package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
  115. package/dist/resources/extensions/gsd/recovery-classification.js +37 -94
  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/state.js +6 -20
  120. package/dist/resources/extensions/gsd/stop-notice.js +57 -0
  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 +56 -0
  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 +3 -2
  127. package/dist/resources/extensions/gsd/tools/exec-tool.js +9 -7
  128. package/dist/resources/extensions/gsd/tools/plan-slice.js +14 -8
  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-closeout.js +138 -0
  138. package/dist/resources/extensions/gsd/unit-context-composer.js +74 -1
  139. package/dist/resources/extensions/gsd/unit-context-manifest.js +4 -27
  140. package/dist/resources/extensions/gsd/unit-registry.js +337 -0
  141. package/dist/resources/extensions/gsd/unit-tool-contracts.js +9 -182
  142. package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
  143. package/dist/resources/extensions/gsd/verification-verdict.js +2 -1
  144. package/dist/resources/extensions/gsd/web-app-uat.js +45 -8
  145. package/dist/resources/extensions/gsd/workflow-event-ledger.js +91 -0
  146. package/dist/resources/extensions/gsd/workflow-event-vocabulary.js +46 -0
  147. package/dist/resources/extensions/gsd/workflow-events.js +6 -18
  148. package/dist/resources/extensions/gsd/workflow-reconcile.js +21 -56
  149. package/dist/resources/extensions/gsd/workflow-tool-surface.js +1 -1
  150. package/dist/resources/extensions/gsd/worktree-git-recovery.js +15 -9
  151. package/dist/resources/extensions/gsd/worktree-lifecycle.js +3 -2
  152. package/dist/resources/extensions/gsd/worktree-manager.js +7 -1
  153. package/dist/resources/extensions/gsd/worktree-root.js +11 -0
  154. package/dist/resources/extensions/gsd/worktree-session-state.js +4 -5
  155. package/dist/resources/extensions/gsd/worktree.js +8 -1
  156. package/dist/resources/extensions/search-the-web/native-search.js +5 -3
  157. package/dist/resources/extensions/shared/browser-contract.js +59 -0
  158. package/dist/resources/extensions/shared/gsd-browser-cli.js +116 -6
  159. package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
  160. package/dist/resources/shared/package-manager-detection.js +1 -1
  161. package/dist/resources/shared/package.json +3 -0
  162. package/dist/resources/skills/create-skill/SKILL.md +3 -0
  163. package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
  164. package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
  165. package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
  166. package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
  167. package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
  168. package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
  169. package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
  170. package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
  171. package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
  172. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  173. package/dist/update-check.d.ts +2 -0
  174. package/dist/update-check.js +24 -1
  175. package/dist/update-cmd.js +20 -3
  176. package/dist/web/standalone/.next/BUILD_ID +1 -1
  177. package/dist/web/standalone/.next/app-path-routes-manifest.json +13 -13
  178. package/dist/web/standalone/.next/build-manifest.json +3 -3
  179. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  180. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  181. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  182. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  183. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  184. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  185. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  186. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  187. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  188. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  189. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  190. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  191. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  192. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  193. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  194. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  195. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  196. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  197. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  198. package/dist/web/standalone/.next/server/app/api/update/route.js.nft.json +1 -1
  199. package/dist/web/standalone/.next/server/app/index.html +1 -1
  200. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  201. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  202. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  203. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  204. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  205. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  206. package/dist/web/standalone/.next/server/app-paths-manifest.json +13 -13
  207. package/dist/web/standalone/.next/server/chunks/5124.js +1 -1
  208. package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
  209. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  210. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  211. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  212. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  213. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  214. package/dist/web/standalone/.next/static/chunks/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
  215. package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
  216. package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
  217. package/dist/web/standalone/package.json +1 -1
  218. package/dist/worktree-cli.js +3 -6
  219. package/dist/worktree-status-banner.js +7 -15
  220. package/package.json +2 -2
  221. package/packages/cloud-mcp-gateway/package.json +2 -2
  222. package/packages/contracts/dist/rpc.d.ts +1 -0
  223. package/packages/contracts/dist/rpc.d.ts.map +1 -1
  224. package/packages/contracts/dist/rpc.js.map +1 -1
  225. package/packages/contracts/dist/workflow.d.ts +4 -0
  226. package/packages/contracts/dist/workflow.d.ts.map +1 -1
  227. package/packages/contracts/dist/workflow.js.map +1 -1
  228. package/packages/contracts/package.json +1 -1
  229. package/packages/daemon/package.json +4 -4
  230. package/packages/gsd-agent-core/package.json +5 -5
  231. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +5 -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 +5 -0
  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/controllers/chat-controller.d.ts.map +1 -1
  236. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
  237. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  238. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
  239. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
  240. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
  241. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
  242. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
  243. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
  244. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
  245. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
  246. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
  247. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  248. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
  249. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
  250. package/packages/gsd-agent-modes/package.json +7 -7
  251. package/packages/mcp-server/dist/cli.js +9 -1
  252. package/packages/mcp-server/dist/cli.js.map +1 -1
  253. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
  254. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
  255. package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
  256. package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
  257. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  258. package/packages/mcp-server/dist/server.js +4 -0
  259. package/packages/mcp-server/dist/server.js.map +1 -1
  260. package/packages/mcp-server/dist/workflow-tools.d.ts +26 -18
  261. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  262. package/packages/mcp-server/dist/workflow-tools.js +116 -39
  263. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  264. package/packages/mcp-server/package.json +5 -4
  265. package/packages/native/package.json +1 -1
  266. package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
  267. package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
  268. package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
  269. package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
  270. package/packages/pi-agent-core/dist/index.d.ts +1 -0
  271. package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
  272. package/packages/pi-agent-core/dist/index.js +3 -0
  273. package/packages/pi-agent-core/dist/index.js.map +1 -1
  274. package/packages/pi-agent-core/package.json +1 -1
  275. package/packages/pi-ai/README.md +1 -0
  276. package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
  277. package/packages/pi-ai/dist/image-models.generated.js +6 -6
  278. package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
  279. package/packages/pi-ai/dist/index.d.ts +2 -0
  280. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  281. package/packages/pi-ai/dist/index.js +2 -0
  282. package/packages/pi-ai/dist/index.js.map +1 -1
  283. package/packages/pi-ai/dist/models.generated.d.ts +35 -125
  284. package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
  285. package/packages/pi-ai/dist/models.generated.js +46 -120
  286. package/packages/pi-ai/dist/models.generated.js.map +1 -1
  287. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  288. package/packages/pi-ai/dist/providers/anthropic.js +12 -7
  289. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  290. package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
  291. package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
  292. package/packages/pi-ai/dist/providers/google-shared.js +12 -3
  293. package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
  294. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  295. package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
  296. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  297. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
  298. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
  299. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
  300. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
  301. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  302. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
  303. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  304. package/packages/pi-ai/package.json +3 -2
  305. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
  306. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
  307. package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
  308. package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
  309. package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
  310. package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
  311. package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
  312. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
  313. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
  314. package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
  315. package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
  316. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  317. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  318. package/packages/pi-coding-agent/dist/index.js +1 -1
  319. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  320. package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
  321. package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
  322. package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
  323. package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
  324. package/packages/pi-coding-agent/package.json +7 -7
  325. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  326. package/packages/pi-tui/dist/tui.js +9 -0
  327. package/packages/pi-tui/dist/tui.js.map +1 -1
  328. package/packages/pi-tui/package.json +2 -2
  329. package/packages/rpc-client/package.json +2 -2
  330. package/pkg/package.json +1 -1
  331. package/src/resources/GSD-WORKFLOW.md +5 -4
  332. package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
  333. package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
  334. package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
  335. package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
  336. package/src/resources/extensions/async-jobs/index.ts +79 -0
  337. package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
  338. package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
  339. package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
  340. package/src/resources/extensions/bg-shell/overlay.ts +9 -5
  341. package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
  342. package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
  343. package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
  344. package/src/resources/extensions/bg-shell/utilities.ts +3 -0
  345. package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
  346. package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
  347. package/src/resources/extensions/browser-tools/index.ts +71 -13
  348. package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
  349. package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +40 -1
  350. package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
  351. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +34 -4
  352. package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
  353. package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
  354. package/src/resources/extensions/gsd/auto/dispatch-history.ts +152 -0
  355. package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
  356. package/src/resources/extensions/gsd/auto/loop.ts +4 -1
  357. package/src/resources/extensions/gsd/auto/orchestrator.ts +98 -56
  358. package/src/resources/extensions/gsd/auto/phases.ts +65 -26
  359. package/src/resources/extensions/gsd/auto/session.ts +3 -0
  360. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +18 -48
  361. package/src/resources/extensions/gsd/auto-dispatch.ts +48 -61
  362. package/src/resources/extensions/gsd/auto-model-selection.ts +41 -12
  363. package/src/resources/extensions/gsd/auto-post-unit.ts +40 -8
  364. package/src/resources/extensions/gsd/auto-prompts.ts +118 -35
  365. package/src/resources/extensions/gsd/auto-start.ts +42 -21
  366. package/src/resources/extensions/gsd/auto-tool-tracking.ts +19 -0
  367. package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
  368. package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +14 -21
  369. package/src/resources/extensions/gsd/auto-verification.ts +26 -28
  370. package/src/resources/extensions/gsd/auto-worktree.ts +44 -94
  371. package/src/resources/extensions/gsd/auto.ts +52 -16
  372. package/src/resources/extensions/gsd/blocked-models.ts +49 -0
  373. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +37 -10
  374. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +23 -6
  375. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
  376. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
  377. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +251 -47
  378. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +352 -84
  379. package/src/resources/extensions/gsd/branch-patterns.ts +3 -0
  380. package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
  381. package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
  382. package/src/resources/extensions/gsd/captures.ts +4 -6
  383. package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
  384. package/src/resources/extensions/gsd/commands/context.ts +16 -2
  385. package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
  386. package/src/resources/extensions/gsd/consent-question.ts +431 -0
  387. package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
  388. package/src/resources/extensions/gsd/constants.ts +0 -3
  389. package/src/resources/extensions/gsd/crash-recovery.ts +13 -11
  390. package/src/resources/extensions/gsd/db/queries.ts +37 -0
  391. package/src/resources/extensions/gsd/db-writer.ts +11 -19
  392. package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
  393. package/src/resources/extensions/gsd/doctor-engine-checks.ts +5 -4
  394. package/src/resources/extensions/gsd/doctor-environment.ts +2 -7
  395. package/src/resources/extensions/gsd/doctor-format.ts +12 -7
  396. package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
  397. package/src/resources/extensions/gsd/doctor-runtime-checks.ts +13 -15
  398. package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
  399. package/src/resources/extensions/gsd/error-classifier.ts +11 -0
  400. package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
  401. package/src/resources/extensions/gsd/files.ts +33 -12
  402. package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
  403. package/src/resources/extensions/gsd/gsd-db.ts +4 -3
  404. package/src/resources/extensions/gsd/guidance.ts +217 -0
  405. package/src/resources/extensions/gsd/guided-flow.ts +37 -28
  406. package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
  407. package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
  408. package/src/resources/extensions/gsd/mcp-tool-name.ts +6 -11
  409. package/src/resources/extensions/gsd/memory-consolidation-scanner.ts +1 -1
  410. package/src/resources/extensions/gsd/migrate/safety.ts +4 -1
  411. package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
  412. package/src/resources/extensions/gsd/milestone-planning-persistence.ts +2 -2
  413. package/src/resources/extensions/gsd/milestone-reopen-events.ts +3 -6
  414. package/src/resources/extensions/gsd/notification-store.ts +26 -3
  415. package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +6 -4
  416. package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
  417. package/src/resources/extensions/gsd/paths.ts +33 -0
  418. package/src/resources/extensions/gsd/pre-execution-checks.ts +109 -3
  419. package/src/resources/extensions/gsd/preferences-models.ts +12 -47
  420. package/src/resources/extensions/gsd/projection-flush.ts +20 -0
  421. package/src/resources/extensions/gsd/prompts/complete-slice.md +3 -3
  422. package/src/resources/extensions/gsd/prompts/execute-task.md +1 -1
  423. package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  424. package/src/resources/extensions/gsd/prompts/plan-slice.md +2 -2
  425. package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
  426. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  427. package/src/resources/extensions/gsd/prompts/refine-slice.md +2 -2
  428. package/src/resources/extensions/gsd/prompts/replan-slice.md +2 -2
  429. package/src/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  430. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -1
  431. package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  432. package/src/resources/extensions/gsd/prompts/run-uat.md +7 -5
  433. package/src/resources/extensions/gsd/prompts/system.md +5 -2
  434. package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  435. package/src/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  436. package/src/resources/extensions/gsd/provider-error-guidance.ts +4 -9
  437. package/src/resources/extensions/gsd/provider-switch-observer.ts +1 -1
  438. package/src/resources/extensions/gsd/publication.ts +122 -0
  439. package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
  440. package/src/resources/extensions/gsd/recovery-classification.ts +42 -96
  441. package/src/resources/extensions/gsd/roadmap-slices.ts +28 -3
  442. package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
  443. package/src/resources/extensions/gsd/session-lock.ts +1 -1
  444. package/src/resources/extensions/gsd/state.ts +9 -21
  445. package/src/resources/extensions/gsd/stop-notice.ts +75 -0
  446. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +97 -1
  447. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +198 -26
  448. package/src/resources/extensions/gsd/tests/auto-remote-session-lock-cleanup.test.ts +65 -3
  449. package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
  450. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
  451. package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
  452. package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
  453. package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
  454. package/src/resources/extensions/gsd/tests/checkout-branch-stash-guard.test.ts +66 -1
  455. package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +22 -0
  456. package/src/resources/extensions/gsd/tests/commands-verdict.test.ts +8 -7
  457. package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
  458. package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
  459. package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
  460. package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
  461. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +10 -10
  462. package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
  463. package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
  464. package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +273 -0
  465. package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
  466. package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
  467. package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
  468. package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
  469. package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
  470. package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
  471. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
  472. package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
  473. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
  474. package/src/resources/extensions/gsd/tests/guidance.test.ts +148 -0
  475. package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +2 -6
  476. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +53 -11
  477. package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +73 -58
  478. package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
  479. package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +199 -0
  480. package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
  481. package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
  482. package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
  483. package/src/resources/extensions/gsd/tests/notification-store.test.ts +32 -0
  484. package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
  485. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
  486. package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +138 -0
  487. package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
  488. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
  489. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +193 -1
  490. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
  491. package/src/resources/extensions/gsd/tests/provider-error-guidance.test.ts +3 -3
  492. package/src/resources/extensions/gsd/tests/publication.test.ts +120 -0
  493. package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +157 -0
  494. package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
  495. package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +20 -1
  496. package/src/resources/extensions/gsd/tests/stop-notice.test.ts +70 -0
  497. package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
  498. package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +76 -0
  499. package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +8 -0
  500. package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +155 -0
  501. package/src/resources/extensions/gsd/tests/tool-unavailable-retry.test.ts +33 -0
  502. package/src/resources/extensions/gsd/tests/transport-gate-double-complete.test.ts +139 -0
  503. package/src/resources/extensions/gsd/tests/uat-policy.test.ts +112 -29
  504. package/src/resources/extensions/gsd/tests/unit-closeout.test.ts +209 -0
  505. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +67 -2
  506. package/src/resources/extensions/gsd/tests/unit-registry.test.ts +163 -0
  507. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
  508. package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +2 -0
  509. package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +44 -1
  510. package/src/resources/extensions/gsd/tests/workflow-events.test.ts +19 -0
  511. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +2 -2
  512. package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
  513. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +275 -40
  514. package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
  515. package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
  516. package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
  517. package/src/resources/extensions/gsd/tests/write-gate.test.ts +67 -1
  518. package/src/resources/extensions/gsd/tool-contract.ts +38 -3
  519. package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
  520. package/src/resources/extensions/gsd/tool-surface-readiness.ts +76 -0
  521. package/src/resources/extensions/gsd/tools/complete-milestone.ts +3 -2
  522. package/src/resources/extensions/gsd/tools/complete-slice.ts +22 -12
  523. package/src/resources/extensions/gsd/tools/complete-task.ts +3 -2
  524. package/src/resources/extensions/gsd/tools/exec-tool.ts +8 -7
  525. package/src/resources/extensions/gsd/tools/plan-slice.ts +14 -8
  526. package/src/resources/extensions/gsd/tools/plan-task.ts +2 -2
  527. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +2 -2
  528. package/src/resources/extensions/gsd/tools/reopen-milestone.ts +2 -2
  529. package/src/resources/extensions/gsd/tools/reopen-slice.ts +2 -2
  530. package/src/resources/extensions/gsd/tools/reopen-task.ts +2 -2
  531. package/src/resources/extensions/gsd/tools/replan-slice.ts +2 -2
  532. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
  533. package/src/resources/extensions/gsd/uat-policy.ts +62 -16
  534. package/src/resources/extensions/gsd/unit-closeout.ts +201 -0
  535. package/src/resources/extensions/gsd/unit-context-composer.ts +111 -1
  536. package/src/resources/extensions/gsd/unit-context-manifest.ts +4 -28
  537. package/src/resources/extensions/gsd/unit-registry.ts +412 -0
  538. package/src/resources/extensions/gsd/unit-tool-contracts.ts +27 -192
  539. package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
  540. package/src/resources/extensions/gsd/verification-verdict.ts +4 -2
  541. package/src/resources/extensions/gsd/web-app-uat.ts +51 -8
  542. package/src/resources/extensions/gsd/workflow-event-ledger.ts +131 -0
  543. package/src/resources/extensions/gsd/workflow-event-vocabulary.ts +59 -0
  544. package/src/resources/extensions/gsd/workflow-events.ts +12 -20
  545. package/src/resources/extensions/gsd/workflow-reconcile.ts +29 -62
  546. package/src/resources/extensions/gsd/workflow-tool-surface.ts +4 -1
  547. package/src/resources/extensions/gsd/worktree-git-recovery.ts +15 -9
  548. package/src/resources/extensions/gsd/worktree-lifecycle.ts +3 -8
  549. package/src/resources/extensions/gsd/worktree-manager.ts +6 -1
  550. package/src/resources/extensions/gsd/worktree-root.ts +12 -0
  551. package/src/resources/extensions/gsd/worktree-session-state.ts +3 -5
  552. package/src/resources/extensions/gsd/worktree.ts +7 -1
  553. package/src/resources/extensions/search-the-web/native-search.ts +5 -3
  554. package/src/resources/extensions/shared/browser-contract.ts +66 -0
  555. package/src/resources/extensions/shared/gsd-browser-cli.ts +141 -6
  556. package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
  557. package/src/resources/shared/package-manager-detection.ts +1 -1
  558. package/src/resources/shared/package.json +3 -0
  559. package/src/resources/skills/create-skill/SKILL.md +3 -0
  560. package/src/resources/skills/create-skill/references/executable-code.md +1 -1
  561. package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
  562. package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
  563. package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
  564. package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
  565. package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
  566. package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
  567. package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
  568. package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
  569. package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
  570. package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
  571. package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
  572. package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
  573. package/src/resources/skills/gsd-browser/SKILL.md +0 -41
  574. /package/dist/web/standalone/.next/static/{C24pqUd-aru-l0Dp0gLZP → FBNo5cT_chy7YNoAQsU3o}/_buildManifest.js +0 -0
  575. /package/dist/web/standalone/.next/static/{C24pqUd-aru-l0Dp0gLZP → FBNo5cT_chy7YNoAQsU3o}/_ssgManifest.js +0 -0
@@ -29,6 +29,7 @@ import { markLatestActiveForWorkerCanceled } from "./db/unit-dispatches.js";
29
29
  import { getRuntimeKv, setRuntimeKv, deleteRuntimeKv } from "./db/runtime-kv.js";
30
30
  import { _getAdapter, isDbAvailable } from "./gsd-db.js";
31
31
  import { gsdRoot, normalizeRealPath } from "./paths.js";
32
+ import { crashResumeHint } from "./guidance.js";
32
33
  import { atomicWriteSync } from "./atomic-write.js";
33
34
  import { effectiveLockFile } from "./session-lock.js";
34
35
  import { isInFlightRuntimePhase, listUnitRuntimeRecords } from "./unit-runtime.js";
@@ -185,6 +186,7 @@ export function writeLock(basePath, unitType, unitId, sessionFile) {
185
186
  * stale session-file pointer.
186
187
  */
187
188
  export function clearLock(basePath) {
189
+ const legacyLock = readLegacyLock(basePath);
188
190
  clearLegacyLockFile(basePath);
189
191
  if (!isDbAvailable())
190
192
  return;
@@ -197,9 +199,13 @@ export function clearLock(basePath) {
197
199
  deleteRuntimeKv("worker", staleWorker.worker_id, SESSION_FILE_KV_KEY);
198
200
  return;
199
201
  }
200
- const lock = readLegacyLock(basePath);
201
- if (lock?.pid)
202
- markWorkerStoppingByPid(projectRoot, lock.pid);
202
+ if (legacyLock?.pid) {
203
+ markWorkerStoppingByPid(projectRoot, legacyLock.pid);
204
+ const workerByLegacyPid = getAllAutoWorkers().find((w) => w.pid === legacyLock.pid
205
+ && normalizeRealPath(w.project_root_realpath) === projectRoot);
206
+ if (workerByLegacyPid)
207
+ forceReleaseLeasesForWorker(workerByLegacyPid.worker_id);
208
+ }
203
209
  const worker = findActiveWorkerForCurrentProcess(projectRoot);
204
210
  if (worker)
205
211
  deleteRuntimeKv("worker", worker.worker_id, SESSION_FILE_KV_KEY);
@@ -289,18 +295,9 @@ export function formatCrashInfo(lock) {
289
295
  ` Started at: ${lock.unitStartedAt}`,
290
296
  ` PID: ${lock.pid}`,
291
297
  ];
292
- if (lock.unitType === "starting" && lock.unitId === "bootstrap") {
293
- lines.push(`No work was lost. Run /gsd auto to restart.`);
294
- }
295
- else if (lock.unitType.includes("research") || lock.unitType.includes("plan")) {
296
- lines.push(`The ${lock.unitType} unit may be incomplete. Run /gsd auto to re-run it.`);
297
- }
298
- else if (lock.unitType.includes("execute")) {
299
- lines.push(`Task execution was interrupted. Run /gsd auto to resume — completed work is preserved.`);
300
- }
301
- else if (lock.unitType.includes("complete")) {
302
- lines.push(`Slice/milestone completion was interrupted. Run /gsd auto to finish.`);
303
- }
298
+ const hint = crashResumeHint(lock.unitType, lock.unitId);
299
+ if (hint)
300
+ lines.push(hint);
304
301
  return lines.join("\n");
305
302
  }
306
303
  /**
@@ -5,6 +5,7 @@
5
5
  // Read-only callers (forensics, dashboard, doctor) depend on this seam, not on
6
6
  // the single-writer surface.
7
7
  import { getDbOrNull } from "./engine.js";
8
+ import { isClosedStatus } from "../status-guards.js";
8
9
  import { getGateIdsForTurn } from "../gate-registry.js";
9
10
  import { emptyTaskStatusCounts, rowToActiveTaskSummary, rowToIdStatusSummary, rowToTaskStatusCounts, rowsToStringColumn, } from "../db-lightweight-query-rows.js";
10
11
  import { rowToActiveDecision, rowToActiveRequirement, rowToDecision, rowToRequirement, rowsToRequirementCounts, } from "../db-decision-requirement-rows.js";
@@ -217,6 +218,31 @@ export function getMilestoneSlices(milestoneId) {
217
218
  const rows = getDbOrNull().prepare("SELECT * FROM slices WHERE milestone_id = :mid ORDER BY sequence, id").all({ ":mid": milestoneId });
218
219
  return rows.map(rowToSlice);
219
220
  }
221
+ /**
222
+ * Consolidated DB read for dispatch/gate/completion decisions (ADR-017).
223
+ * `done` uses the canonical closed-status predicate (`isClosedStatus`) — the
224
+ * same vocabulary the SQL terminal-status fragment derives from. Decision
225
+ * paths must consume this instead of parsing `.gsd/*.md` projections.
226
+ * Rows keep `getMilestoneSlices` ordering (sequence, then id).
227
+ */
228
+ export function getMilestoneSliceSummaries(milestoneId) {
229
+ return getMilestoneSlices(milestoneId).map((s) => ({
230
+ id: s.id,
231
+ title: s.title,
232
+ done: isClosedStatus(s.status),
233
+ depends: s.depends ?? [],
234
+ }));
235
+ }
236
+ /**
237
+ * Ids of slices closed per the canonical status vocabulary (ADR-017), in
238
+ * milestone order. Thin wrapper over `getMilestoneSliceSummaries` for the
239
+ * common "which slices are done?" decision-path read.
240
+ */
241
+ export function getClosedSliceIds(milestoneId) {
242
+ return getMilestoneSliceSummaries(milestoneId)
243
+ .filter((s) => s.done)
244
+ .map((s) => s.id);
245
+ }
220
246
  export function getArtifact(path) {
221
247
  if (!getDbOrNull())
222
248
  return null;
@@ -620,27 +620,18 @@ async function mirrorDecisionToMemory(id, normalizedFields) {
620
620
  /**
621
621
  * Extract a milestone/slice reference from a deferral decision.
622
622
  *
623
- * Detects deferrals by checking:
624
- * - scope contains "defer" (e.g., "deferral", "defer")
625
- * - choice or decision contains "defer" + an M###/S## pattern
623
+ * Detects deferrals when the slice reference is part of the deferral phrase.
626
624
  *
627
625
  * Returns { milestoneId, sliceId } if found, null otherwise.
628
626
  */
629
627
  export function extractDeferredSliceRef(fields) {
630
- const isDeferral = /\bdefer(?:ral|red|ring|s)?\b/i.test(fields.scope) ||
631
- /\bdefer(?:ral|red|ring|s)?\b/i.test(fields.choice) ||
632
- /\bdefer(?:ral|red|ring|s)?\b/i.test(fields.decision);
633
- if (!isDeferral)
634
- return null;
635
- // Look for M###/S## pattern in choice first, then decision
636
- const slicePattern = /\b(M\d{3,4})\/(S\d{2,3})\b/;
637
- const choiceMatch = fields.choice.match(slicePattern);
638
- if (choiceMatch) {
639
- return { milestoneId: choiceMatch[1], sliceId: choiceMatch[2] };
640
- }
641
- const decisionMatch = fields.decision.match(slicePattern);
642
- if (decisionMatch) {
643
- return { milestoneId: decisionMatch[1], sliceId: decisionMatch[2] };
628
+ const defersSlicePattern = /\bdefer(?:ral|red|ring|s)?\b\s+(?:(?:of|the)\s+)*(?:slice\s+)?\b(M\d{3,4})\/(S\d{2,3})\b/i;
629
+ const sliceIsDeferredPattern = /\b(M\d{3,4})\/(S\d{2,3})\b\s+(?:is|was|will be|should be|can be)\s+defer(?:red|ring)?\b/i;
630
+ for (const text of [fields.choice, fields.decision, fields.scope]) {
631
+ const match = text.match(defersSlicePattern) ?? text.match(sliceIsDeferredPattern);
632
+ if (match) {
633
+ return { milestoneId: match[1], sliceId: match[2] };
634
+ }
644
635
  }
645
636
  return null;
646
637
  }
@@ -2,9 +2,8 @@
2
2
  import { resolveMilestoneFile } from "./paths.js";
3
3
  import { findMilestoneIds } from "./guided-flow.js";
4
4
  import { parseUnitId } from "./unit-id.js";
5
- import { isDbAvailable, getMilestoneSlices, getMilestone } from "./gsd-db.js";
6
- import { parseRoadmap } from "./parsers-legacy.js";
7
- import { isClosedStatus, isSkippedForDispatch } from "./status-guards.js";
5
+ import { isDbAvailable, getMilestoneSliceSummaries, getMilestone } from "./gsd-db.js";
6
+ import { isSkippedForDispatch } from "./status-guards.js";
8
7
  import { classifyMilestoneSummaryContent } from "./milestone-summary-classifier.js";
9
8
  import { readFileSync } from "node:fs";
10
9
  const SLICE_DISPATCH_TYPES = new Set([
@@ -97,38 +96,14 @@ export function getPriorSliceCompletionBlocker(base, _mainBranch, unitType, unit
97
96
  continue;
98
97
  }
99
98
  }
100
- let slices = null;
101
- if (isDbAvailable()) {
102
- const rows = getMilestoneSlices(mid);
103
- if (rows.length > 0) {
104
- slices = rows.map((r) => ({
105
- id: r.id,
106
- done: isClosedStatus(r.status),
107
- depends: r.depends ?? [],
108
- }));
109
- }
110
- }
111
- if (!slices) {
112
- // File-based fallback: parse roadmap checkboxes
113
- const roadmapPath = resolveMilestoneFile(base, mid, "ROADMAP");
114
- if (!roadmapPath)
115
- continue;
116
- let roadmapContent;
117
- try {
118
- roadmapContent = readFileSync(roadmapPath, "utf-8");
119
- }
120
- catch {
121
- continue;
122
- }
123
- const parsed = parseRoadmap(roadmapContent);
124
- if (parsed.slices.length === 0)
125
- continue;
126
- slices = parsed.slices.map((s) => ({
127
- id: s.id,
128
- done: s.done,
129
- depends: s.depends ?? [],
130
- }));
131
- }
99
+ // DB-authoritative eligibility list (ADR-017) — markdown projections are
100
+ // never parsed for dispatch decisions. No DB / no rows → skip this
101
+ // milestone's check (unknown is not a blocker).
102
+ if (!isDbAvailable())
103
+ continue;
104
+ const slices = getMilestoneSliceSummaries(mid);
105
+ if (slices.length === 0)
106
+ continue;
132
107
  if (mid !== targetMid) {
133
108
  const incomplete = slices.find((slice) => !slice.done);
134
109
  if (incomplete) {
@@ -1,11 +1,11 @@
1
1
  import { existsSync, statSync } from "node:fs";
2
- import { join } from "node:path";
3
2
  import { isDbAvailable, _getAdapter } from "./gsd-db.js";
4
3
  import { isAfter, latestExplicitReopenAt } from "./milestone-reopen-events.js";
5
4
  import { resolveGsdPathContract, resolveMilestoneFile } from "./paths.js";
6
5
  import { deriveState } from "./state.js";
6
+ import { workflowEventLogPath } from "./workflow-event-ledger.js";
7
7
  import { readEvents } from "./workflow-events.js";
8
- import { renderAllProjections } from "./workflow-projections.js";
8
+ import { flushWorkflowProjections } from "./projection-flush.js";
9
9
  export async function checkEngineHealth(basePath, issues, fixesApplied) {
10
10
  const dbPath = resolveGsdPathContract(basePath).projectDb;
11
11
  if (!isDbAvailable() && existsSync(dbPath)) {
@@ -228,7 +228,7 @@ export async function checkEngineHealth(basePath, issues, fixesApplied) {
228
228
  // relative to the event log and re-render them.
229
229
  try {
230
230
  if (isDbAvailable()) {
231
- const eventLogPath = join(basePath, ".gsd", "event-log.jsonl");
231
+ const eventLogPath = workflowEventLogPath(basePath);
232
232
  const events = readEvents(eventLogPath);
233
233
  if (events.length > 0) {
234
234
  const lastEventTs = new Date(events[events.length - 1].ts).getTime();
@@ -239,7 +239,7 @@ export async function checkEngineHealth(basePath, issues, fixesApplied) {
239
239
  const roadmapPath = resolveMilestoneFile(basePath, milestone.id, "ROADMAP");
240
240
  if (!roadmapPath || !existsSync(roadmapPath)) {
241
241
  try {
242
- await renderAllProjections(basePath, milestone.id);
242
+ await flushWorkflowProjections(basePath, { milestoneId: milestone.id });
243
243
  fixesApplied.push(`re-rendered missing projections for ${milestone.id}`);
244
244
  }
245
245
  catch {
@@ -250,7 +250,7 @@ export async function checkEngineHealth(basePath, issues, fixesApplied) {
250
250
  const projectionMtime = statSync(roadmapPath).mtimeMs;
251
251
  if (lastEventTs > projectionMtime) {
252
252
  try {
253
- await renderAllProjections(basePath, milestone.id);
253
+ await flushWorkflowProjections(basePath, { milestoneId: milestone.id });
254
254
  fixesApplied.push(`re-rendered stale projections for ${milestone.id}`);
255
255
  }
256
256
  catch {
@@ -12,7 +12,7 @@ import { existsSync, readFileSync, statSync } from "node:fs";
12
12
  import { execSync } from "node:child_process";
13
13
  import { join } from "node:path";
14
14
  import { detectPythonExecutable } from "./python-resolver.js";
15
- import { findWorktreeSegment } from "./worktree-root.js";
15
+ import { projectRootFromWorktreePath } from "./worktree-root.js";
16
16
  // ── Constants ──────────────────────────────────────────────────────────────
17
17
  /** Default dev server ports to scan for conflicts. */
18
18
  const DEFAULT_DEV_PORTS = [3000, 3001, 4000, 5000, 5173, 8000, 8080, 8888];
@@ -33,11 +33,7 @@ function resolveWorktreeProjectRoot(basePath) {
33
33
  const envRoot = process.env.GSD_WORKTREE;
34
34
  if (envRoot)
35
35
  return envRoot;
36
- const segment = findWorktreeSegment(basePath.replace(/\\/g, "/"));
37
- if (!segment)
38
- return null;
39
- // Everything before the worktree segment is the project root
40
- return basePath.slice(0, segment.gsdIdx);
36
+ return projectRootFromWorktreePath(basePath);
41
37
  }
42
38
  function tryExec(cmd, cwd) {
43
39
  try {
@@ -1,3 +1,7 @@
1
+ import { doctorFixHint } from "./guidance.js";
2
+ function severityTag(severity) {
3
+ return severity === "error" ? "ERROR" : severity === "warning" ? "WARN" : "INFO";
4
+ }
1
5
  function matchesScope(unitId, scope) {
2
6
  if (!scope)
3
7
  return true;
@@ -47,8 +51,10 @@ export function formatDoctorReport(report, options) {
47
51
  if (scopedIssues.length > 0) {
48
52
  lines.push("Priority issues:");
49
53
  for (const issue of scopedIssues.slice(0, maxIssues)) {
50
- const prefix = issue.severity === "error" ? "ERROR" : issue.severity === "warning" ? "WARN" : "INFO";
51
- lines.push(`- [${prefix}] ${issue.unitId}: ${issue.message}${issue.file ? ` (${issue.file})` : ""}`);
54
+ lines.push(`- [${severityTag(issue.severity)}] ${issue.unitId}: ${issue.message}${issue.file ? ` (${issue.file})` : ""}`);
55
+ const hint = doctorFixHint(issue.code);
56
+ if (hint && issue.severity !== "info")
57
+ lines.push(` Fix: ${hint}`);
52
58
  }
53
59
  if (scopedIssues.length > maxIssues) {
54
60
  lines.push(`- ...and ${scopedIssues.length - maxIssues} more in scope`);
@@ -66,10 +72,7 @@ export function formatDoctorReport(report, options) {
66
72
  export function formatDoctorIssuesForPrompt(issues) {
67
73
  if (issues.length === 0)
68
74
  return "- No remaining issues in scope.";
69
- return issues.map(issue => {
70
- const prefix = issue.severity === "error" ? "ERROR" : issue.severity === "warning" ? "WARN" : "INFO";
71
- return `- [${prefix}] ${issue.unitId} | ${issue.code} | ${issue.message}${issue.file ? ` | file: ${issue.file}` : ""} | fixable: ${issue.fixable ? "yes" : "no"}`;
72
- }).join("\n");
75
+ return issues.map(issue => `- [${severityTag(issue.severity)}] ${issue.unitId} | ${issue.code} | ${issue.message}${issue.file ? ` | file: ${issue.file}` : ""} | fixable: ${issue.fixable ? "yes" : "no"}`).join("\n");
73
76
  }
74
77
  /**
75
78
  * Serialize a doctor report to JSON — suitable for CI/tooling integration.
@@ -3,10 +3,9 @@ import { spawnSync } from "node:child_process";
3
3
  import { cpSync, existsSync, mkdirSync, readdirSync, realpathSync, rmSync, statSync } from "node:fs";
4
4
  import { dirname, join } from "node:path";
5
5
  import { loadFile } from "./files.js";
6
- import { parseRoadmap as parseLegacyRoadmap } from "./parsers-legacy.js";
7
- import { isDbAvailable, getMilestone } from "./gsd-db.js";
8
6
  import { resolveMilestoneFile } from "./paths.js";
9
- import { deriveState, isMilestoneComplete } from "./state.js";
7
+ import { isCompletedMilestoneTerminal } from "./milestone-closeout.js";
8
+ import { deriveState } from "./state.js";
10
9
  import { allWorktreesDirs, createWorktree, listWorktrees, resolveGitDir } from "./worktree-manager.js";
11
10
  import { abortAndReset } from "./git-self-heal.js";
12
11
  import { RUNTIME_EXCLUSION_PATHS, resolveMilestoneIntegrationBranch, writeIntegrationBranch } from "./git-service.js";
@@ -141,21 +140,6 @@ function getSnapshotDiffCheckFailure(basePath) {
141
140
  }
142
141
  return failures.length > 0 ? failures.join("\n") : null;
143
142
  }
144
- async function isCompletedMilestoneTerminal(basePath, milestoneId) {
145
- const summaryPath = resolveMilestoneFile(basePath, milestoneId, "SUMMARY");
146
- if (!summaryPath)
147
- return false;
148
- if (isDbAvailable()) {
149
- const milestone = getMilestone(milestoneId);
150
- return !!milestone && milestone.status === "complete";
151
- }
152
- const roadmapPath = resolveMilestoneFile(basePath, milestoneId, "ROADMAP");
153
- const roadmapContent = roadmapPath ? await loadFile(roadmapPath) : null;
154
- if (!roadmapContent)
155
- return false;
156
- const roadmap = parseLegacyRoadmap(roadmapContent);
157
- return isMilestoneComplete(roadmap);
158
- }
159
143
  export async function checkGitHealth(basePath, issues, fixesApplied, shouldFix, isolationMode = "none") {
160
144
  // Degrade gracefully if not a git repo
161
145
  if (!nativeIsRepo(basePath)) {
@@ -401,21 +401,19 @@ export async function checkRuntimeHealth(basePath, issues, fixesApplied, shouldF
401
401
  if (!hasBlanketIgnore) {
402
402
  missing.push(...criticalPatterns.filter(p => !existingLines.has(p)));
403
403
  }
404
- {
405
- if (missing.length > 0) {
406
- issues.push({
407
- severity: "warning",
408
- code: "gitignore_missing_patterns",
409
- scope: "project",
410
- unitId: "project",
411
- message: `${missing.length} critical GSD runtime pattern(s) missing from .gitignore: ${missing.join(", ")}`,
412
- file: ".gitignore",
413
- fixable: true,
414
- });
415
- if (shouldFix("gitignore_missing_patterns")) {
416
- ensureGitignore(basePath, { manageGitignore });
417
- fixesApplied.push("added missing GSD runtime patterns to .gitignore");
418
- }
404
+ if (missing.length > 0) {
405
+ issues.push({
406
+ severity: "warning",
407
+ code: "gitignore_missing_patterns",
408
+ scope: "project",
409
+ unitId: "project",
410
+ message: `${missing.length} critical GSD runtime pattern(s) missing from .gitignore: ${missing.join(", ")}`,
411
+ file: ".gitignore",
412
+ fixable: true,
413
+ });
414
+ if (shouldFix("gitignore_missing_patterns")) {
415
+ ensureGitignore(basePath, { manageGitignore });
416
+ fixesApplied.push("added missing GSD runtime patterns to .gitignore");
419
417
  }
420
418
  }
421
419
  }
@@ -0,0 +1,70 @@
1
+ // Project/App: gsd-pi
2
+ // File Purpose: Typed contract for which tool lifecycle hooks fire under which
3
+ // engine, plus the single seam for tool-name normalization.
4
+ //
5
+ // ── Why this contract exists ────────────────────────────────────────────────
6
+ // External engines (claude-code-cli) pre-execute tools inside the vendor CLI
7
+ // and hand the agent loop a `toolCall.externalResult`. The loop short-circuits
8
+ // before `beforeToolCall`/`afterToolCall` ever run for those calls
9
+ // (packages/pi-agent-core/src/agent-loop.ts, prepareToolCall: the
10
+ // externalResult branch returns an "immediate" outcome before the
11
+ // config.beforeToolCall invocation, and "immediate" outcomes skip
12
+ // finalizeExecutedToolCall where config.afterToolCall lives).
13
+ // `beforeToolCall`/`afterToolCall` are exactly what the extension runner maps
14
+ // to the `tool_call`/`tool_result` extension events
15
+ // (packages/gsd-agent-core/src/session/agent-session-extensions.ts,
16
+ // installAgentToolHooks).
17
+ //
18
+ // `tool_execution_start` is emitted unconditionally before prepareToolCall
19
+ // and `tool_execution_end` after every finalized outcome — immediate or
20
+ // executed — so those two are the ONLY tool lifecycle hooks that fire for
21
+ // every tool call on every engine.
22
+ //
23
+ // Consequence: any enforcement attached only to `tool_call` (blocking) or
24
+ // `tool_result` (rewriting) is silently dead under external engines. Safety
25
+ // enforcement must ride `tool_execution_start`/`tool_execution_end`, or
26
+ // mirror across both with toolCallId dedup. See the per-registration contract
27
+ // comments in bootstrap/register-hooks.ts for how each registered hook
28
+ // honors (or knowingly violates) this contract.
29
+ import { stripMcpToolPrefix } from "./mcp-tool-name.js";
30
+ import { canonicalWorkflowSurfaceToolName } from "./workflow-tool-surface.js";
31
+ /**
32
+ * Tool lifecycle hooks that fire for EVERY tool call on EVERY engine,
33
+ * including external engines (claude-code-cli) that pre-execute tools.
34
+ * Attach safety-critical enforcement and evidence collection here.
35
+ */
36
+ export const UNIVERSAL_TOOL_HOOKS = ["tool_execution_start", "tool_execution_end"];
37
+ /**
38
+ * Tool lifecycle hooks that fire ONLY for natively executed tools. External
39
+ * engines pre-execute tools (externalResult), short-circuiting the agent
40
+ * loop's beforeToolCall/afterToolCall — so handlers on these events never run
41
+ * for those calls. Blocking guards attached only here are dead under external
42
+ * engines; they need a tool_execution_start mirror to be universal.
43
+ */
44
+ export const NATIVE_ONLY_TOOL_HOOKS = ["tool_call", "tool_result"];
45
+ // Non-tool lifecycle events (session_start, agent_end, message_update, ...)
46
+ // are intentionally NOT classified here: they are emitted by the session
47
+ // host / extension runner independent of tool execution, so the external
48
+ // engine short-circuit above does not apply to them. Only classify events
49
+ // whose engine behavior has been verified against the agent loop.
50
+ /**
51
+ * Canonical tool name: strips the `mcp__<server>__` prefix when present,
52
+ * nothing else. Use for identity checks against host/native tool names and
53
+ * for any guard that must NOT conflate workflow aliases with their canonical
54
+ * tools (e.g. write gates, evidence keys).
55
+ *
56
+ * Malformed MCP names (empty server or empty tool segment, e.g.
57
+ * `mcp____tool` or `mcp__server__`) are returned unchanged.
58
+ */
59
+ export function canonicalToolName(toolName) {
60
+ return stripMcpToolPrefix(toolName);
61
+ }
62
+ /**
63
+ * Workflow-aware canonical tool name: strips the MCP prefix AND resolves
64
+ * workflow tool aliases to their canonical contract names. Use whenever the
65
+ * name is compared against the workflow tool surface (scoping, presentation,
66
+ * dispatch) — plain {@link canonicalToolName} would miss alias spellings.
67
+ */
68
+ export function canonicalWorkflowToolName(toolName) {
69
+ return canonicalWorkflowSurfaceToolName(toolName);
70
+ }
@@ -9,6 +9,7 @@
9
9
  *
10
10
  * @see https://github.com/open-gsd/gsd-pi/issues/2577
11
11
  */
12
+ import { TOOL_SURFACE_NOT_READY } from "./tool-surface-readiness.js";
12
13
  export function createRetryState() {
13
14
  return { networkRetryCount: 0, consecutiveTransientCount: 0, currentRetryModelId: undefined };
14
15
  }
@@ -44,6 +45,10 @@ const CONNECTION_RE = /terminated|connection.?(?:refused|error)|other side close
44
45
  const STREAM_RE = /in JSON at position \d+|Unexpected end of JSON|SyntaxError.*JSON/i;
45
46
  const RESET_DELAY_RE = /reset in (\d+)s/i;
46
47
  const TOOL_SCHEMA_RE = /schema overload|consecutive tool validation failures/i;
48
+ // GSD tool-surface readiness abort (claude-code stream adapter): the workflow
49
+ // MCP server had not registered the Unit's required tools at SDK init. The
50
+ // server typically finishes connecting within seconds — same-model retry.
51
+ const TOOL_SURFACE_NOT_READY_RE = new RegExp(TOOL_SURFACE_NOT_READY, "i");
47
52
  // Provider rejected the request shape for the selected model (400 bad request,
48
53
  // grammar limits, etc.). Not transient — try a different model/fallback.
49
54
  // Context-window 400s stay in SERVER_RE (checked earlier).
@@ -77,6 +82,10 @@ export function classifyError(errorMsg, retryAfterMs) {
77
82
  if (TOOL_SCHEMA_RE.test(errorMsg)) {
78
83
  return { kind: "tool-schema", retryAfterMs: 0 };
79
84
  }
85
+ // Tool-surface readiness abort — transient; retry the same model shortly.
86
+ if (TOOL_SURFACE_NOT_READY_RE.test(errorMsg)) {
87
+ return { kind: "network", retryAfterMs: retryAfterMs ?? 3_000 };
88
+ }
80
89
  const isPermanent = PERMANENT_RE.test(errorMsg);
81
90
  const isRateLimit = RATE_LIMIT_RE.test(errorMsg) || AFFORDABILITY_RE.test(errorMsg);
82
91
  const isUnsupportedModel = UNSUPPORTED_MODEL_MODEL_RE.test(errorMsg) &&
@@ -11,7 +11,11 @@ import { spawn } from "node:child_process";
11
11
  import { existsSync, mkdirSync, writeFileSync } from "node:fs";
12
12
  import { randomUUID } from "node:crypto";
13
13
  import { resolve } from "node:path";
14
+ import { killProcessTree, SIGKILL_GRACE_MS, HARD_DEADLINE_MS } from "@gsd/pi-coding-agent";
14
15
  const ALWAYS_FORWARD_ENV = ["PATH", "HOME"];
16
+ // SIGKILL_GRACE_MS / HARD_DEADLINE_MS are imported from @gsd/pi-coding-agent
17
+ // (shell.ts) — the single source of truth for the graceful-kill timing ladder —
18
+ // so this sandbox can never drift from the canonical kill path it delegates to.
15
19
  export const EXEC_DEFAULTS = {
16
20
  clampTimeoutMs: 600_000,
17
21
  defaultTimeoutMs: 30_000,
@@ -120,6 +124,7 @@ export function runExecSandbox(request, opts) {
120
124
  exit_code: null,
121
125
  signal: null,
122
126
  timed_out: false,
127
+ force_resolved: false,
123
128
  duration_ms: duration,
124
129
  stdout_bytes: 0,
125
130
  stderr_bytes: Buffer.byteLength(`spawn error: ${message}\n`),
@@ -172,24 +177,38 @@ export function runExecSandbox(request, opts) {
172
177
  stderrTruncated = true;
173
178
  }
174
179
  });
180
+ const effectiveGraceMs = opts.kill_grace_ms ?? SIGKILL_GRACE_MS;
181
+ const effectiveForceResolveDelay = opts.force_resolve_delay_ms ?? (effectiveGraceMs + HARD_DEADLINE_MS);
175
182
  let timedOut = false;
183
+ let settled = false;
184
+ let forceResolveTimer;
176
185
  const timer = setTimeout(() => {
177
186
  timedOut = true;
178
- if (useProcessGroup && child.pid != null) {
179
- try {
180
- process.kill(-child.pid, "SIGKILL");
181
- }
182
- catch {
183
- child.kill("SIGKILL");
184
- }
187
+ // killProcessTree handles both platforms and kills the whole tree: on Unix
188
+ // it signals the process group (SIGTERM -> grace -> SIGKILL); on Windows it
189
+ // force-kills the tree via taskkill /F /T. Using child.kill("SIGTERM") here
190
+ // would only terminate the direct child on Windows, orphaning grandchildren.
191
+ if (child.pid != null) {
192
+ killProcessTree(child.pid, { graceMs: effectiveGraceMs });
185
193
  }
186
194
  else {
187
- child.kill("SIGKILL");
195
+ child.kill("SIGTERM");
188
196
  }
197
+ // Arm hard-deadline force-resolve in case child never closes (D-state).
198
+ // The "SIGKILL" here is a synthetic marker (the process may not have actually
199
+ // received it); force_resolved=true records that this was a deadline, not an exit.
200
+ forceResolveTimer = setTimeout(() => {
201
+ finalize(null, "SIGKILL", true);
202
+ }, effectiveForceResolveDelay);
203
+ forceResolveTimer.unref?.();
189
204
  }, timeoutMs);
190
205
  timer.unref?.();
191
- const finalize = (exitCode, signal) => {
206
+ const finalize = (exitCode, signal, forceResolved = false) => {
207
+ if (settled)
208
+ return;
209
+ settled = true;
192
210
  clearTimeout(timer);
211
+ clearTimeout(forceResolveTimer);
193
212
  const duration = Date.now() - started;
194
213
  const stdoutBuf = Buffer.concat(stdoutChunks);
195
214
  const stderrBuf = Buffer.concat(stderrChunks);
@@ -211,6 +230,7 @@ export function runExecSandbox(request, opts) {
211
230
  exit_code: exitCode,
212
231
  signal,
213
232
  timed_out: timedOut,
233
+ force_resolved: forceResolved,
214
234
  duration_ms: duration,
215
235
  stdout_bytes: stdoutBytes,
216
236
  stderr_bytes: stderrBytes,
@@ -254,6 +274,7 @@ function writeMeta(path, result, request, now) {
254
274
  exit_code: result.exit_code,
255
275
  signal: result.signal,
256
276
  timed_out: result.timed_out,
277
+ force_resolved: result.force_resolved,
257
278
  duration_ms: result.duration_ms,
258
279
  stdout_bytes: result.stdout_bytes,
259
280
  stderr_bytes: result.stderr_bytes,
@@ -261,7 +282,6 @@ function writeMeta(path, result, request, now) {
261
282
  stderr_truncated: result.stderr_truncated,
262
283
  stdout_path: result.stdout_path,
263
284
  stderr_path: result.stderr_path,
264
- ...(request.metadata ? { metadata: request.metadata } : {}),
265
285
  };
266
286
  writeFileSync(path, `${JSON.stringify(meta, null, 2)}\n`);
267
287
  }
@@ -576,38 +576,52 @@ export function parseTaskPlanIO(content) {
576
576
  outputFiles: extractPaths(outputSection),
577
577
  };
578
578
  }
579
+ /** Canonical list of recognised UAT types — uat-policy.ts re-exports this as UAT_TYPES. */
580
+ export const UAT_TYPE_KEYWORDS = [
581
+ 'artifact-driven',
582
+ 'browser-executable',
583
+ 'runtime-executable',
584
+ 'live-runtime',
585
+ 'mixed',
586
+ 'human-experience',
587
+ ];
588
+ /** Match a value against the recognised UAT type keywords (leading-keyword-only). */
589
+ function matchUatTypeKeyword(value) {
590
+ const normalized = value.trim().toLowerCase();
591
+ return UAT_TYPE_KEYWORDS.find(keyword => normalized.startsWith(keyword));
592
+ }
579
593
  /**
580
594
  * Extract the UAT type from a UAT file's raw content.
581
595
  *
582
596
  * UAT files have no YAML frontmatter - pass raw file content directly.
583
597
  * Classification is leading-keyword-only: e.g. `mixed (artifact-driven + live-runtime)` → `'mixed'`.
584
598
  *
599
+ * The canonical form is a `- UAT mode: <type>` bullet under `## UAT Type`
600
+ * (case-insensitive prefix, `**bold**` tolerated). When no such line exists,
601
+ * a line that itself starts with a recognised keyword — e.g. a bare
602
+ * `browser-executable` under the heading — is accepted, so agent-authored
603
+ * format drift does not silently fall back to artifact-driven.
604
+ *
585
605
  * Returns `undefined` when:
586
606
  * - the `## UAT Type` section is absent
587
- * - no `UAT mode:` bullet is found in the section
588
- * - the value does not start with a recognised keyword
607
+ * - a `UAT mode:` line exists but its value starts with no recognised keyword
608
+ * - no line in the section starts with `UAT mode:` or a recognised keyword
589
609
  */
590
610
  export function extractUatType(content) {
591
611
  const sectionText = extractSection(content, 'UAT Type');
592
612
  if (!sectionText)
593
613
  return undefined;
594
- const bullets = parseBullets(sectionText);
595
- const modeBullet = bullets.find(b => b.startsWith('UAT mode:'));
596
- if (!modeBullet)
597
- return undefined;
598
- const rawValue = modeBullet.slice('UAT mode:'.length).trim().toLowerCase();
599
- if (rawValue.startsWith('artifact-driven'))
600
- return 'artifact-driven';
601
- if (rawValue.startsWith('browser-executable'))
602
- return 'browser-executable';
603
- if (rawValue.startsWith('runtime-executable'))
604
- return 'runtime-executable';
605
- if (rawValue.startsWith('live-runtime'))
606
- return 'live-runtime';
607
- if (rawValue.startsWith('human-experience'))
608
- return 'human-experience';
609
- if (rawValue.startsWith('mixed'))
610
- return 'mixed';
614
+ const lines = parseBullets(sectionText).map(line => line.replace(/\*\*/g, ''));
615
+ for (const line of lines) {
616
+ const declared = /^uat mode:\s*(.*)$/i.exec(line);
617
+ if (declared)
618
+ return matchUatTypeKeyword(declared[1]);
619
+ }
620
+ for (const line of lines) {
621
+ const matched = matchUatTypeKeyword(line);
622
+ if (matched)
623
+ return matched;
624
+ }
611
625
  return undefined;
612
626
  }
613
627
  /**