gsd-pi 2.74.0-dev.2b524c3 → 2.74.0-dev.703eabc

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 (484) hide show
  1. package/dist/cli.js +85 -0
  2. package/dist/headless-query.js +4 -1
  3. package/dist/help-text.js +23 -0
  4. package/dist/resources/extensions/gsd/activity-log.js +16 -0
  5. package/dist/resources/extensions/gsd/auto/detect-stuck.js +11 -4
  6. package/dist/resources/extensions/gsd/auto/loop.js +147 -10
  7. package/dist/resources/extensions/gsd/auto/phases.js +158 -4
  8. package/dist/resources/extensions/gsd/auto/session.js +10 -0
  9. package/dist/resources/extensions/gsd/auto-dispatch.js +11 -1
  10. package/dist/resources/extensions/gsd/auto-model-selection.js +51 -5
  11. package/dist/resources/extensions/gsd/auto-post-unit.js +220 -17
  12. package/dist/resources/extensions/gsd/auto-prompts.js +12 -0
  13. package/dist/resources/extensions/gsd/auto-unit-closeout.js +18 -0
  14. package/dist/resources/extensions/gsd/auto-verification.js +100 -2
  15. package/dist/resources/extensions/gsd/auto.js +36 -4
  16. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +30 -8
  17. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +45 -4
  18. package/dist/resources/extensions/gsd/commands/catalog.js +26 -1
  19. package/dist/resources/extensions/gsd/commands/handlers/ops.js +25 -0
  20. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +68 -9
  21. package/dist/resources/extensions/gsd/commands-add-tests.js +111 -0
  22. package/dist/resources/extensions/gsd/commands-backlog.js +140 -0
  23. package/dist/resources/extensions/gsd/commands-do.js +79 -0
  24. package/dist/resources/extensions/gsd/commands-extract-learnings.js +225 -0
  25. package/dist/resources/extensions/gsd/commands-maintenance.js +6 -6
  26. package/dist/resources/extensions/gsd/commands-pr-branch.js +180 -0
  27. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +1 -1
  28. package/dist/resources/extensions/gsd/commands-session-report.js +82 -0
  29. package/dist/resources/extensions/gsd/commands-ship.js +187 -0
  30. package/dist/resources/extensions/gsd/db-writer.js +3 -5
  31. package/dist/resources/extensions/gsd/docs/preferences-reference.md +14 -1
  32. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +144 -0
  33. package/dist/resources/extensions/gsd/ecosystem/loader.js +145 -0
  34. package/dist/resources/extensions/gsd/git-service.js +49 -1
  35. package/dist/resources/extensions/gsd/graph-context.js +157 -0
  36. package/dist/resources/extensions/gsd/gsd-db.js +581 -2
  37. package/dist/resources/extensions/gsd/guided-flow.js +23 -0
  38. package/dist/resources/extensions/gsd/index.js +15 -2
  39. package/dist/resources/extensions/gsd/init-wizard.js +1 -0
  40. package/dist/resources/extensions/gsd/journal.js +27 -0
  41. package/dist/resources/extensions/gsd/md-importer.js +3 -4
  42. package/dist/resources/extensions/gsd/memory-store.js +19 -51
  43. package/dist/resources/extensions/gsd/metrics.js +19 -0
  44. package/dist/resources/extensions/gsd/milestone-validation-gates.js +13 -12
  45. package/dist/resources/extensions/gsd/native-git-bridge.js +7 -4
  46. package/dist/resources/extensions/gsd/parallel-orchestrator.js +33 -1
  47. package/dist/resources/extensions/gsd/preferences-models.js +20 -3
  48. package/dist/resources/extensions/gsd/preferences-types.js +1 -0
  49. package/dist/resources/extensions/gsd/preferences-validation.js +108 -2
  50. package/dist/resources/extensions/gsd/preferences.js +26 -0
  51. package/dist/resources/extensions/gsd/prompts/add-tests.md +35 -0
  52. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +12 -2
  53. package/dist/resources/extensions/gsd/state.js +5 -1
  54. package/dist/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
  55. package/dist/resources/extensions/gsd/tools/complete-slice.js +20 -0
  56. package/dist/resources/extensions/gsd/tools/validate-milestone.js +39 -4
  57. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +3 -14
  58. package/dist/resources/extensions/gsd/triage-resolution.js +2 -5
  59. package/dist/resources/extensions/gsd/unit-ownership.js +1 -1
  60. package/dist/resources/extensions/gsd/uok/audit-toggle.js +7 -0
  61. package/dist/resources/extensions/gsd/uok/audit.js +40 -0
  62. package/dist/resources/extensions/gsd/uok/contracts.js +1 -0
  63. package/dist/resources/extensions/gsd/uok/execution-graph.js +179 -0
  64. package/dist/resources/extensions/gsd/uok/flags.js +29 -0
  65. package/dist/resources/extensions/gsd/uok/gate-runner.js +109 -0
  66. package/dist/resources/extensions/gsd/uok/gitops.js +53 -0
  67. package/dist/resources/extensions/gsd/uok/kernel.js +80 -0
  68. package/dist/resources/extensions/gsd/uok/loop-adapter.js +133 -0
  69. package/dist/resources/extensions/gsd/uok/model-policy.js +66 -0
  70. package/dist/resources/extensions/gsd/uok/plan-v2.js +132 -0
  71. package/dist/resources/extensions/gsd/workflow-logger.js +22 -0
  72. package/dist/resources/extensions/gsd/workflow-manifest.js +8 -69
  73. package/dist/resources/extensions/gsd/workflow-migration.js +21 -22
  74. package/dist/resources/extensions/gsd/workflow-projections.js +4 -1
  75. package/dist/resources/extensions/gsd/workflow-reconcile.js +14 -11
  76. package/dist/resources/extensions/ttsr/ttsr-manager.js +3 -1
  77. package/dist/tsconfig.extensions.tsbuildinfo +1 -0
  78. package/dist/web/standalone/.next/BUILD_ID +1 -1
  79. package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
  80. package/dist/web/standalone/.next/build-manifest.json +2 -2
  81. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  82. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  83. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  84. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  85. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  86. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  87. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  88. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  89. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  90. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  91. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  92. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  93. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  94. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  95. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  96. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  97. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  98. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  99. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
  100. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +1 -1
  101. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
  102. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
  103. package/dist/web/standalone/.next/server/app/index.html +1 -1
  104. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  105. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  106. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  107. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  108. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  109. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  110. package/dist/web/standalone/.next/server/app-paths-manifest.json +12 -12
  111. package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
  112. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  113. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  114. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  115. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  116. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  117. package/package.json +3 -2
  118. package/packages/daemon/package.json +2 -2
  119. package/packages/mcp-server/dist/index.d.ts +3 -0
  120. package/packages/mcp-server/dist/index.d.ts.map +1 -1
  121. package/packages/mcp-server/dist/index.js +3 -0
  122. package/packages/mcp-server/dist/index.js.map +1 -1
  123. package/packages/mcp-server/dist/readers/graph.d.ts +87 -0
  124. package/packages/mcp-server/dist/readers/graph.d.ts.map +1 -0
  125. package/packages/mcp-server/dist/readers/graph.js +655 -0
  126. package/packages/mcp-server/dist/readers/graph.js.map +1 -0
  127. package/packages/mcp-server/dist/readers/index.d.ts +2 -0
  128. package/packages/mcp-server/dist/readers/index.d.ts.map +1 -1
  129. package/packages/mcp-server/dist/readers/index.js +1 -0
  130. package/packages/mcp-server/dist/readers/index.js.map +1 -1
  131. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  132. package/packages/mcp-server/dist/server.js +65 -0
  133. package/packages/mcp-server/dist/server.js.map +1 -1
  134. package/packages/mcp-server/package.json +2 -2
  135. package/packages/mcp-server/src/index.ts +15 -0
  136. package/packages/mcp-server/src/readers/graph.test.ts +604 -0
  137. package/packages/mcp-server/src/readers/graph.ts +855 -0
  138. package/packages/mcp-server/src/readers/index.ts +12 -0
  139. package/packages/mcp-server/src/server.ts +83 -0
  140. package/packages/mcp-server/tsconfig.json +1 -0
  141. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -0
  142. package/packages/native/package.json +2 -2
  143. package/packages/native/tsconfig.tsbuildinfo +1 -0
  144. package/packages/pi-agent-core/package.json +1 -1
  145. package/packages/pi-agent-core/tsconfig.json +1 -0
  146. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -0
  147. package/packages/pi-ai/dist/index.d.ts +1 -9
  148. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  149. package/packages/pi-ai/dist/index.js +1 -9
  150. package/packages/pi-ai/dist/index.js.map +1 -1
  151. package/packages/pi-ai/dist/models/capability-patches.d.ts +19 -0
  152. package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -0
  153. package/packages/pi-ai/dist/models/capability-patches.js +36 -0
  154. package/packages/pi-ai/dist/models/capability-patches.js.map +1 -0
  155. package/packages/pi-ai/dist/{models.custom.d.ts → models/custom.d.ts} +1 -1
  156. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -0
  157. package/packages/pi-ai/dist/{models.custom.js → models/custom.js} +4 -4
  158. package/packages/pi-ai/dist/models/custom.js.map +1 -0
  159. package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts +1482 -0
  160. package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts.map +1 -0
  161. package/packages/pi-ai/dist/models/generated/amazon-bedrock.js +1484 -0
  162. package/packages/pi-ai/dist/models/generated/amazon-bedrock.js.map +1 -0
  163. package/packages/pi-ai/dist/models/generated/anthropic.d.ts +377 -0
  164. package/packages/pi-ai/dist/models/generated/anthropic.d.ts.map +1 -0
  165. package/packages/pi-ai/dist/models/generated/anthropic.js +379 -0
  166. package/packages/pi-ai/dist/models/generated/anthropic.js.map +1 -0
  167. package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts +700 -0
  168. package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts.map +1 -0
  169. package/packages/pi-ai/dist/models/generated/azure-openai-responses.js +702 -0
  170. package/packages/pi-ai/dist/models/generated/azure-openai-responses.js.map +1 -0
  171. package/packages/pi-ai/dist/models/generated/cerebras.d.ts +71 -0
  172. package/packages/pi-ai/dist/models/generated/cerebras.d.ts.map +1 -0
  173. package/packages/pi-ai/dist/models/generated/cerebras.js +73 -0
  174. package/packages/pi-ai/dist/models/generated/cerebras.js.map +1 -0
  175. package/packages/pi-ai/dist/models/generated/github-copilot.d.ts +590 -0
  176. package/packages/pi-ai/dist/models/generated/github-copilot.d.ts.map +1 -0
  177. package/packages/pi-ai/dist/models/generated/github-copilot.js +444 -0
  178. package/packages/pi-ai/dist/models/generated/github-copilot.js.map +1 -0
  179. package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts +156 -0
  180. package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts.map +1 -0
  181. package/packages/pi-ai/dist/models/generated/google-antigravity.js +158 -0
  182. package/packages/pi-ai/dist/models/generated/google-antigravity.js.map +1 -0
  183. package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts +105 -0
  184. package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts.map +1 -0
  185. package/packages/pi-ai/dist/models/generated/google-gemini-cli.js +107 -0
  186. package/packages/pi-ai/dist/models/generated/google-gemini-cli.js.map +1 -0
  187. package/packages/pi-ai/dist/models/generated/google-vertex.d.ts +207 -0
  188. package/packages/pi-ai/dist/models/generated/google-vertex.d.ts.map +1 -0
  189. package/packages/pi-ai/dist/models/generated/google-vertex.js +209 -0
  190. package/packages/pi-ai/dist/models/generated/google-vertex.js.map +1 -0
  191. package/packages/pi-ai/dist/models/generated/google.d.ts +462 -0
  192. package/packages/pi-ai/dist/models/generated/google.d.ts.map +1 -0
  193. package/packages/pi-ai/dist/models/generated/google.js +464 -0
  194. package/packages/pi-ai/dist/models/generated/google.js.map +1 -0
  195. package/packages/pi-ai/dist/models/generated/groq.d.ts +309 -0
  196. package/packages/pi-ai/dist/models/generated/groq.d.ts.map +1 -0
  197. package/packages/pi-ai/dist/models/generated/groq.js +311 -0
  198. package/packages/pi-ai/dist/models/generated/groq.js.map +1 -0
  199. package/packages/pi-ai/dist/models/generated/huggingface.d.ts +383 -0
  200. package/packages/pi-ai/dist/models/generated/huggingface.d.ts.map +1 -0
  201. package/packages/pi-ai/dist/models/generated/huggingface.js +347 -0
  202. package/packages/pi-ai/dist/models/generated/huggingface.js.map +1 -0
  203. package/packages/pi-ai/dist/{models.generated.d.ts → models/generated/index.d.ts} +1 -1
  204. package/packages/pi-ai/dist/{models.generated.d.ts.map → models/generated/index.d.ts.map} +1 -1
  205. package/packages/pi-ai/dist/models/generated/index.js +51 -0
  206. package/packages/pi-ai/dist/models/generated/index.js.map +1 -0
  207. package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts +37 -0
  208. package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts.map +1 -0
  209. package/packages/pi-ai/dist/models/generated/kimi-coding.js +39 -0
  210. package/packages/pi-ai/dist/models/generated/kimi-coding.js.map +1 -0
  211. package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts +105 -0
  212. package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts.map +1 -0
  213. package/packages/pi-ai/dist/models/generated/minimax-cn.js +107 -0
  214. package/packages/pi-ai/dist/models/generated/minimax-cn.js.map +1 -0
  215. package/packages/pi-ai/dist/models/generated/minimax.d.ts +105 -0
  216. package/packages/pi-ai/dist/models/generated/minimax.d.ts.map +1 -0
  217. package/packages/pi-ai/dist/models/generated/minimax.js +107 -0
  218. package/packages/pi-ai/dist/models/generated/minimax.js.map +1 -0
  219. package/packages/pi-ai/dist/models/generated/mistral.d.ts +445 -0
  220. package/packages/pi-ai/dist/models/generated/mistral.d.ts.map +1 -0
  221. package/packages/pi-ai/dist/models/generated/mistral.js +447 -0
  222. package/packages/pi-ai/dist/models/generated/mistral.js.map +1 -0
  223. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +139 -0
  224. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -0
  225. package/packages/pi-ai/dist/models/generated/openai-codex.js +141 -0
  226. package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -0
  227. package/packages/pi-ai/dist/models/generated/openai.d.ts +700 -0
  228. package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -0
  229. package/packages/pi-ai/dist/models/generated/openai.js +702 -0
  230. package/packages/pi-ai/dist/models/generated/openai.js.map +1 -0
  231. package/packages/pi-ai/dist/models/generated/opencode-go.d.ts +122 -0
  232. package/packages/pi-ai/dist/models/generated/opencode-go.d.ts.map +1 -0
  233. package/packages/pi-ai/dist/models/generated/opencode-go.js +124 -0
  234. package/packages/pi-ai/dist/models/generated/opencode-go.js.map +1 -0
  235. package/packages/pi-ai/dist/models/generated/opencode.d.ts +530 -0
  236. package/packages/pi-ai/dist/models/generated/opencode.d.ts.map +1 -0
  237. package/packages/pi-ai/dist/models/generated/opencode.js +532 -0
  238. package/packages/pi-ai/dist/models/generated/opencode.js.map +1 -0
  239. package/packages/pi-ai/dist/models/generated/openrouter.d.ts +4270 -0
  240. package/packages/pi-ai/dist/models/generated/openrouter.d.ts.map +1 -0
  241. package/packages/pi-ai/dist/models/generated/openrouter.js +4272 -0
  242. package/packages/pi-ai/dist/models/generated/openrouter.js.map +1 -0
  243. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts +2604 -0
  244. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts.map +1 -0
  245. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js +2606 -0
  246. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js.map +1 -0
  247. package/packages/pi-ai/dist/models/generated/xai.d.ts +411 -0
  248. package/packages/pi-ai/dist/models/generated/xai.d.ts.map +1 -0
  249. package/packages/pi-ai/dist/models/generated/xai.js +413 -0
  250. package/packages/pi-ai/dist/models/generated/xai.js.map +1 -0
  251. package/packages/pi-ai/dist/models/generated/zai.d.ts +276 -0
  252. package/packages/pi-ai/dist/models/generated/zai.d.ts.map +1 -0
  253. package/packages/pi-ai/dist/models/generated/zai.js +239 -0
  254. package/packages/pi-ai/dist/models/generated/zai.js.map +1 -0
  255. package/packages/pi-ai/dist/models/index.d.ts +27 -0
  256. package/packages/pi-ai/dist/models/index.d.ts.map +1 -0
  257. package/packages/pi-ai/dist/models/index.js +80 -0
  258. package/packages/pi-ai/dist/models/index.js.map +1 -0
  259. package/packages/pi-ai/dist/models.d.ts +1 -36
  260. package/packages/pi-ai/dist/models.d.ts.map +1 -1
  261. package/packages/pi-ai/dist/models.generated.test.js +1 -2
  262. package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
  263. package/packages/pi-ai/dist/models.js +3 -112
  264. package/packages/pi-ai/dist/models.js.map +1 -1
  265. package/packages/pi-ai/dist/models.test.js +6 -5
  266. package/packages/pi-ai/dist/models.test.js.map +1 -1
  267. package/packages/pi-ai/package.json +1 -1
  268. package/packages/pi-ai/scripts/generate-models.ts +74 -40
  269. package/packages/pi-ai/src/index.ts +1 -9
  270. package/packages/pi-ai/src/models/capability-patches.ts +40 -0
  271. package/packages/pi-ai/src/{models.custom.ts → models/custom.ts} +4 -4
  272. package/packages/pi-ai/src/models/generated/amazon-bedrock.ts +1486 -0
  273. package/packages/pi-ai/src/models/generated/anthropic.ts +381 -0
  274. package/packages/pi-ai/src/models/generated/azure-openai-responses.ts +704 -0
  275. package/packages/pi-ai/src/models/generated/cerebras.ts +75 -0
  276. package/packages/pi-ai/src/models/generated/github-copilot.ts +446 -0
  277. package/packages/pi-ai/src/models/generated/google-antigravity.ts +160 -0
  278. package/packages/pi-ai/src/models/generated/google-gemini-cli.ts +109 -0
  279. package/packages/pi-ai/src/models/generated/google-vertex.ts +211 -0
  280. package/packages/pi-ai/src/models/generated/google.ts +466 -0
  281. package/packages/pi-ai/src/models/generated/groq.ts +313 -0
  282. package/packages/pi-ai/src/models/generated/huggingface.ts +349 -0
  283. package/packages/pi-ai/src/models/generated/index.ts +52 -0
  284. package/packages/pi-ai/src/models/generated/kimi-coding.ts +41 -0
  285. package/packages/pi-ai/src/models/generated/minimax-cn.ts +109 -0
  286. package/packages/pi-ai/src/models/generated/minimax.ts +109 -0
  287. package/packages/pi-ai/src/models/generated/mistral.ts +449 -0
  288. package/packages/pi-ai/src/models/generated/openai-codex.ts +143 -0
  289. package/packages/pi-ai/src/models/generated/openai.ts +704 -0
  290. package/packages/pi-ai/src/models/generated/opencode-go.ts +126 -0
  291. package/packages/pi-ai/src/models/generated/opencode.ts +534 -0
  292. package/packages/pi-ai/src/models/generated/openrouter.ts +4274 -0
  293. package/packages/pi-ai/src/models/generated/vercel-ai-gateway.ts +2608 -0
  294. package/packages/pi-ai/src/models/generated/xai.ts +415 -0
  295. package/packages/pi-ai/src/models/generated/zai.ts +241 -0
  296. package/packages/pi-ai/src/models/index.ts +106 -0
  297. package/packages/pi-ai/src/models.generated.test.ts +1 -2
  298. package/packages/pi-ai/src/models.test.ts +6 -5
  299. package/packages/pi-ai/src/models.ts +3 -153
  300. package/packages/pi-ai/tsconfig.json +1 -0
  301. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -0
  302. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  303. package/packages/pi-coding-agent/dist/core/agent-session.js +8 -2
  304. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  305. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +472 -0
  306. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
  307. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts +2 -0
  308. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts.map +1 -0
  309. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js +52 -0
  310. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js.map +1 -0
  311. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  312. package/packages/pi-coding-agent/dist/core/model-registry.js +2 -2
  313. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  314. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +11 -0
  315. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  316. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +1 -0
  317. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  318. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +23 -9
  319. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
  320. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +11 -0
  321. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -0
  322. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +47 -0
  323. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -0
  324. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  325. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +51 -8
  326. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  327. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
  328. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +22 -22
  329. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
  330. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  331. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +232 -18
  332. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  333. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts +2 -0
  334. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts.map +1 -0
  335. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js +38 -0
  336. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js.map +1 -0
  337. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +13 -0
  338. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  339. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +53 -6
  340. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  341. package/packages/pi-coding-agent/src/core/agent-session.ts +12 -6
  342. package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +612 -0
  343. package/packages/pi-coding-agent/src/core/model-registry-env-fallback.test.ts +59 -0
  344. package/packages/pi-coding-agent/src/core/model-registry.ts +2 -1
  345. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +19 -0
  346. package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +25 -10
  347. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +67 -0
  348. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +66 -7
  349. package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +23 -26
  350. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +298 -41
  351. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-ordering.test.ts +44 -0
  352. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +73 -6
  353. package/packages/pi-coding-agent/src/types/ambient-modules.d.ts +69 -0
  354. package/packages/pi-coding-agent/tsconfig.json +3 -2
  355. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -0
  356. package/packages/pi-tui/package.json +1 -1
  357. package/packages/pi-tui/tsconfig.json +1 -0
  358. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -0
  359. package/packages/rpc-client/package.json +1 -1
  360. package/packages/rpc-client/tsconfig.json +1 -0
  361. package/packages/rpc-client/tsconfig.tsbuildinfo +1 -0
  362. package/src/resources/extensions/gsd/activity-log.ts +21 -0
  363. package/src/resources/extensions/gsd/auto/detect-stuck.ts +12 -4
  364. package/src/resources/extensions/gsd/auto/loop-deps.ts +10 -0
  365. package/src/resources/extensions/gsd/auto/loop.ts +159 -10
  366. package/src/resources/extensions/gsd/auto/phases.ts +191 -4
  367. package/src/resources/extensions/gsd/auto/session.ts +10 -0
  368. package/src/resources/extensions/gsd/auto-dispatch.ts +16 -6
  369. package/src/resources/extensions/gsd/auto-model-selection.ts +66 -5
  370. package/src/resources/extensions/gsd/auto-post-unit.ts +238 -18
  371. package/src/resources/extensions/gsd/auto-prompts.ts +13 -0
  372. package/src/resources/extensions/gsd/auto-unit-closeout.ts +25 -1
  373. package/src/resources/extensions/gsd/auto-verification.ts +129 -2
  374. package/src/resources/extensions/gsd/auto.ts +41 -2
  375. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +38 -8
  376. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +56 -3
  377. package/src/resources/extensions/gsd/commands/catalog.ts +26 -1
  378. package/src/resources/extensions/gsd/commands/handlers/ops.ts +25 -0
  379. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +74 -9
  380. package/src/resources/extensions/gsd/commands-add-tests.ts +137 -0
  381. package/src/resources/extensions/gsd/commands-backlog.ts +182 -0
  382. package/src/resources/extensions/gsd/commands-do.ts +109 -0
  383. package/src/resources/extensions/gsd/commands-extract-learnings.ts +304 -0
  384. package/src/resources/extensions/gsd/commands-maintenance.ts +6 -6
  385. package/src/resources/extensions/gsd/commands-pr-branch.ts +234 -0
  386. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +1 -1
  387. package/src/resources/extensions/gsd/commands-session-report.ts +101 -0
  388. package/src/resources/extensions/gsd/commands-ship.ts +219 -0
  389. package/src/resources/extensions/gsd/db-writer.ts +3 -5
  390. package/src/resources/extensions/gsd/docs/preferences-reference.md +14 -1
  391. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +228 -0
  392. package/src/resources/extensions/gsd/ecosystem/loader.ts +201 -0
  393. package/src/resources/extensions/gsd/git-service.ts +68 -0
  394. package/src/resources/extensions/gsd/graph-context.ts +212 -0
  395. package/src/resources/extensions/gsd/gsd-db.ts +788 -3
  396. package/src/resources/extensions/gsd/guided-flow.ts +32 -0
  397. package/src/resources/extensions/gsd/index.ts +18 -2
  398. package/src/resources/extensions/gsd/init-wizard.ts +3 -2
  399. package/src/resources/extensions/gsd/journal.ts +30 -0
  400. package/src/resources/extensions/gsd/md-importer.ts +3 -5
  401. package/src/resources/extensions/gsd/memory-store.ts +31 -62
  402. package/src/resources/extensions/gsd/metrics.ts +26 -0
  403. package/src/resources/extensions/gsd/milestone-validation-gates.ts +13 -14
  404. package/src/resources/extensions/gsd/native-git-bridge.ts +11 -12
  405. package/src/resources/extensions/gsd/parallel-orchestrator.ts +40 -1
  406. package/src/resources/extensions/gsd/preferences-models.ts +20 -3
  407. package/src/resources/extensions/gsd/preferences-types.ts +32 -0
  408. package/src/resources/extensions/gsd/preferences-validation.ts +107 -2
  409. package/src/resources/extensions/gsd/preferences.ts +28 -0
  410. package/src/resources/extensions/gsd/prompts/add-tests.md +35 -0
  411. package/src/resources/extensions/gsd/session-lock.ts +14 -2
  412. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +20 -1
  413. package/src/resources/extensions/gsd/state.ts +9 -2
  414. package/src/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
  415. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +7 -3
  416. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +20 -0
  417. package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +7 -3
  418. package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +6 -2
  419. package/src/resources/extensions/gsd/tests/commands-backlog.test.ts +158 -0
  420. package/src/resources/extensions/gsd/tests/commands-do.test.ts +127 -0
  421. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +340 -0
  422. package/src/resources/extensions/gsd/tests/commands-pr-branch.test.ts +68 -0
  423. package/src/resources/extensions/gsd/tests/commands-session-report.test.ts +82 -0
  424. package/src/resources/extensions/gsd/tests/commands-ship.test.ts +71 -0
  425. package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +14 -0
  426. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  427. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  428. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +154 -0
  429. package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +10 -7
  430. package/src/resources/extensions/gsd/tests/graph-context.test.ts +337 -0
  431. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +1 -1
  432. package/src/resources/extensions/gsd/tests/health-widget.test.ts +1 -1
  433. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +68 -1
  434. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -2
  435. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -3
  436. package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +140 -0
  437. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +79 -1
  438. package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +2 -1
  439. package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +40 -1
  440. package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +1 -1
  441. package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +180 -0
  442. package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -5
  443. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +101 -0
  444. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +85 -0
  445. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +69 -0
  446. package/src/resources/extensions/gsd/tests/uok-flags.test.ts +39 -0
  447. package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +70 -0
  448. package/src/resources/extensions/gsd/tests/uok-gitops-turn-action.test.ts +85 -0
  449. package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +35 -0
  450. package/src/resources/extensions/gsd/tests/uok-model-policy.test.ts +89 -0
  451. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +167 -0
  452. package/src/resources/extensions/gsd/tests/uok-preferences.test.ts +42 -0
  453. package/src/resources/extensions/gsd/tests/validate-milestone-write-order.test.ts +39 -0
  454. package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +223 -0
  455. package/src/resources/extensions/gsd/tools/complete-slice.ts +26 -0
  456. package/src/resources/extensions/gsd/tools/validate-milestone.ts +48 -3
  457. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +3 -11
  458. package/src/resources/extensions/gsd/triage-resolution.ts +2 -7
  459. package/src/resources/extensions/gsd/types.ts +14 -1
  460. package/src/resources/extensions/gsd/unit-ownership.ts +2 -2
  461. package/src/resources/extensions/gsd/uok/audit-toggle.ts +9 -0
  462. package/src/resources/extensions/gsd/uok/audit.ts +51 -0
  463. package/src/resources/extensions/gsd/uok/contracts.ts +135 -0
  464. package/src/resources/extensions/gsd/uok/execution-graph.ts +241 -0
  465. package/src/resources/extensions/gsd/uok/flags.ts +45 -0
  466. package/src/resources/extensions/gsd/uok/gate-runner.ts +146 -0
  467. package/src/resources/extensions/gsd/uok/gitops.ts +75 -0
  468. package/src/resources/extensions/gsd/uok/kernel.ts +105 -0
  469. package/src/resources/extensions/gsd/uok/loop-adapter.ts +162 -0
  470. package/src/resources/extensions/gsd/uok/model-policy.ts +112 -0
  471. package/src/resources/extensions/gsd/uok/plan-v2.ts +156 -0
  472. package/src/resources/extensions/gsd/workflow-logger.ts +27 -1
  473. package/src/resources/extensions/gsd/workflow-manifest.ts +9 -104
  474. package/src/resources/extensions/gsd/workflow-migration.ts +21 -29
  475. package/src/resources/extensions/gsd/workflow-projections.ts +8 -1
  476. package/src/resources/extensions/gsd/workflow-reconcile.ts +15 -15
  477. package/src/resources/extensions/ttsr/ttsr-manager.ts +10 -5
  478. package/packages/pi-ai/dist/models.custom.d.ts.map +0 -1
  479. package/packages/pi-ai/dist/models.custom.js.map +0 -1
  480. package/packages/pi-ai/dist/models.generated.js +0 -14343
  481. package/packages/pi-ai/dist/models.generated.js.map +0 -1
  482. package/packages/pi-ai/src/models.generated.ts +0 -14345
  483. /package/dist/web/standalone/.next/static/{YzIEI9sxJy4t5xgClF08g → 3U-oZ5FT59BM7sm2GInic}/_buildManifest.js +0 -0
  484. /package/dist/web/standalone/.next/static/{YzIEI9sxJy4t5xgClF08g → 3U-oZ5FT59BM7sm2GInic}/_ssgManifest.js +0 -0
@@ -33,6 +33,8 @@ import { runPostExecutionChecks, type PostExecutionResult } from "./post-executi
33
33
  import type { AutoSession } from "./auto/session.js";
34
34
  import type { VerificationResult as VerificationGateResult } from "./types.js";
35
35
  import { join } from "node:path";
36
+ import { resolveUokFlags } from "./uok/flags.js";
37
+ import { UokGateRunner } from "./uok/gate-runner.js";
36
38
 
37
39
  export interface VerificationContext {
38
40
  s: AutoSession;
@@ -67,6 +69,37 @@ async function runValidateMilestonePostCheck(
67
69
  pauseAuto: (ctx?: ExtensionContext, pi?: ExtensionAPI) => Promise<void>,
68
70
  ): Promise<VerificationResult> {
69
71
  const { s, ctx, pi } = vctx;
72
+ const prefs = loadEffectiveGSDPreferences()?.preferences;
73
+ const uokFlags = resolveUokFlags(prefs);
74
+ const persistMilestoneValidationGate = async (
75
+ outcome: "pass" | "fail" | "retry" | "manual-attention",
76
+ failureClass: "none" | "verification" | "manual-attention",
77
+ rationale: string,
78
+ findings = "",
79
+ milestoneId?: string,
80
+ ): Promise<void> => {
81
+ if (!uokFlags.gates || !s.currentUnit) return;
82
+ const gateRunner = new UokGateRunner();
83
+ gateRunner.register({
84
+ id: "milestone-validation-post-check",
85
+ type: "verification",
86
+ execute: async () => ({
87
+ outcome,
88
+ failureClass,
89
+ rationale,
90
+ findings,
91
+ }),
92
+ });
93
+ await gateRunner.run("milestone-validation-post-check", {
94
+ basePath: s.basePath,
95
+ traceId: `validation-post-check:${s.currentUnit.id}`,
96
+ turnId: s.currentUnit.id,
97
+ milestoneId,
98
+ unitType: s.currentUnit.type,
99
+ unitId: s.currentUnit.id,
100
+ });
101
+ };
102
+
70
103
  if (!s.currentUnit) return "continue";
71
104
 
72
105
  const { milestone: mid } = parseUnitId(s.currentUnit.id);
@@ -79,14 +112,32 @@ async function runValidateMilestonePostCheck(
79
112
  if (!validationContent) return "continue";
80
113
 
81
114
  const verdict = extractVerdict(validationContent);
82
- if (verdict !== "needs-remediation") return "continue";
115
+ if (verdict !== "needs-remediation") {
116
+ await persistMilestoneValidationGate(
117
+ "pass",
118
+ "none",
119
+ `milestone validation verdict is ${verdict}; no remediation loop risk`,
120
+ "",
121
+ mid,
122
+ );
123
+ return "continue";
124
+ }
83
125
 
84
126
  const incompleteSliceCount = await countIncompleteSlices(s.basePath, mid);
85
127
 
86
128
  // If any non-closed slices exist, the agent successfully queued remediation
87
129
  // work — proceed normally. The state machine will execute those slices and
88
130
  // re-validate per the #3596/#3670 fix.
89
- if (incompleteSliceCount > 0) return "continue";
131
+ if (incompleteSliceCount > 0) {
132
+ await persistMilestoneValidationGate(
133
+ "pass",
134
+ "none",
135
+ `remediation slices present (${incompleteSliceCount}); validation can continue`,
136
+ "",
137
+ mid,
138
+ );
139
+ return "continue";
140
+ }
90
141
 
91
142
  ctx.ui.notify(
92
143
  `Milestone ${mid} validation returned verdict=needs-remediation but no remediation slices were added. Pausing for human review.`,
@@ -96,6 +147,13 @@ async function runValidateMilestonePostCheck(
96
147
  `validate-milestone: pausing — verdict=needs-remediation with no incomplete slices for ${mid}. ` +
97
148
  `The agent must call gsd_reassess_roadmap to add remediation slices before re-validation.\n`,
98
149
  );
150
+ await persistMilestoneValidationGate(
151
+ "manual-attention",
152
+ "manual-attention",
153
+ "needs-remediation verdict without queued remediation slices",
154
+ `No incomplete slices found for ${mid} while verdict=needs-remediation`,
155
+ mid,
156
+ );
99
157
  await pauseAuto(ctx, pi);
100
158
  return "pause";
101
159
  }
@@ -158,6 +216,7 @@ export async function runPostUnitVerification(
158
216
  try {
159
217
  const effectivePrefs = loadEffectiveGSDPreferences();
160
218
  const prefs = effectivePrefs?.preferences;
219
+ const uokFlags = resolveUokFlags(prefs);
161
220
 
162
221
  // Read task plan verify field
163
222
  const { milestone: mid, slice: sid, task: tid } = parseUnitId(s.currentUnit.id);
@@ -196,6 +255,37 @@ export async function runPostUnitVerification(
196
255
  }
197
256
  }
198
257
 
258
+ if (uokFlags.gates) {
259
+ const gateRunner = new UokGateRunner();
260
+ gateRunner.register({
261
+ id: "verification-gate",
262
+ type: "verification",
263
+ execute: async () => ({
264
+ outcome: result.passed ? "pass" : "fail",
265
+ failureClass: result.runtimeErrors?.some((e) => e.blocking)
266
+ ? "execution"
267
+ : "verification",
268
+ rationale: result.passed
269
+ ? "verification checks passed"
270
+ : "verification checks failed",
271
+ findings: result.passed
272
+ ? ""
273
+ : formatFailureContext(result),
274
+ }),
275
+ });
276
+
277
+ await gateRunner.run("verification-gate", {
278
+ basePath: s.basePath,
279
+ traceId: `verification:${s.currentUnit.id}`,
280
+ turnId: s.currentUnit.id,
281
+ milestoneId: mid ?? undefined,
282
+ sliceId: sid ?? undefined,
283
+ taskId: tid ?? undefined,
284
+ unitType: s.currentUnit.type,
285
+ unitId: s.currentUnit.id,
286
+ });
287
+ }
288
+
199
289
  // Auto-fix retry preferences
200
290
  const autoFixEnabled = prefs?.verification_auto_fix !== false;
201
291
  const maxRetries =
@@ -338,6 +428,43 @@ export async function runPostUnitVerification(
338
428
  );
339
429
  }
340
430
 
431
+ if (uokFlags.gates) {
432
+ const strictMode = prefs?.enhanced_verification_strict === true;
433
+ const warnEscalated = postExecResult.status === "warn" && strictMode;
434
+ const blockingFailure = postExecResult.status === "fail" || warnEscalated;
435
+ const findings = postExecResult.checks
436
+ .filter((check) => !check.passed)
437
+ .map((check) => `[${check.category}] ${check.target}: ${check.message}`)
438
+ .join("\n");
439
+ const gateRunner = new UokGateRunner();
440
+ gateRunner.register({
441
+ id: "post-execution-checks",
442
+ type: "artifact",
443
+ execute: async () => ({
444
+ outcome: blockingFailure ? "fail" : "pass",
445
+ failureClass: postExecResult.status === "fail"
446
+ ? "artifact"
447
+ : warnEscalated
448
+ ? "policy"
449
+ : "none",
450
+ rationale: blockingFailure
451
+ ? `post-execution checks ${postExecResult.status}${warnEscalated ? " (strict)" : ""}`
452
+ : "post-execution checks passed",
453
+ findings,
454
+ }),
455
+ });
456
+ await gateRunner.run("post-execution-checks", {
457
+ basePath: s.basePath,
458
+ traceId: `verification:${s.currentUnit.id}`,
459
+ turnId: s.currentUnit.id,
460
+ milestoneId: mid,
461
+ sliceId: sid,
462
+ taskId: tid,
463
+ unitType: s.currentUnit.type,
464
+ unitId: s.currentUnit.id,
465
+ });
466
+ }
467
+
341
468
  // Check for blocking failures
342
469
  if (postExecResult.status === "fail") {
343
470
  postExecBlockingFailure = true;
@@ -195,12 +195,15 @@ import { clearCmuxSidebar, logCmuxEvent, syncCmuxSidebar } from "../cmux/index.j
195
195
  import { startUnitSupervision } from "./auto-timers.js";
196
196
  import { runPostUnitVerification } from "./auto-verification.js";
197
197
  import {
198
+ autoCommitUnit,
198
199
  postUnitPreVerification,
199
200
  postUnitPostVerification,
200
201
  } from "./auto-post-unit.js";
201
202
  import { bootstrapAutoSession, openProjectDbIfPresent, type BootstrapDeps } from "./auto-start.js";
202
203
  import { initHealthWidget } from "./health-widget.js";
203
204
  import { autoLoop, resolveAgentEnd, resolveAgentEndCancelled, _resetPendingResolve, isSessionSwitchInFlight, type LoopDeps, type ErrorContext } from "./auto-loop.js";
205
+ import { runAutoLoopWithUok } from "./uok/kernel.js";
206
+ import { resolveUokFlags } from "./uok/flags.js";
204
207
  // Slice-level parallelism (#2340)
205
208
  import { getEligibleSlices } from "./slice-parallel-eligibility.js";
206
209
  import { startSliceParallel } from "./slice-parallel-orchestrator.js";
@@ -604,11 +607,29 @@ function buildSnapshotOpts(
604
607
  continueHereFired?: boolean;
605
608
  promptCharCount?: number;
606
609
  baselineCharCount?: number;
610
+ traceId?: string;
611
+ turnId?: string;
612
+ gitAction?: "commit" | "snapshot" | "status-only";
613
+ gitPush?: boolean;
614
+ gitStatus?: "ok" | "failed";
615
+ gitError?: string;
607
616
  } & Record<string, unknown> {
617
+ const prefs = loadEffectiveGSDPreferences()?.preferences;
618
+ const uokFlags = resolveUokFlags(prefs);
608
619
  return {
609
620
  ...(s.autoStartTime > 0 ? { autoSessionKey: String(s.autoStartTime) } : {}),
610
621
  promptCharCount: s.lastPromptCharCount,
611
622
  baselineCharCount: s.lastBaselineCharCount,
623
+ traceId: s.currentTraceId ?? undefined,
624
+ turnId: s.currentTurnId ?? undefined,
625
+ ...(uokFlags.gitops
626
+ ? {
627
+ gitAction: uokFlags.gitopsTurnAction,
628
+ gitPush: uokFlags.gitopsTurnPush,
629
+ gitStatus: s.lastGitActionStatus ?? undefined,
630
+ gitError: s.lastGitActionFailure ?? undefined,
631
+ }
632
+ : {}),
612
633
  ...(s.currentUnitRouting ?? {}),
613
634
  };
614
635
  }
@@ -1180,6 +1201,7 @@ function buildLoopDeps(): LoopDeps {
1180
1201
  getMainBranch,
1181
1202
  // Unit closeout + runtime records
1182
1203
  closeoutUnit,
1204
+ autoCommitUnit,
1183
1205
  recordOutcome,
1184
1206
  writeLock,
1185
1207
  captureAvailableSkills,
@@ -1400,6 +1422,11 @@ export async function startAuto(
1400
1422
  s.stepMode = requestedStepMode;
1401
1423
  s.cmdCtx = ctx;
1402
1424
  s.basePath = base;
1425
+ // Ensure the workflow-logger audit log is pinned to the project root
1426
+ // even when auto-mode is entered via a path that bypasses the
1427
+ // bootstrap/dynamic-tools ensureDbOpen() → setLogBasePath() chain
1428
+ // (e.g. /clear resume, hot-reload).
1429
+ setLogBasePath(base);
1403
1430
  s.unitDispatchCount.clear();
1404
1431
  s.unitLifetimeDispatches.clear();
1405
1432
  if (!getLedger()) initMetrics(base);
@@ -1506,7 +1533,13 @@ export async function startAuto(
1506
1533
  logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, s.stepMode ? "Step-mode resumed." : "Auto-mode resumed.", "progress");
1507
1534
 
1508
1535
  captureProjectRootEnv(s.originalBasePath || s.basePath);
1509
- await autoLoop(ctx, pi, s, buildLoopDeps());
1536
+ await runAutoLoopWithUok({
1537
+ ctx,
1538
+ pi,
1539
+ s,
1540
+ deps: buildLoopDeps(),
1541
+ runLegacyLoop: autoLoop,
1542
+ });
1510
1543
  cleanupAfterLoopExit(ctx);
1511
1544
  return;
1512
1545
  }
@@ -1541,7 +1574,13 @@ export async function startAuto(
1541
1574
  logCmuxEvent(loadEffectiveGSDPreferences()?.preferences, requestedStepMode ? "Step-mode started." : "Auto-mode started.", "progress");
1542
1575
 
1543
1576
  // Dispatch the first unit
1544
- await autoLoop(ctx, pi, s, buildLoopDeps());
1577
+ await runAutoLoopWithUok({
1578
+ ctx,
1579
+ pi,
1580
+ s,
1581
+ deps: buildLoopDeps(),
1582
+ runLegacyLoop: autoLoop,
1583
+ });
1545
1584
  cleanupAfterLoopExit(ctx);
1546
1585
  }
1547
1586
 
@@ -2,9 +2,10 @@
2
2
 
3
3
  import type { ExtensionAPI, ExtensionCommandContext } from "@gsd/pi-coding-agent";
4
4
 
5
- import { registerGSDCommand } from "../commands.js";
6
5
  import { registerExitCommand } from "../exit-command.js";
7
6
  import { registerWorktreeCommand } from "../worktree-command.js";
7
+ import type { GSDEcosystemBeforeAgentStartHandler } from "../ecosystem/gsd-extension-api.js";
8
+ import { loadEcosystemExtensions } from "../ecosystem/loader.js";
8
9
  import { registerDbTools } from "./db-tools.js";
9
10
  import { registerDynamicTools } from "./dynamic-tools.js";
10
11
  import { registerJournalTools } from "./journal-tools.js";
@@ -12,6 +13,7 @@ import { registerQueryTools } from "./query-tools.js";
12
13
  import { registerHooks } from "./register-hooks.js";
13
14
  import { registerShortcuts } from "./register-shortcuts.js";
14
15
  import { writeCrashLog } from "./crash-log.js";
16
+ import { logWarning } from "../workflow-logger.js";
15
17
 
16
18
  export { writeCrashLog } from "./crash-log.js";
17
19
 
@@ -58,12 +60,17 @@ function installEpipeGuard(): void {
58
60
  }
59
61
 
60
62
  export function registerGsdExtension(pi: ExtensionAPI): void {
61
- registerGSDCommand(pi);
63
+ // Note: registerGSDCommand is called by index.ts before this function,
64
+ // so we intentionally skip it here to avoid double-registration.
62
65
  registerWorktreeCommand(pi);
63
66
  registerExitCommand(pi);
64
67
 
65
68
  installEpipeGuard();
66
69
 
70
+ // Ecosystem handlers captured by the GSDExtensionAPI wrapper for the
71
+ // GSD-owned `before_agent_start` dispatch step (#3338).
72
+ const ecosystemHandlers: GSDEcosystemBeforeAgentStartHandler[] = [];
73
+
67
74
  pi.registerCommand("kill", {
68
75
  description: "Exit GSD immediately (no cleanup)",
69
76
  handler: async (_args: string, _ctx: ExtensionCommandContext) => {
@@ -71,10 +78,33 @@ export function registerGsdExtension(pi: ExtensionAPI): void {
71
78
  },
72
79
  });
73
80
 
74
- registerDynamicTools(pi);
75
- registerDbTools(pi);
76
- registerJournalTools(pi);
77
- registerQueryTools(pi);
78
- registerShortcuts(pi);
79
- registerHooks(pi);
81
+ // Wrap non-critical registrations individually so one failure
82
+ // doesn't prevent the others from loading.
83
+ const nonCriticalRegistrations: Array<[string, () => void]> = [
84
+ ["dynamic-tools", () => registerDynamicTools(pi)],
85
+ ["db-tools", () => registerDbTools(pi)],
86
+ ["journal-tools", () => registerJournalTools(pi)],
87
+ ["query-tools", () => registerQueryTools(pi)],
88
+ ["shortcuts", () => registerShortcuts(pi)],
89
+ ["hooks", () => registerHooks(pi, ecosystemHandlers)],
90
+ ["ecosystem", () => {
91
+ void loadEcosystemExtensions(pi, ecosystemHandlers).catch((err) => {
92
+ logWarning(
93
+ "ecosystem",
94
+ `loader failed: ${err instanceof Error ? err.message : String(err)}`,
95
+ );
96
+ });
97
+ }],
98
+ ];
99
+
100
+ for (const [name, register] of nonCriticalRegistrations) {
101
+ try {
102
+ register();
103
+ } catch (err) {
104
+ logWarning(
105
+ "bootstrap",
106
+ `Failed to register ${name}: ${err instanceof Error ? err.message : String(err)}`,
107
+ );
108
+ }
109
+ }
80
110
  }
@@ -3,6 +3,10 @@ import { join } from "node:path";
3
3
  import type { ExtensionAPI, ExtensionContext } from "@gsd/pi-coding-agent";
4
4
  import { isToolCallEventType } from "@gsd/pi-coding-agent";
5
5
 
6
+ import type { GSDEcosystemBeforeAgentStartHandler } from "../ecosystem/gsd-extension-api.js";
7
+ import { updateSnapshot } from "../ecosystem/gsd-extension-api.js";
8
+ import { getEcosystemReadyPromise } from "../ecosystem/loader.js";
9
+
6
10
  import { buildMilestoneFileName, resolveMilestonePath, resolveSliceFile, resolveSlicePath } from "../paths.js";
7
11
  import { buildBeforeAgentStartResult } from "./system-context.js";
8
12
  import { handleAgentEnd } from "./agent-end-recovery.js";
@@ -35,7 +39,10 @@ async function syncServiceTierStatus(ctx: ExtensionContext): Promise<void> {
35
39
  ctx.ui.setStatus("gsd-fast", formatServiceTierFooterStatus(getEffectiveServiceTier(), ctx.model?.id));
36
40
  }
37
41
 
38
- export function registerHooks(pi: ExtensionAPI): void {
42
+ export function registerHooks(
43
+ pi: ExtensionAPI,
44
+ ecosystemHandlers: GSDEcosystemBeforeAgentStartHandler[],
45
+ ): void {
39
46
  pi.on("session_start", async (_event, ctx) => {
40
47
  initNotificationStore(process.cwd());
41
48
  installNotifyInterceptor(ctx);
@@ -93,7 +100,50 @@ export function registerHooks(pi: ExtensionAPI): void {
93
100
  });
94
101
 
95
102
  pi.on("before_agent_start", async (event, ctx: ExtensionContext) => {
96
- return buildBeforeAgentStartResult(event, ctx);
103
+ // Wait for ecosystem loader to finish (no-op after first turn).
104
+ await getEcosystemReadyPromise();
105
+
106
+ // GSD's own context injection (existing behavior — unchanged).
107
+ const gsdResult = await buildBeforeAgentStartResult(event, ctx);
108
+
109
+ // Refresh the snapshot used by ecosystem getPhase()/getActiveUnit().
110
+ // deriveState has its own ~100ms cache so this is cheap on repeat calls.
111
+ try {
112
+ const state = await deriveState(process.cwd());
113
+ updateSnapshot(state);
114
+ } catch {
115
+ updateSnapshot(null);
116
+ }
117
+
118
+ // Chain ecosystem handlers using pi's runner.ts chaining protocol:
119
+ // each handler sees the systemPrompt mutated by prior handlers.
120
+ let currentSystemPrompt = gsdResult?.systemPrompt ?? event.systemPrompt;
121
+ // `any` because pi's BeforeAgentStartEventResult.message uses an internal
122
+ // CustomMessage type that's not re-exported (see ecosystem/gsd-extension-api.ts).
123
+ let lastMessage: any = gsdResult?.message;
124
+
125
+ for (const handler of ecosystemHandlers) {
126
+ try {
127
+ const r = await handler(
128
+ { ...event, systemPrompt: currentSystemPrompt },
129
+ ctx,
130
+ );
131
+ if (r?.systemPrompt !== undefined) currentSystemPrompt = r.systemPrompt;
132
+ if (r?.message) lastMessage = r.message;
133
+ } catch (err) {
134
+ safetyLogWarning(
135
+ "ecosystem",
136
+ `before_agent_start handler failed: ${err instanceof Error ? err.message : String(err)}`,
137
+ );
138
+ }
139
+ }
140
+
141
+ // Compose result. Return undefined if nothing changed (preserves runner contract).
142
+ if (currentSystemPrompt === event.systemPrompt && !lastMessage) return undefined;
143
+ return {
144
+ systemPrompt: currentSystemPrompt !== event.systemPrompt ? currentSystemPrompt : undefined,
145
+ message: lastMessage,
146
+ };
97
147
  });
98
148
 
99
149
  pi.on("agent_end", async (event, ctx: ExtensionContext) => {
@@ -125,7 +175,10 @@ export function registerHooks(pi: ExtensionAPI): void {
125
175
  await ensureDbOpen();
126
176
  const state = await deriveState(basePath);
127
177
  if (!state.activeMilestone || !state.activeSlice || !state.activeTask) return;
128
- if (state.phase !== "executing") return;
178
+ // Write checkpoint for ALL phases, not just "executing" — discuss, research,
179
+ // and planning also carry in-memory state (user answers, gate verification)
180
+ // that would be lost on compaction (#4258).
181
+ // if (state.phase !== "executing") return;
129
182
 
130
183
  const sliceDir = resolveSlicePath(basePath, state.activeMilestone.id, state.activeSlice.id);
131
184
  if (!sliceDir) return;
@@ -15,7 +15,7 @@ export interface GsdCommandDefinition {
15
15
  type CompletionMap = Record<string, readonly GsdCommandDefinition[]>;
16
16
 
17
17
  export const GSD_COMMAND_DESCRIPTION =
18
- "GSD — Get Shit Done: /gsd help|start|templates|next|auto|stop|pause|status|widget|visualize|queue|quick|discuss|capture|triage|dispatch|history|undo|undo-task|reset-slice|rate|skip|export|cleanup|model|mode|prefs|config|keys|hooks|run-hook|skill-health|doctor|logs|forensics|changelog|migrate|remote|steer|knowledge|new-milestone|parallel|cmux|park|unpark|init|setup|inspect|extensions|update|fast|mcp|rethink|codebase|notifications";
18
+ "GSD — Get Shit Done: /gsd help|start|templates|next|auto|stop|pause|status|widget|visualize|queue|quick|discuss|capture|triage|dispatch|history|undo|undo-task|reset-slice|rate|skip|export|cleanup|model|mode|prefs|config|keys|hooks|run-hook|skill-health|doctor|logs|forensics|changelog|migrate|remote|steer|knowledge|new-milestone|parallel|cmux|park|unpark|init|setup|inspect|extensions|update|fast|mcp|rethink|codebase|notifications|ship|do|session-report|backlog|pr-branch|add-tests";
19
19
 
20
20
  export const TOP_LEVEL_SUBCOMMANDS: readonly GsdCommandDefinition[] = [
21
21
  { cmd: "help", desc: "Categorized command reference with descriptions" },
@@ -74,6 +74,12 @@ export const TOP_LEVEL_SUBCOMMANDS: readonly GsdCommandDefinition[] = [
74
74
  { cmd: "rethink", desc: "Conversational project reorganization — reorder, park, discard, add milestones" },
75
75
  { cmd: "workflow", desc: "Custom workflow lifecycle (new, run, list, validate, pause, resume)" },
76
76
  { cmd: "codebase", desc: "Generate, refresh, and inspect the codebase map cache (.gsd/CODEBASE.md)" },
77
+ { cmd: "ship", desc: "Create PR from milestone artifacts and open for review" },
78
+ { cmd: "do", desc: "Route freeform text to the right GSD command" },
79
+ { cmd: "session-report", desc: "Session cost, tokens, and work summary" },
80
+ { cmd: "backlog", desc: "Manage backlog items (add, promote, remove, list)" },
81
+ { cmd: "pr-branch", desc: "Create clean PR branch filtering .gsd/ commits" },
82
+ { cmd: "add-tests", desc: "Generate tests for completed slices" },
77
83
  ];
78
84
 
79
85
  const NESTED_COMPLETIONS: CompletionMap = {
@@ -244,6 +250,25 @@ const NESTED_COMPLETIONS: CompletionMap = {
244
250
  { cmd: "stats", desc: "Show file count, description coverage, and generation time" },
245
251
  { cmd: "help", desc: "Show usage and available subcommands" },
246
252
  ],
253
+ ship: [
254
+ { cmd: "--dry-run", desc: "Preview PR without creating" },
255
+ { cmd: "--draft", desc: "Open as draft PR" },
256
+ { cmd: "--base", desc: "Override target branch (default: main)" },
257
+ { cmd: "--force", desc: "Ship even with pending tasks" },
258
+ ],
259
+ "session-report": [
260
+ { cmd: "--json", desc: "Machine-readable JSON output" },
261
+ { cmd: "--save", desc: "Save report to .gsd/reports/" },
262
+ ],
263
+ backlog: [
264
+ { cmd: "add", desc: "Add item to backlog" },
265
+ { cmd: "promote", desc: "Promote backlog item to active slice" },
266
+ { cmd: "remove", desc: "Remove backlog item" },
267
+ ],
268
+ "pr-branch": [
269
+ { cmd: "--dry-run", desc: "Preview what would be filtered" },
270
+ { cmd: "--name", desc: "Custom branch name" },
271
+ ],
247
272
  };
248
273
 
249
274
  function filterOptions(
@@ -11,6 +11,9 @@ import { handleExport } from "../../export.js";
11
11
  import { handleHistory } from "../../history.js";
12
12
  import { handleUndo } from "../../undo.js";
13
13
  import { handleRemote } from "../../../remote-questions/mod.js";
14
+ import { handleShip } from "../../commands-ship.js";
15
+ import { handleSessionReport } from "../../commands-session-report.js";
16
+ import { handlePrBranch } from "../../commands-pr-branch.js";
14
17
  import { projectRoot } from "../context.js";
15
18
 
16
19
  export async function handleOpsCommand(trimmed: string, ctx: ExtensionCommandContext, pi: ExtensionAPI): Promise<boolean> {
@@ -216,5 +219,27 @@ Examples:
216
219
  await handleCodebase(trimmed.replace(/^codebase\s*/, "").trim(), ctx, pi);
217
220
  return true;
218
221
  }
222
+ if (trimmed === "ship" || trimmed.startsWith("ship ")) {
223
+ await handleShip(trimmed.replace(/^ship\s*/, "").trim(), ctx, pi);
224
+ return true;
225
+ }
226
+ if (trimmed === "session-report" || trimmed.startsWith("session-report ")) {
227
+ await handleSessionReport(trimmed.replace(/^session-report\s*/, "").trim(), ctx);
228
+ return true;
229
+ }
230
+ if (trimmed === "pr-branch" || trimmed.startsWith("pr-branch ")) {
231
+ await handlePrBranch(trimmed.replace(/^pr-branch\s*/, "").trim(), ctx);
232
+ return true;
233
+ }
234
+ if (trimmed === "add-tests" || trimmed.startsWith("add-tests ")) {
235
+ const { handleAddTests } = await import("../../commands-add-tests.js");
236
+ await handleAddTests(trimmed.replace(/^add-tests\s*/, "").trim(), ctx, pi);
237
+ return true;
238
+ }
239
+ if (trimmed === "extract-learnings" || trimmed.startsWith("extract-learnings ")) {
240
+ const { handleExtractLearnings } = await import("../../commands-extract-learnings.js");
241
+ await handleExtractLearnings(trimmed.replace(/^extract-learnings\s*/, "").trim(), ctx, pi);
242
+ return true;
243
+ }
219
244
  return false;
220
245
  }
@@ -38,6 +38,67 @@ const WORKFLOW_USAGE = [
38
38
  " resume — Resume paused custom workflow auto-mode",
39
39
  ].join("\n");
40
40
 
41
+ function splitWorkflowRunArgs(input: string): string[] {
42
+ const tokens: string[] = [];
43
+ let current = "";
44
+ let quote: '"' | "'" | null = null;
45
+ let escapeNext = false;
46
+
47
+ for (const ch of input) {
48
+ if (escapeNext) {
49
+ current += ch;
50
+ escapeNext = false;
51
+ continue;
52
+ }
53
+
54
+ if (ch === "\\") {
55
+ escapeNext = true;
56
+ continue;
57
+ }
58
+
59
+ if (quote) {
60
+ if (ch === quote) {
61
+ quote = null;
62
+ } else {
63
+ current += ch;
64
+ }
65
+ continue;
66
+ }
67
+
68
+ if (ch === '"' || ch === "'") {
69
+ quote = ch;
70
+ continue;
71
+ }
72
+
73
+ if (/\s/.test(ch)) {
74
+ if (current) {
75
+ tokens.push(current);
76
+ current = "";
77
+ }
78
+ continue;
79
+ }
80
+
81
+ current += ch;
82
+ }
83
+
84
+ if (escapeNext) current += "\\";
85
+ if (current) tokens.push(current);
86
+ return tokens;
87
+ }
88
+
89
+ export function parseWorkflowRunArgs(args: string): { defName: string; overrides: Record<string, string> } {
90
+ const parts = splitWorkflowRunArgs(args);
91
+ const defName = parts[0] ?? "";
92
+ const overrides: Record<string, string> = {};
93
+ for (let i = 1; i < parts.length; i++) {
94
+ const eqIdx = parts[i].indexOf("=");
95
+ if (eqIdx > 0) {
96
+ overrides[parts[i].slice(0, eqIdx)] = parts[i].slice(eqIdx + 1);
97
+ }
98
+ }
99
+ return { defName, overrides };
100
+ }
101
+
41
102
  async function handleCustomWorkflow(
42
103
  sub: string,
43
104
  ctx: ExtensionCommandContext,
@@ -62,15 +123,7 @@ async function handleCustomWorkflow(
62
123
  ctx.ui.notify("Usage: /gsd workflow run <name> [param=value ...]", "warning");
63
124
  return true;
64
125
  }
65
- const parts = args.split(/\s+/);
66
- const defName = parts[0];
67
- const overrides: Record<string, string> = {};
68
- for (let i = 1; i < parts.length; i++) {
69
- const eqIdx = parts[i].indexOf("=");
70
- if (eqIdx > 0) {
71
- overrides[parts[i].slice(0, eqIdx)] = parts[i].slice(eqIdx + 1);
72
- }
73
- }
126
+ const { defName, overrides } = parseWorkflowRunArgs(args);
74
127
  try {
75
128
  const base = projectRoot();
76
129
  const runDir = createRun(base, defName, Object.keys(overrides).length > 0 ? overrides : undefined);
@@ -168,6 +221,18 @@ async function handleCustomWorkflow(
168
221
  }
169
222
 
170
223
  export async function handleWorkflowCommand(trimmed: string, ctx: ExtensionCommandContext, pi: ExtensionAPI): Promise<boolean> {
224
+ // ── /gsd do — natural language routing (must be early to route to other commands) ──
225
+ if (trimmed === "do" || trimmed.startsWith("do ")) {
226
+ const { handleDo } = await import("../../commands-do.js");
227
+ await handleDo(trimmed.replace(/^do\s*/, "").trim(), ctx, pi);
228
+ return true;
229
+ }
230
+ // ── Backlog management ──
231
+ if (trimmed === "backlog" || trimmed.startsWith("backlog ")) {
232
+ const { handleBacklog } = await import("../../commands-backlog.js");
233
+ await handleBacklog(trimmed.replace(/^backlog\s*/, "").trim(), ctx, pi);
234
+ return true;
235
+ }
171
236
  // ── Custom workflow commands (`/gsd workflow ...`) ──
172
237
  if (trimmed === "workflow" || trimmed.startsWith("workflow ")) {
173
238
  const sub = trimmed.slice("workflow".length).trim();