gsd-pi 2.80.0 → 2.81.0

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 (1172) hide show
  1. package/README.md +35 -59
  2. package/dist/claude-cli-check.d.ts +30 -0
  3. package/dist/claude-cli-check.js +18 -7
  4. package/dist/cli.js +0 -19
  5. package/dist/headless-query.d.ts +10 -0
  6. package/dist/headless-query.js +6 -4
  7. package/dist/loader-entrypoint.d.ts +8 -0
  8. package/dist/loader-entrypoint.js +27 -0
  9. package/dist/loader.js +2 -11
  10. package/dist/mcp-server.d.ts +1 -0
  11. package/dist/mcp-server.js +6 -3
  12. package/dist/resources/.managed-resources-content-hash +1 -1
  13. package/dist/resources/GSD-WORKFLOW.md +2 -2
  14. package/dist/resources/extensions/claude-code-cli/readiness.js +18 -7
  15. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +40 -3
  16. package/dist/resources/extensions/github-sync/sync.js +4 -1
  17. package/dist/resources/extensions/github-sync/templates.js +90 -74
  18. package/dist/resources/extensions/gsd/auto/contracts.js +2 -0
  19. package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +53 -0
  20. package/dist/resources/extensions/gsd/auto/loop.js +462 -525
  21. package/dist/resources/extensions/gsd/auto/orchestrator.js +48 -4
  22. package/dist/resources/extensions/gsd/auto/phases.js +311 -154
  23. package/dist/resources/extensions/gsd/auto/resolve.js +29 -0
  24. package/dist/resources/extensions/gsd/auto/run-unit.js +41 -45
  25. package/dist/resources/extensions/gsd/auto/session.js +9 -1
  26. package/dist/resources/extensions/gsd/auto/unit-runner-events.js +7 -0
  27. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-dispatch-outcome.js +12 -0
  28. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-iteration.js +24 -0
  29. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-reconcile-outcome.js +33 -0
  30. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-reconcile.js +26 -0
  31. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-retry.js +49 -0
  32. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-verify-outcome.js +25 -0
  33. package/dist/resources/extensions/gsd/auto/workflow-dispatch-claim.js +80 -0
  34. package/dist/resources/extensions/gsd/auto/workflow-dispatch-ledger.js +26 -0
  35. package/dist/resources/extensions/gsd/auto/workflow-iteration-completion.js +10 -0
  36. package/dist/resources/extensions/gsd/auto/workflow-journal-reporter.js +16 -0
  37. package/dist/resources/extensions/gsd/auto/workflow-kernel.js +263 -0
  38. package/dist/resources/extensions/gsd/auto/workflow-memory-pressure.js +36 -0
  39. package/dist/resources/extensions/gsd/auto/workflow-phase-reporter.js +9 -0
  40. package/dist/resources/extensions/gsd/auto/workflow-session-lock.js +35 -0
  41. package/dist/resources/extensions/gsd/auto/workflow-sidecar-iteration.js +24 -0
  42. package/dist/resources/extensions/gsd/auto/workflow-sidecar-queue.js +26 -0
  43. package/dist/resources/extensions/gsd/auto/workflow-turn-reporter.js +36 -0
  44. package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +44 -0
  45. package/dist/resources/extensions/gsd/auto/workflow-worker-heartbeat.js +23 -0
  46. package/dist/resources/extensions/gsd/auto-dashboard.js +72 -15
  47. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +5 -32
  48. package/dist/resources/extensions/gsd/auto-dispatch.js +26 -0
  49. package/dist/resources/extensions/gsd/auto-post-unit.js +122 -88
  50. package/dist/resources/extensions/gsd/auto-prompts.js +382 -20
  51. package/dist/resources/extensions/gsd/auto-recovery.js +197 -9
  52. package/dist/resources/extensions/gsd/auto-start.js +254 -17
  53. package/dist/resources/extensions/gsd/auto-supervisor.js +8 -1
  54. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +2 -2
  55. package/dist/resources/extensions/gsd/auto-verification.js +2 -11
  56. package/dist/resources/extensions/gsd/auto-worktree.js +316 -374
  57. package/dist/resources/extensions/gsd/auto.js +273 -87
  58. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +136 -11
  59. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +54 -37
  60. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +37 -10
  61. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +30 -20
  62. package/dist/resources/extensions/gsd/bootstrap/journal-tools.js +4 -1
  63. package/dist/resources/extensions/gsd/bootstrap/memory-tools.js +6 -4
  64. package/dist/resources/extensions/gsd/bootstrap/query-tools.js +5 -3
  65. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +1 -1
  66. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +349 -57
  67. package/dist/resources/extensions/gsd/bootstrap/sanitize-complete-milestone.js +4 -0
  68. package/dist/resources/extensions/gsd/bootstrap/system-context.js +82 -23
  69. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +147 -2
  70. package/dist/resources/extensions/gsd/clean-root-preflight.js +65 -9
  71. package/dist/resources/extensions/gsd/commands/dispatcher.js +5 -0
  72. package/dist/resources/extensions/gsd/commands/handlers/ops.js +2 -2
  73. package/dist/resources/extensions/gsd/commands-config.js +1 -1
  74. package/dist/resources/extensions/gsd/commands-eval-review.js +2 -2
  75. package/dist/resources/extensions/gsd/commands-extract-learnings.js +17 -12
  76. package/dist/resources/extensions/gsd/commands-handlers.js +23 -9
  77. package/dist/resources/extensions/gsd/commands-ship.js +23 -46
  78. package/dist/resources/extensions/gsd/commands-workflow-templates.js +12 -7
  79. package/dist/resources/extensions/gsd/component-loader.js +5 -11
  80. package/dist/resources/extensions/gsd/context-budget.js +37 -2
  81. package/dist/resources/extensions/gsd/crash-recovery.js +56 -10
  82. package/dist/resources/extensions/gsd/custom-workflow-engine.js +25 -1
  83. package/dist/resources/extensions/gsd/dashboard-overlay.js +1 -1
  84. package/dist/resources/extensions/gsd/db/unit-dispatches.js +92 -0
  85. package/dist/resources/extensions/gsd/db-adapter.js +47 -0
  86. package/dist/resources/extensions/gsd/db-base-schema.js +353 -0
  87. package/dist/resources/extensions/gsd/db-connection-cache.js +31 -0
  88. package/dist/resources/extensions/gsd/db-coordination-schema.js +104 -0
  89. package/dist/resources/extensions/gsd/db-decision-requirement-rows.js +71 -0
  90. package/dist/resources/extensions/gsd/db-gate-rows.js +16 -0
  91. package/dist/resources/extensions/gsd/db-lightweight-query-rows.js +29 -0
  92. package/dist/resources/extensions/gsd/db-memory-fts-schema.js +56 -0
  93. package/dist/resources/extensions/gsd/db-migration-backup.js +22 -0
  94. package/dist/resources/extensions/gsd/db-migration-steps.js +416 -0
  95. package/dist/resources/extensions/gsd/db-milestone-artifact-rows.js +35 -0
  96. package/dist/resources/extensions/gsd/db-open-state.js +32 -0
  97. package/dist/resources/extensions/gsd/db-provider.js +108 -0
  98. package/dist/resources/extensions/gsd/db-runtime-kv-schema.js +27 -0
  99. package/dist/resources/extensions/gsd/db-schema-metadata.js +23 -0
  100. package/dist/resources/extensions/gsd/db-task-slice-rows.js +86 -0
  101. package/dist/resources/extensions/gsd/db-transaction.js +63 -0
  102. package/dist/resources/extensions/gsd/db-verification-evidence-rows.js +3 -0
  103. package/dist/resources/extensions/gsd/db-verification-evidence-schema.js +19 -0
  104. package/dist/resources/extensions/gsd/detection.js +106 -0
  105. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +2 -0
  106. package/dist/resources/extensions/gsd/escalation.js +2 -0
  107. package/dist/resources/extensions/gsd/git-service.js +73 -5
  108. package/dist/resources/extensions/gsd/graph.js +9 -3
  109. package/dist/resources/extensions/gsd/gsd-db.js +331 -1535
  110. package/dist/resources/extensions/gsd/guided-flow.js +149 -48
  111. package/dist/resources/extensions/gsd/health-widget.js +3 -0
  112. package/dist/resources/extensions/gsd/init-wizard.js +4 -1
  113. package/dist/resources/extensions/gsd/legacy-telemetry.js +70 -0
  114. package/dist/resources/extensions/gsd/markdown-renderer.js +2 -0
  115. package/dist/resources/extensions/gsd/memory-store.js +69 -12
  116. package/dist/resources/extensions/gsd/migrate/command.js +40 -1
  117. package/dist/resources/extensions/gsd/migration-auto-check.js +87 -0
  118. package/dist/resources/extensions/gsd/model-router.js +9 -6
  119. package/dist/resources/extensions/gsd/native-git-bridge.js +32 -8
  120. package/dist/resources/extensions/gsd/notification-widget.js +21 -3
  121. package/dist/resources/extensions/gsd/orphan-stash-audit.js +101 -0
  122. package/dist/resources/extensions/gsd/parallel-orchestrator.js +13 -3
  123. package/dist/resources/extensions/gsd/planning-path-scope.js +26 -0
  124. package/dist/resources/extensions/gsd/post-execution-checks.js +2 -0
  125. package/dist/resources/extensions/gsd/pr-evidence.js +117 -0
  126. package/dist/resources/extensions/gsd/pre-execution-checks.js +24 -0
  127. package/dist/resources/extensions/gsd/process-task-path.js +61 -0
  128. package/dist/resources/extensions/gsd/prompt-loader.js +37 -7
  129. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +41 -35
  130. package/dist/resources/extensions/gsd/prompts/complete-slice.md +23 -34
  131. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +50 -96
  132. package/dist/resources/extensions/gsd/prompts/discuss.md +81 -181
  133. package/dist/resources/extensions/gsd/prompts/execute-task.md +42 -67
  134. package/dist/resources/extensions/gsd/prompts/forensics.md +41 -84
  135. package/dist/resources/extensions/gsd/prompts/guided-discuss-milestone.md +29 -39
  136. package/dist/resources/extensions/gsd/prompts/guided-discuss-project.md +30 -65
  137. package/dist/resources/extensions/gsd/prompts/guided-discuss-requirements.md +25 -52
  138. package/dist/resources/extensions/gsd/prompts/guided-discuss-slice.md +36 -36
  139. package/dist/resources/extensions/gsd/prompts/guided-research-project.md +20 -38
  140. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +1 -1
  141. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +47 -59
  142. package/dist/resources/extensions/gsd/prompts/plan-slice.md +25 -87
  143. package/dist/resources/extensions/gsd/prompts/queue.md +46 -53
  144. package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -5
  145. package/dist/resources/extensions/gsd/prompts/refine-slice.md +23 -23
  146. package/dist/resources/extensions/gsd/prompts/replan-slice.md +2 -2
  147. package/dist/resources/extensions/gsd/prompts/research-slice.md +23 -23
  148. package/dist/resources/extensions/gsd/prompts/rethink.md +10 -10
  149. package/dist/resources/extensions/gsd/prompts/system.md +65 -107
  150. package/dist/resources/extensions/gsd/prompts/triage-captures.md +15 -15
  151. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +24 -24
  152. package/dist/resources/extensions/gsd/prompts/worktree-merge.md +35 -35
  153. package/dist/resources/extensions/gsd/quick.js +34 -2
  154. package/dist/resources/extensions/gsd/recovery-classification.js +94 -0
  155. package/dist/resources/extensions/gsd/safety/evidence-collector.js +10 -2
  156. package/dist/resources/extensions/gsd/slice-cadence.js +45 -2
  157. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +15 -9
  158. package/dist/resources/extensions/gsd/state-reconciliation.js +27 -0
  159. package/dist/resources/extensions/gsd/state.js +4 -0
  160. package/dist/resources/extensions/gsd/tool-contract.js +50 -0
  161. package/dist/resources/extensions/gsd/tools/complete-milestone.js +20 -16
  162. package/dist/resources/extensions/gsd/tools/complete-task.js +3 -1
  163. package/dist/resources/extensions/gsd/tools/context-mode-tool-result.js +15 -0
  164. package/dist/resources/extensions/gsd/tools/exec-search-tool.js +5 -0
  165. package/dist/resources/extensions/gsd/tools/exec-tool.js +3 -15
  166. package/dist/resources/extensions/gsd/tools/memory-tools.js +1 -0
  167. package/dist/resources/extensions/gsd/tools/plan-slice.js +9 -0
  168. package/dist/resources/extensions/gsd/tools/plan-task.js +9 -0
  169. package/dist/resources/extensions/gsd/tools/resume-tool.js +5 -0
  170. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +7 -2
  171. package/dist/resources/extensions/gsd/unit-context-composer.js +12 -3
  172. package/dist/resources/extensions/gsd/unit-runtime.js +22 -0
  173. package/dist/resources/extensions/gsd/uok/kernel.js +8 -3
  174. package/dist/resources/extensions/gsd/uok/plan-v2.js +2 -0
  175. package/dist/resources/extensions/gsd/workflow-logger.js +13 -13
  176. package/dist/resources/extensions/gsd/workflow-manifest.js +2 -0
  177. package/dist/resources/extensions/gsd/workflow-projections.js +2 -0
  178. package/dist/resources/extensions/gsd/workflow-protocol.js +131 -0
  179. package/dist/resources/extensions/gsd/workflow-templates.js +9 -0
  180. package/dist/resources/extensions/gsd/working-output-messages.js +64 -0
  181. package/dist/resources/extensions/gsd/worktree-lifecycle.js +958 -0
  182. package/dist/resources/extensions/gsd/worktree-manager.js +16 -14
  183. package/dist/resources/extensions/gsd/worktree-safety.js +119 -0
  184. package/dist/resources/extensions/gsd/worktree-state-projection.js +317 -0
  185. package/dist/resources/skills/web-quality-audit/scripts/analyze.sh +0 -0
  186. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  187. package/dist/web/standalone/.next/BUILD_ID +1 -1
  188. package/dist/web/standalone/.next/app-path-routes-manifest.json +3 -3
  189. package/dist/web/standalone/.next/build-manifest.json +3 -3
  190. package/dist/web/standalone/.next/react-loadable-manifest.json +2 -2
  191. package/dist/web/standalone/.next/required-server-files.json +1 -1
  192. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  193. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  194. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  195. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  196. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  197. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  198. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  199. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  200. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  201. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  202. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  203. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  204. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  205. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  206. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  207. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  208. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  209. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  210. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  211. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  212. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  213. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  214. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  216. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +1 -1
  217. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  218. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  219. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  220. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  221. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  222. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  223. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  224. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  225. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  226. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  228. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  229. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  230. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  232. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  233. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  234. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  235. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  236. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  237. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  238. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  239. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  240. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  241. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  242. package/dist/web/standalone/.next/server/app/api/notifications/route.js +1 -1
  243. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  244. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  245. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  246. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  247. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  248. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  249. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  250. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  251. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  252. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  253. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  254. package/dist/web/standalone/.next/server/app/api/session/events/route.js +1 -1
  255. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  256. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  257. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  258. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  259. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  260. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  261. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  262. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  263. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  264. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  265. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  266. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
  267. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  268. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
  269. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  270. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  271. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  272. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  273. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  274. package/dist/web/standalone/.next/server/app/index.html +1 -1
  275. package/dist/web/standalone/.next/server/app/index.rsc +2 -2
  276. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  277. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +2 -2
  278. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  279. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  280. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  281. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  282. package/dist/web/standalone/.next/server/app-paths-manifest.json +3 -3
  283. package/dist/web/standalone/.next/server/chunks/167.js +2 -0
  284. package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
  285. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  286. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  287. package/dist/web/standalone/.next/server/middleware.js +2 -2
  288. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  289. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  290. package/dist/web/standalone/.next/static/chunks/8359.e059d86b255fce1c.js +10 -0
  291. package/dist/web/standalone/.next/static/chunks/app/{page-ff639266d978f2a0.js → page-200592a7f3baf579.js} +1 -1
  292. package/dist/web/standalone/.next/static/chunks/{webpack-d82dbee6356c1733.js → webpack-de742b64187e13fe.js} +1 -1
  293. package/dist/web/standalone/package.json +1 -0
  294. package/dist/web/standalone/server.js +1 -1
  295. package/dist/welcome-screen.d.ts +2 -0
  296. package/dist/welcome-screen.js +9 -7
  297. package/package.json +20 -9
  298. package/packages/contracts/dist/index.d.ts +3 -0
  299. package/packages/contracts/dist/index.d.ts.map +1 -0
  300. package/packages/contracts/dist/index.js +5 -0
  301. package/packages/contracts/dist/index.js.map +1 -0
  302. package/packages/contracts/dist/rpc.d.ts +549 -0
  303. package/packages/contracts/dist/rpc.d.ts.map +1 -0
  304. package/packages/contracts/dist/rpc.js +53 -0
  305. package/packages/contracts/dist/rpc.js.map +1 -0
  306. package/packages/contracts/dist/rpc.test.d.ts +2 -0
  307. package/packages/contracts/dist/rpc.test.d.ts.map +1 -0
  308. package/packages/contracts/dist/rpc.test.js +47 -0
  309. package/packages/contracts/dist/rpc.test.js.map +1 -0
  310. package/packages/contracts/dist/workflow.d.ts +180 -0
  311. package/packages/contracts/dist/workflow.d.ts.map +1 -0
  312. package/packages/contracts/dist/workflow.js +201 -0
  313. package/packages/contracts/dist/workflow.js.map +1 -0
  314. package/packages/contracts/package.json +39 -0
  315. package/packages/contracts/src/index.ts +5 -0
  316. package/packages/contracts/src/rpc.test.ts +72 -0
  317. package/packages/contracts/src/rpc.ts +286 -0
  318. package/packages/contracts/src/workflow.ts +213 -0
  319. package/packages/contracts/tsconfig.json +25 -0
  320. package/packages/daemon/package.json +3 -2
  321. package/packages/daemon/src/event-bridge.test.ts +2 -1
  322. package/packages/daemon/src/event-bridge.ts +1 -1
  323. package/packages/daemon/src/event-formatter.test.ts +1 -2
  324. package/packages/daemon/src/event-formatter.ts +1 -2
  325. package/packages/daemon/src/session-manager.ts +2 -2
  326. package/packages/daemon/src/types.ts +3 -18
  327. package/packages/mcp-server/dist/server.d.ts +13 -0
  328. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  329. package/packages/mcp-server/dist/server.js +77 -0
  330. package/packages/mcp-server/dist/server.js.map +1 -1
  331. package/packages/mcp-server/dist/session-manager.js +1 -1
  332. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  333. package/packages/mcp-server/dist/types.d.ts +3 -11
  334. package/packages/mcp-server/dist/types.d.ts.map +1 -1
  335. package/packages/mcp-server/dist/types.js.map +1 -1
  336. package/packages/mcp-server/dist/workflow-tools.d.ts +1 -1
  337. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  338. package/packages/mcp-server/dist/workflow-tools.js +24 -57
  339. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  340. package/packages/mcp-server/package.json +3 -2
  341. package/packages/mcp-server/src/mcp-server.test.ts +138 -0
  342. package/packages/mcp-server/src/server.ts +99 -1
  343. package/packages/mcp-server/src/session-manager.ts +2 -2
  344. package/packages/mcp-server/src/types.ts +7 -18
  345. package/packages/mcp-server/src/workflow-tools.test.ts +75 -2
  346. package/packages/mcp-server/src/workflow-tools.ts +32 -56
  347. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  348. package/packages/native/package.json +1 -1
  349. package/packages/native/tsconfig.tsbuildinfo +1 -1
  350. package/packages/pi-agent-core/dist/agent-loop.d.ts.map +1 -1
  351. package/packages/pi-agent-core/dist/agent-loop.js +4 -1
  352. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  353. package/packages/pi-agent-core/dist/agent.d.ts +9 -2
  354. package/packages/pi-agent-core/dist/agent.d.ts.map +1 -1
  355. package/packages/pi-agent-core/dist/agent.js +43 -11
  356. package/packages/pi-agent-core/dist/agent.js.map +1 -1
  357. package/packages/pi-agent-core/dist/index.d.ts +1 -0
  358. package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
  359. package/packages/pi-agent-core/dist/index.js +2 -0
  360. package/packages/pi-agent-core/dist/index.js.map +1 -1
  361. package/packages/pi-agent-core/dist/token-audit.d.ts +47 -0
  362. package/packages/pi-agent-core/dist/token-audit.d.ts.map +1 -0
  363. package/packages/pi-agent-core/dist/token-audit.js +221 -0
  364. package/packages/pi-agent-core/dist/token-audit.js.map +1 -0
  365. package/packages/pi-agent-core/dist/types.d.ts +31 -0
  366. package/packages/pi-agent-core/dist/types.d.ts.map +1 -1
  367. package/packages/pi-agent-core/dist/types.js.map +1 -1
  368. package/packages/pi-agent-core/package.json +1 -1
  369. package/packages/pi-agent-core/src/agent-loop.test.ts +128 -0
  370. package/packages/pi-agent-core/src/agent-loop.ts +4 -1
  371. package/packages/pi-agent-core/src/agent.ts +52 -11
  372. package/packages/pi-agent-core/src/index.ts +2 -0
  373. package/packages/pi-agent-core/src/token-audit.test.ts +189 -0
  374. package/packages/pi-agent-core/src/token-audit.ts +287 -0
  375. package/packages/pi-agent-core/src/types.ts +26 -10
  376. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  377. package/packages/pi-ai/dist/models/fake-model.d.ts +12 -0
  378. package/packages/pi-ai/dist/models/fake-model.d.ts.map +1 -0
  379. package/packages/pi-ai/dist/models/fake-model.js +27 -0
  380. package/packages/pi-ai/dist/models/fake-model.js.map +1 -0
  381. package/packages/pi-ai/dist/models/index.d.ts.map +1 -1
  382. package/packages/pi-ai/dist/models/index.js +8 -0
  383. package/packages/pi-ai/dist/models/index.js.map +1 -1
  384. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +35 -13
  385. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  386. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js +21 -11
  387. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js.map +1 -1
  388. package/packages/pi-ai/dist/providers/anthropic.d.ts +7 -0
  389. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  390. package/packages/pi-ai/dist/providers/anthropic.js +9 -7
  391. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  392. package/packages/pi-ai/dist/providers/fake.d.ts +42 -0
  393. package/packages/pi-ai/dist/providers/fake.d.ts.map +1 -0
  394. package/packages/pi-ai/dist/providers/fake.js +319 -0
  395. package/packages/pi-ai/dist/providers/fake.js.map +1 -0
  396. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +23 -14
  397. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -1
  398. package/packages/pi-ai/dist/providers/register-builtins.d.ts.map +1 -1
  399. package/packages/pi-ai/dist/providers/register-builtins.js +24 -0
  400. package/packages/pi-ai/dist/providers/register-builtins.js.map +1 -1
  401. package/packages/pi-ai/dist/types.d.ts +2 -0
  402. package/packages/pi-ai/dist/types.d.ts.map +1 -1
  403. package/packages/pi-ai/dist/types.js.map +1 -1
  404. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js +48 -21
  405. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js.map +1 -1
  406. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js +22 -21
  407. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js.map +1 -1
  408. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js +22 -21
  409. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js.map +1 -1
  410. package/packages/pi-ai/package.json +1 -1
  411. package/packages/pi-ai/src/models/fake-model.ts +30 -0
  412. package/packages/pi-ai/src/models/index.ts +9 -0
  413. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +39 -25
  414. package/packages/pi-ai/src/providers/anthropic-bearer-auth.test.ts +26 -22
  415. package/packages/pi-ai/src/providers/anthropic.ts +22 -9
  416. package/packages/pi-ai/src/providers/fake.ts +376 -0
  417. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +34 -21
  418. package/packages/pi-ai/src/providers/register-builtins.ts +23 -0
  419. package/packages/pi-ai/src/types.ts +3 -0
  420. package/packages/pi-ai/src/utils/oauth/github-copilot.test.ts +56 -22
  421. package/packages/pi-ai/src/utils/oauth/google-antigravity.test.ts +24 -28
  422. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.test.ts +24 -28
  423. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  424. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +36 -1
  425. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  426. package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js +30 -1
  427. package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js.map +1 -1
  428. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +21 -2
  429. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  430. package/packages/pi-coding-agent/dist/core/agent-session.js +94 -16
  431. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  432. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +78 -0
  433. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
  434. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +11 -0
  435. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  436. package/packages/pi-coding-agent/dist/core/compaction/compaction.js +9 -0
  437. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  438. package/packages/pi-coding-agent/dist/core/compaction-threshold.test.d.ts +2 -0
  439. package/packages/pi-coding-agent/dist/core/compaction-threshold.test.d.ts.map +1 -0
  440. package/packages/pi-coding-agent/dist/core/compaction-threshold.test.js +103 -0
  441. package/packages/pi-coding-agent/dist/core/compaction-threshold.test.js.map +1 -0
  442. package/packages/pi-coding-agent/dist/core/db-snapshot.d.ts +15 -0
  443. package/packages/pi-coding-agent/dist/core/db-snapshot.d.ts.map +1 -0
  444. package/packages/pi-coding-agent/dist/core/db-snapshot.js +66 -0
  445. package/packages/pi-coding-agent/dist/core/db-snapshot.js.map +1 -0
  446. package/packages/pi-coding-agent/dist/core/db-snapshot.test.d.ts +2 -0
  447. package/packages/pi-coding-agent/dist/core/db-snapshot.test.d.ts.map +1 -0
  448. package/packages/pi-coding-agent/dist/core/db-snapshot.test.js +24 -0
  449. package/packages/pi-coding-agent/dist/core/db-snapshot.test.js.map +1 -0
  450. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  451. package/packages/pi-coding-agent/dist/core/extensions/loader.js +8 -0
  452. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  453. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +5 -0
  454. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  455. package/packages/pi-coding-agent/dist/core/extensions/runner.js +20 -7
  456. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  457. package/packages/pi-coding-agent/dist/core/extensions/runner.test.js +102 -3
  458. package/packages/pi-coding-agent/dist/core/extensions/runner.test.js.map +1 -1
  459. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +60 -4
  460. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  461. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  462. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js +2 -0
  463. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js.map +1 -1
  464. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  465. package/packages/pi-coding-agent/dist/core/model-registry.js +5 -0
  466. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  467. package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.d.ts +2 -0
  468. package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.d.ts.map +1 -0
  469. package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.js +46 -0
  470. package/packages/pi-coding-agent/dist/core/sdk-tool-filter.test.js.map +1 -0
  471. package/packages/pi-coding-agent/dist/core/sdk.d.ts +10 -2
  472. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  473. package/packages/pi-coding-agent/dist/core/sdk.js +81 -4
  474. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  475. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +24 -0
  476. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  477. package/packages/pi-coding-agent/dist/core/settings-manager.js +33 -0
  478. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  479. package/packages/pi-coding-agent/dist/core/skill-tool.test.js +22 -0
  480. package/packages/pi-coding-agent/dist/core/skill-tool.test.js.map +1 -1
  481. package/packages/pi-coding-agent/dist/core/slash-commands.d.ts.map +1 -1
  482. package/packages/pi-coding-agent/dist/core/slash-commands.js +1 -0
  483. package/packages/pi-coding-agent/dist/core/slash-commands.js.map +1 -1
  484. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts +6 -7
  485. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
  486. package/packages/pi-coding-agent/dist/core/system-prompt.js +2 -3
  487. package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  488. package/packages/pi-coding-agent/dist/core/tools/bash-spawn-windows.test.js +22 -56
  489. package/packages/pi-coding-agent/dist/core/tools/bash-spawn-windows.test.js.map +1 -1
  490. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +1 -0
  491. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
  492. package/packages/pi-coding-agent/dist/core/tools/bash.js +3 -1
  493. package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
  494. package/packages/pi-coding-agent/dist/core/tools/edit.d.ts +2 -0
  495. package/packages/pi-coding-agent/dist/core/tools/edit.d.ts.map +1 -1
  496. package/packages/pi-coding-agent/dist/core/tools/edit.js +12 -1
  497. package/packages/pi-coding-agent/dist/core/tools/edit.js.map +1 -1
  498. package/packages/pi-coding-agent/dist/core/tools/find.d.ts +2 -0
  499. package/packages/pi-coding-agent/dist/core/tools/find.d.ts.map +1 -1
  500. package/packages/pi-coding-agent/dist/core/tools/find.js +14 -6
  501. package/packages/pi-coding-agent/dist/core/tools/find.js.map +1 -1
  502. package/packages/pi-coding-agent/dist/core/tools/grep.d.ts +2 -0
  503. package/packages/pi-coding-agent/dist/core/tools/grep.d.ts.map +1 -1
  504. package/packages/pi-coding-agent/dist/core/tools/grep.js +12 -3
  505. package/packages/pi-coding-agent/dist/core/tools/grep.js.map +1 -1
  506. package/packages/pi-coding-agent/dist/core/tools/hashline-read.d.ts +2 -0
  507. package/packages/pi-coding-agent/dist/core/tools/hashline-read.d.ts.map +1 -1
  508. package/packages/pi-coding-agent/dist/core/tools/hashline-read.js +3 -1
  509. package/packages/pi-coding-agent/dist/core/tools/hashline-read.js.map +1 -1
  510. package/packages/pi-coding-agent/dist/core/tools/index.d.ts +2 -1
  511. package/packages/pi-coding-agent/dist/core/tools/index.d.ts.map +1 -1
  512. package/packages/pi-coding-agent/dist/core/tools/index.js +1 -0
  513. package/packages/pi-coding-agent/dist/core/tools/index.js.map +1 -1
  514. package/packages/pi-coding-agent/dist/core/tools/ls.d.ts +2 -0
  515. package/packages/pi-coding-agent/dist/core/tools/ls.d.ts.map +1 -1
  516. package/packages/pi-coding-agent/dist/core/tools/ls.js +10 -3
  517. package/packages/pi-coding-agent/dist/core/tools/ls.js.map +1 -1
  518. package/packages/pi-coding-agent/dist/core/tools/read.d.ts +2 -0
  519. package/packages/pi-coding-agent/dist/core/tools/read.d.ts.map +1 -1
  520. package/packages/pi-coding-agent/dist/core/tools/read.js +3 -1
  521. package/packages/pi-coding-agent/dist/core/tools/read.js.map +1 -1
  522. package/packages/pi-coding-agent/dist/core/tools/spawn-shell-windows.test.js +7 -62
  523. package/packages/pi-coding-agent/dist/core/tools/spawn-shell-windows.test.js.map +1 -1
  524. package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.d.ts +2 -0
  525. package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.d.ts.map +1 -0
  526. package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.js +115 -0
  527. package/packages/pi-coding-agent/dist/core/tools/tool-target-metadata.test.js.map +1 -0
  528. package/packages/pi-coding-agent/dist/core/tools/tool-target.d.ts +19 -0
  529. package/packages/pi-coding-agent/dist/core/tools/tool-target.d.ts.map +1 -0
  530. package/packages/pi-coding-agent/dist/core/tools/tool-target.js +20 -0
  531. package/packages/pi-coding-agent/dist/core/tools/tool-target.js.map +1 -0
  532. package/packages/pi-coding-agent/dist/core/tools/write.d.ts +4 -0
  533. package/packages/pi-coding-agent/dist/core/tools/write.d.ts.map +1 -1
  534. package/packages/pi-coding-agent/dist/core/tools/write.js +9 -1
  535. package/packages/pi-coding-agent/dist/core/tools/write.js.map +1 -1
  536. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.js +6 -4
  537. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.js.map +1 -1
  538. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +154 -14
  539. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  540. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.d.ts +26 -0
  541. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.d.ts.map +1 -0
  542. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.js +112 -0
  543. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.js.map +1 -0
  544. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.d.ts +2 -0
  545. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.d.ts.map +1 -0
  546. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.js +51 -0
  547. package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.js.map +1 -0
  548. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  549. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
  550. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -1
  551. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +10 -9
  552. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -1
  553. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts +3 -0
  554. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  555. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.js +11 -0
  556. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.js.map +1 -1
  557. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js +51 -6
  558. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js.map +1 -1
  559. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +22 -0
  560. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  561. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +262 -20
  562. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  563. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  564. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +86 -2
  565. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  566. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.test.js +111 -1
  567. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.test.js.map +1 -1
  568. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +1 -0
  569. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
  570. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.d.ts +1 -0
  571. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.d.ts.map +1 -1
  572. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.js.map +1 -1
  573. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +14 -1
  574. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  575. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +77 -11
  576. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  577. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.d.ts.map +1 -1
  578. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.js +20 -0
  579. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.js.map +1 -1
  580. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.test.d.ts +2 -0
  581. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.test.d.ts.map +1 -0
  582. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.test.js +79 -0
  583. package/packages/pi-coding-agent/dist/modes/interactive/slash-command-handlers.test.js.map +1 -0
  584. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.d.ts +12 -0
  585. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.d.ts.map +1 -1
  586. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.js +13 -0
  587. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.js.map +1 -1
  588. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +1 -1
  589. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  590. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js +18 -1
  591. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
  592. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts.map +1 -1
  593. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +36 -27
  594. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -1
  595. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.d.ts +11 -0
  596. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.d.ts.map +1 -0
  597. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.js +18 -0
  598. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.js.map +1 -0
  599. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.d.ts +2 -0
  600. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.d.ts.map +1 -0
  601. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.js +48 -0
  602. package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.js.map +1 -0
  603. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js +1 -1
  604. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js.map +1 -1
  605. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts +1 -512
  606. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts.map +1 -1
  607. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.js +3 -7
  608. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.js.map +1 -1
  609. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.d.ts +2 -0
  610. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.d.ts.map +1 -0
  611. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.js +28 -0
  612. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage-safety-guard.test.js.map +1 -0
  613. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.d.ts.map +1 -1
  614. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.js +3 -2
  615. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.js.map +1 -1
  616. package/packages/pi-coding-agent/package.json +2 -1
  617. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +40 -1
  618. package/packages/pi-coding-agent/src/core/agent-session-tool-refresh.test.ts +40 -1
  619. package/packages/pi-coding-agent/src/core/agent-session.ts +102 -16
  620. package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +91 -0
  621. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +18 -0
  622. package/packages/pi-coding-agent/src/core/compaction-threshold.test.ts +121 -0
  623. package/packages/pi-coding-agent/src/core/db-snapshot.test.ts +32 -0
  624. package/packages/pi-coding-agent/src/core/db-snapshot.ts +66 -0
  625. package/packages/pi-coding-agent/src/core/extensions/loader.ts +10 -0
  626. package/packages/pi-coding-agent/src/core/extensions/runner.test.ts +113 -3
  627. package/packages/pi-coding-agent/src/core/extensions/runner.ts +24 -6
  628. package/packages/pi-coding-agent/src/core/extensions/types.ts +63 -2
  629. package/packages/pi-coding-agent/src/core/hooks-runner.test.ts +2 -0
  630. package/packages/pi-coding-agent/src/core/model-registry.ts +4 -0
  631. package/packages/pi-coding-agent/src/core/sdk-tool-filter.test.ts +60 -0
  632. package/packages/pi-coding-agent/src/core/sdk.ts +92 -4
  633. package/packages/pi-coding-agent/src/core/settings-manager.ts +51 -1
  634. package/packages/pi-coding-agent/src/core/skill-tool.test.ts +28 -0
  635. package/packages/pi-coding-agent/src/core/slash-commands.ts +1 -0
  636. package/packages/pi-coding-agent/src/core/system-prompt.ts +8 -10
  637. package/packages/pi-coding-agent/src/core/tools/bash-spawn-windows.test.ts +22 -66
  638. package/packages/pi-coding-agent/src/core/tools/bash.ts +4 -1
  639. package/packages/pi-coding-agent/src/core/tools/edit.ts +13 -1
  640. package/packages/pi-coding-agent/src/core/tools/find.ts +15 -6
  641. package/packages/pi-coding-agent/src/core/tools/grep.ts +13 -3
  642. package/packages/pi-coding-agent/src/core/tools/hashline-read.ts +4 -1
  643. package/packages/pi-coding-agent/src/core/tools/index.ts +8 -0
  644. package/packages/pi-coding-agent/src/core/tools/ls.ts +11 -3
  645. package/packages/pi-coding-agent/src/core/tools/read.ts +4 -1
  646. package/packages/pi-coding-agent/src/core/tools/spawn-shell-windows.test.ts +11 -72
  647. package/packages/pi-coding-agent/src/core/tools/tool-target-metadata.test.ts +127 -0
  648. package/packages/pi-coding-agent/src/core/tools/tool-target.ts +48 -0
  649. package/packages/pi-coding-agent/src/core/tools/write.ts +14 -2
  650. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.ts +7 -5
  651. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +217 -16
  652. package/packages/pi-coding-agent/src/modes/interactive/components/adaptive-layout.test.ts +59 -0
  653. package/packages/pi-coding-agent/src/modes/interactive/components/adaptive-layout.ts +160 -0
  654. package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +1 -0
  655. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +10 -9
  656. package/packages/pi-coding-agent/src/modes/interactive/components/settings-selector.ts +15 -0
  657. package/packages/pi-coding-agent/src/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.ts +71 -9
  658. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +299 -20
  659. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.test.ts +118 -1
  660. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +108 -3
  661. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +1 -0
  662. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-state.ts +1 -1
  663. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +101 -11
  664. package/packages/pi-coding-agent/src/modes/interactive/slash-command-handlers.test.ts +95 -0
  665. package/packages/pi-coding-agent/src/modes/interactive/slash-command-handlers.ts +24 -1
  666. package/packages/pi-coding-agent/src/modes/interactive/theme/theme-schema.ts +13 -0
  667. package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +32 -2
  668. package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +36 -27
  669. package/packages/pi-coding-agent/src/modes/interactive/tui-mode.test.ts +65 -0
  670. package/packages/pi-coding-agent/src/modes/interactive/tui-mode.ts +29 -0
  671. package/packages/pi-coding-agent/src/modes/rpc/rpc-mode.ts +1 -1
  672. package/packages/pi-coding-agent/src/modes/rpc/rpc-types.ts +3 -336
  673. package/packages/pi-coding-agent/src/resources/extensions/memory/storage-safety-guard.test.ts +31 -0
  674. package/packages/pi-coding-agent/src/resources/extensions/memory/storage.ts +3 -2
  675. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  676. package/packages/pi-tui/dist/__tests__/style.test.d.ts +2 -0
  677. package/packages/pi-tui/dist/__tests__/style.test.d.ts.map +1 -0
  678. package/packages/pi-tui/dist/__tests__/style.test.js +63 -0
  679. package/packages/pi-tui/dist/__tests__/style.test.js.map +1 -0
  680. package/packages/pi-tui/dist/__tests__/tui.test.js +24 -3
  681. package/packages/pi-tui/dist/__tests__/tui.test.js.map +1 -1
  682. package/packages/pi-tui/dist/index.d.ts +1 -0
  683. package/packages/pi-tui/dist/index.d.ts.map +1 -1
  684. package/packages/pi-tui/dist/index.js +2 -0
  685. package/packages/pi-tui/dist/index.js.map +1 -1
  686. package/packages/pi-tui/dist/style.d.ts +41 -0
  687. package/packages/pi-tui/dist/style.d.ts.map +1 -0
  688. package/packages/pi-tui/dist/style.js +158 -0
  689. package/packages/pi-tui/dist/style.js.map +1 -0
  690. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  691. package/packages/pi-tui/dist/tui.js +19 -8
  692. package/packages/pi-tui/dist/tui.js.map +1 -1
  693. package/packages/pi-tui/package.json +1 -1
  694. package/packages/pi-tui/src/__tests__/style.test.ts +76 -0
  695. package/packages/pi-tui/src/__tests__/tui.test.ts +29 -3
  696. package/packages/pi-tui/src/index.ts +9 -0
  697. package/packages/pi-tui/src/style.ts +225 -0
  698. package/packages/pi-tui/src/tui.ts +21 -8
  699. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  700. package/packages/rpc-client/README.md +10 -3
  701. package/packages/rpc-client/dist/index.d.ts +1 -1
  702. package/packages/rpc-client/dist/index.d.ts.map +1 -1
  703. package/packages/rpc-client/dist/index.js.map +1 -1
  704. package/packages/rpc-client/dist/rpc-client.d.ts +2 -6
  705. package/packages/rpc-client/dist/rpc-client.d.ts.map +1 -1
  706. package/packages/rpc-client/dist/rpc-client.js.map +1 -1
  707. package/packages/rpc-client/dist/rpc-types.d.ts +1 -565
  708. package/packages/rpc-client/dist/rpc-types.d.ts.map +1 -1
  709. package/packages/rpc-client/dist/rpc-types.js +3 -11
  710. package/packages/rpc-client/dist/rpc-types.js.map +1 -1
  711. package/packages/rpc-client/package.json +4 -1
  712. package/packages/rpc-client/src/index.ts +1 -1
  713. package/packages/rpc-client/src/rpc-client.ts +3 -6
  714. package/packages/rpc-client/src/rpc-types.ts +3 -398
  715. package/packages/rpc-client/tsconfig.tsbuildinfo +1 -1
  716. package/pkg/dist/modes/interactive/theme/theme-schema.d.ts +12 -0
  717. package/pkg/dist/modes/interactive/theme/theme-schema.d.ts.map +1 -1
  718. package/pkg/dist/modes/interactive/theme/theme-schema.js +13 -0
  719. package/pkg/dist/modes/interactive/theme/theme-schema.js.map +1 -1
  720. package/pkg/dist/modes/interactive/theme/theme.d.ts +1 -1
  721. package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  722. package/pkg/dist/modes/interactive/theme/theme.js +18 -1
  723. package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
  724. package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -1
  725. package/pkg/dist/modes/interactive/theme/themes.js +36 -27
  726. package/pkg/dist/modes/interactive/theme/themes.js.map +1 -1
  727. package/pkg/package.json +1 -1
  728. package/src/resources/GSD-WORKFLOW.md +2 -2
  729. package/src/resources/extensions/claude-code-cli/readiness.ts +25 -7
  730. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +42 -3
  731. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +67 -0
  732. package/src/resources/extensions/github-sync/sync.ts +8 -1
  733. package/src/resources/extensions/github-sync/templates.ts +93 -88
  734. package/src/resources/extensions/github-sync/tests/inline-code.test.ts +66 -0
  735. package/src/resources/extensions/github-sync/tests/sync-source.test.ts +6 -18
  736. package/src/resources/extensions/github-sync/tests/templates.test.ts +10 -2
  737. package/src/resources/extensions/gsd/auto/contracts.ts +19 -2
  738. package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +72 -0
  739. package/src/resources/extensions/gsd/auto/loop-deps.ts +11 -11
  740. package/src/resources/extensions/gsd/auto/loop.ts +540 -602
  741. package/src/resources/extensions/gsd/auto/orchestrator.ts +52 -4
  742. package/src/resources/extensions/gsd/auto/phases.ts +427 -220
  743. package/src/resources/extensions/gsd/auto/resolve.ts +42 -1
  744. package/src/resources/extensions/gsd/auto/run-unit.ts +52 -44
  745. package/src/resources/extensions/gsd/auto/session.ts +9 -1
  746. package/src/resources/extensions/gsd/auto/types.ts +3 -0
  747. package/src/resources/extensions/gsd/auto/unit-runner-events.ts +15 -0
  748. package/src/resources/extensions/gsd/auto/workflow-custom-engine-dispatch-outcome.ts +28 -0
  749. package/src/resources/extensions/gsd/auto/workflow-custom-engine-iteration.ts +52 -0
  750. package/src/resources/extensions/gsd/auto/workflow-custom-engine-reconcile-outcome.ts +58 -0
  751. package/src/resources/extensions/gsd/auto/workflow-custom-engine-reconcile.ts +71 -0
  752. package/src/resources/extensions/gsd/auto/workflow-custom-engine-retry.ts +90 -0
  753. package/src/resources/extensions/gsd/auto/workflow-custom-engine-verify-outcome.ts +50 -0
  754. package/src/resources/extensions/gsd/auto/workflow-dispatch-claim.ts +159 -0
  755. package/src/resources/extensions/gsd/auto/workflow-dispatch-ledger.ts +45 -0
  756. package/src/resources/extensions/gsd/auto/workflow-iteration-completion.ts +26 -0
  757. package/src/resources/extensions/gsd/auto/workflow-journal-reporter.ts +33 -0
  758. package/src/resources/extensions/gsd/auto/workflow-kernel.ts +520 -0
  759. package/src/resources/extensions/gsd/auto/workflow-memory-pressure.ts +58 -0
  760. package/src/resources/extensions/gsd/auto/workflow-phase-reporter.ts +22 -0
  761. package/src/resources/extensions/gsd/auto/workflow-session-lock.ts +68 -0
  762. package/src/resources/extensions/gsd/auto/workflow-sidecar-iteration.ts +46 -0
  763. package/src/resources/extensions/gsd/auto/workflow-sidecar-queue.ts +46 -0
  764. package/src/resources/extensions/gsd/auto/workflow-turn-reporter.ts +68 -0
  765. package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +89 -0
  766. package/src/resources/extensions/gsd/auto/workflow-worker-heartbeat.ts +51 -0
  767. package/src/resources/extensions/gsd/auto-dashboard.ts +81 -8
  768. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +8 -34
  769. package/src/resources/extensions/gsd/auto-dispatch.ts +33 -0
  770. package/src/resources/extensions/gsd/auto-post-unit.ts +134 -90
  771. package/src/resources/extensions/gsd/auto-prompts.ts +398 -19
  772. package/src/resources/extensions/gsd/auto-recovery.ts +207 -7
  773. package/src/resources/extensions/gsd/auto-start.ts +326 -25
  774. package/src/resources/extensions/gsd/auto-supervisor.ts +7 -0
  775. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +2 -2
  776. package/src/resources/extensions/gsd/auto-verification.ts +5 -1
  777. package/src/resources/extensions/gsd/auto-worktree.ts +344 -396
  778. package/src/resources/extensions/gsd/auto.ts +336 -89
  779. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +162 -11
  780. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +56 -37
  781. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +36 -10
  782. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +32 -19
  783. package/src/resources/extensions/gsd/bootstrap/journal-tools.ts +5 -1
  784. package/src/resources/extensions/gsd/bootstrap/memory-tools.ts +7 -4
  785. package/src/resources/extensions/gsd/bootstrap/query-tools.ts +6 -3
  786. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +1 -1
  787. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +406 -57
  788. package/src/resources/extensions/gsd/bootstrap/sanitize-complete-milestone.ts +4 -0
  789. package/src/resources/extensions/gsd/bootstrap/system-context.ts +90 -22
  790. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +153 -2
  791. package/src/resources/extensions/gsd/clean-root-preflight.ts +72 -9
  792. package/src/resources/extensions/gsd/commands/dispatcher.ts +6 -0
  793. package/src/resources/extensions/gsd/commands/handlers/ops.ts +4 -2
  794. package/src/resources/extensions/gsd/commands-config.ts +1 -1
  795. package/src/resources/extensions/gsd/commands-eval-review.ts +2 -2
  796. package/src/resources/extensions/gsd/commands-extract-learnings.ts +17 -12
  797. package/src/resources/extensions/gsd/commands-handlers.ts +34 -15
  798. package/src/resources/extensions/gsd/commands-ship.ts +24 -51
  799. package/src/resources/extensions/gsd/commands-workflow-templates.ts +13 -0
  800. package/src/resources/extensions/gsd/component-loader.ts +5 -11
  801. package/src/resources/extensions/gsd/context-budget.ts +44 -2
  802. package/src/resources/extensions/gsd/crash-recovery.ts +67 -10
  803. package/src/resources/extensions/gsd/custom-workflow-engine.ts +29 -0
  804. package/src/resources/extensions/gsd/dashboard-overlay.ts +1 -1
  805. package/src/resources/extensions/gsd/db/unit-dispatches.ts +107 -0
  806. package/src/resources/extensions/gsd/db-adapter.ts +75 -0
  807. package/src/resources/extensions/gsd/db-base-schema.ts +385 -0
  808. package/src/resources/extensions/gsd/db-connection-cache.ts +45 -0
  809. package/src/resources/extensions/gsd/db-coordination-schema.ts +109 -0
  810. package/src/resources/extensions/gsd/db-decision-requirement-rows.ts +77 -0
  811. package/src/resources/extensions/gsd/db-gate-rows.ts +19 -0
  812. package/src/resources/extensions/gsd/db-lightweight-query-rows.ts +50 -0
  813. package/src/resources/extensions/gsd/db-memory-fts-schema.ts +66 -0
  814. package/src/resources/extensions/gsd/db-migration-backup.ts +34 -0
  815. package/src/resources/extensions/gsd/db-migration-steps.ts +459 -0
  816. package/src/resources/extensions/gsd/db-milestone-artifact-rows.ts +70 -0
  817. package/src/resources/extensions/gsd/db-open-state.ts +47 -0
  818. package/src/resources/extensions/gsd/db-provider.ts +148 -0
  819. package/src/resources/extensions/gsd/db-runtime-kv-schema.ts +30 -0
  820. package/src/resources/extensions/gsd/db-schema-metadata.ts +33 -0
  821. package/src/resources/extensions/gsd/db-task-slice-rows.ts +146 -0
  822. package/src/resources/extensions/gsd/db-transaction.ts +76 -0
  823. package/src/resources/extensions/gsd/db-verification-evidence-rows.ts +14 -0
  824. package/src/resources/extensions/gsd/db-verification-evidence-schema.ts +22 -0
  825. package/src/resources/extensions/gsd/detection.ts +128 -0
  826. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +3 -0
  827. package/src/resources/extensions/gsd/escalation.ts +3 -1
  828. package/src/resources/extensions/gsd/git-service.ts +87 -10
  829. package/src/resources/extensions/gsd/graph.ts +12 -5
  830. package/src/resources/extensions/gsd/gsd-db.ts +399 -1677
  831. package/src/resources/extensions/gsd/guided-flow.ts +175 -55
  832. package/src/resources/extensions/gsd/health-widget.ts +3 -0
  833. package/src/resources/extensions/gsd/init-wizard.ts +5 -1
  834. package/src/resources/extensions/gsd/legacy-telemetry.ts +99 -0
  835. package/src/resources/extensions/gsd/markdown-renderer.ts +4 -1
  836. package/src/resources/extensions/gsd/memory-store.ts +77 -12
  837. package/src/resources/extensions/gsd/migrate/command.ts +47 -1
  838. package/src/resources/extensions/gsd/migration-auto-check.ts +129 -0
  839. package/src/resources/extensions/gsd/model-router.ts +10 -6
  840. package/src/resources/extensions/gsd/native-git-bridge.ts +39 -6
  841. package/src/resources/extensions/gsd/notification-widget.ts +25 -4
  842. package/src/resources/extensions/gsd/orphan-stash-audit.ts +117 -0
  843. package/src/resources/extensions/gsd/parallel-orchestrator.ts +13 -3
  844. package/src/resources/extensions/gsd/planning-path-scope.ts +35 -0
  845. package/src/resources/extensions/gsd/post-execution-checks.ts +4 -1
  846. package/src/resources/extensions/gsd/pr-evidence.ts +182 -0
  847. package/src/resources/extensions/gsd/pre-execution-checks.ts +27 -1
  848. package/src/resources/extensions/gsd/preferences-types.ts +1 -1
  849. package/src/resources/extensions/gsd/process-task-path.ts +81 -0
  850. package/src/resources/extensions/gsd/prompt-loader.ts +36 -7
  851. package/src/resources/extensions/gsd/prompts/complete-milestone.md +41 -35
  852. package/src/resources/extensions/gsd/prompts/complete-slice.md +23 -34
  853. package/src/resources/extensions/gsd/prompts/discuss-headless.md +50 -96
  854. package/src/resources/extensions/gsd/prompts/discuss.md +81 -181
  855. package/src/resources/extensions/gsd/prompts/execute-task.md +42 -67
  856. package/src/resources/extensions/gsd/prompts/forensics.md +41 -84
  857. package/src/resources/extensions/gsd/prompts/guided-discuss-milestone.md +29 -39
  858. package/src/resources/extensions/gsd/prompts/guided-discuss-project.md +30 -65
  859. package/src/resources/extensions/gsd/prompts/guided-discuss-requirements.md +25 -52
  860. package/src/resources/extensions/gsd/prompts/guided-discuss-slice.md +36 -36
  861. package/src/resources/extensions/gsd/prompts/guided-research-project.md +20 -38
  862. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +1 -1
  863. package/src/resources/extensions/gsd/prompts/plan-milestone.md +47 -59
  864. package/src/resources/extensions/gsd/prompts/plan-slice.md +25 -87
  865. package/src/resources/extensions/gsd/prompts/queue.md +46 -53
  866. package/src/resources/extensions/gsd/prompts/quick-task.md +1 -5
  867. package/src/resources/extensions/gsd/prompts/refine-slice.md +23 -23
  868. package/src/resources/extensions/gsd/prompts/replan-slice.md +2 -2
  869. package/src/resources/extensions/gsd/prompts/research-slice.md +23 -23
  870. package/src/resources/extensions/gsd/prompts/rethink.md +10 -10
  871. package/src/resources/extensions/gsd/prompts/system.md +65 -107
  872. package/src/resources/extensions/gsd/prompts/triage-captures.md +15 -15
  873. package/src/resources/extensions/gsd/prompts/validate-milestone.md +24 -24
  874. package/src/resources/extensions/gsd/prompts/worktree-merge.md +35 -35
  875. package/src/resources/extensions/gsd/quick.ts +37 -2
  876. package/src/resources/extensions/gsd/recovery-classification.ts +122 -0
  877. package/src/resources/extensions/gsd/safety/evidence-collector.ts +11 -2
  878. package/src/resources/extensions/gsd/slice-cadence.ts +49 -2
  879. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +23 -9
  880. package/src/resources/extensions/gsd/state-reconciliation.ts +57 -0
  881. package/src/resources/extensions/gsd/state.ts +6 -3
  882. package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +59 -89
  883. package/src/resources/extensions/gsd/tests/artifact-retry-cap.test.ts +47 -172
  884. package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +0 -35
  885. package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +7 -1
  886. package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +133 -9
  887. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +660 -40
  888. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +80 -59
  889. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +119 -2
  890. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +3 -47
  891. package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +76 -18
  892. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +175 -11
  893. package/src/resources/extensions/gsd/tests/auto-pr-bugs.test.ts +54 -76
  894. package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +67 -26
  895. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +184 -2
  896. package/src/resources/extensions/gsd/tests/auto-remediate-slice-status.test.ts +32 -30
  897. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +32 -128
  898. package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +20 -54
  899. package/src/resources/extensions/gsd/tests/auto-start-cold-db-bootstrap.test.ts +20 -30
  900. package/src/resources/extensions/gsd/tests/auto-start-index-lock.test.ts +17 -29
  901. package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +142 -0
  902. package/src/resources/extensions/gsd/tests/auto-start-time-persistence.test.ts +21 -39
  903. package/src/resources/extensions/gsd/tests/auto-start-worktree-db-path.test.ts +15 -24
  904. package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +44 -29
  905. package/src/resources/extensions/gsd/tests/auto-warning-noise-regression.test.ts +39 -51
  906. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +159 -213
  907. package/src/resources/extensions/gsd/tests/bootstrap-derive-state-db-open.test.ts +15 -32
  908. package/src/resources/extensions/gsd/tests/browser-teardown.test.ts +0 -41
  909. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +97 -2
  910. package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +34 -27
  911. package/src/resources/extensions/gsd/tests/cmux.test.ts +51 -53
  912. package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +39 -61
  913. package/src/resources/extensions/gsd/tests/commands-config.test.ts +26 -19
  914. package/src/resources/extensions/gsd/tests/commands-eval-review.test.ts +2 -2
  915. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +9 -0
  916. package/src/resources/extensions/gsd/tests/commands-ship-eval-warn.test.ts +3 -2
  917. package/src/resources/extensions/gsd/tests/compaction-snapshot.test.ts +14 -1
  918. package/src/resources/extensions/gsd/tests/complete-milestone-excerpt.test.ts +31 -0
  919. package/src/resources/extensions/gsd/tests/complete-milestone-prompt-rendering.test.ts +47 -0
  920. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +159 -5
  921. package/src/resources/extensions/gsd/tests/complete-slice-composer.test.ts +3 -2
  922. package/src/resources/extensions/gsd/tests/complete-task-normalize-lists.test.ts +29 -33
  923. package/src/resources/extensions/gsd/tests/completed-units-metrics-sync.test.ts +45 -108
  924. package/src/resources/extensions/gsd/tests/component-loader.test.ts +2 -9
  925. package/src/resources/extensions/gsd/tests/context-budget.test.ts +10 -1
  926. package/src/resources/extensions/gsd/tests/context-store.test.ts +7 -1
  927. package/src/resources/extensions/gsd/tests/crash-handler-secondary.test.ts +90 -31
  928. package/src/resources/extensions/gsd/tests/crash-recovery-via-db.test.ts +22 -0
  929. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +162 -10
  930. package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +139 -0
  931. package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +50 -0
  932. package/src/resources/extensions/gsd/tests/cwd-fallback-hardening.test.ts +138 -0
  933. package/src/resources/extensions/gsd/tests/dashboard-custom-engine.test.ts +4 -68
  934. package/src/resources/extensions/gsd/tests/db-adapter.test.ts +82 -0
  935. package/src/resources/extensions/gsd/tests/db-base-schema.test.ts +62 -0
  936. package/src/resources/extensions/gsd/tests/db-connection-cache.test.ts +60 -0
  937. package/src/resources/extensions/gsd/tests/db-coordination-schema.test.ts +39 -0
  938. package/src/resources/extensions/gsd/tests/db-decision-requirement-rows.test.ts +135 -0
  939. package/src/resources/extensions/gsd/tests/db-gate-rows.test.ts +53 -0
  940. package/src/resources/extensions/gsd/tests/db-lightweight-query-rows.test.ts +45 -0
  941. package/src/resources/extensions/gsd/tests/db-memory-fts-schema.test.ts +86 -0
  942. package/src/resources/extensions/gsd/tests/db-migration-backup.test.ts +105 -0
  943. package/src/resources/extensions/gsd/tests/db-migration-steps.integration.test.ts +428 -0
  944. package/src/resources/extensions/gsd/tests/db-migration-steps.test.ts +159 -0
  945. package/src/resources/extensions/gsd/tests/db-milestone-artifact-rows.test.ts +53 -0
  946. package/src/resources/extensions/gsd/tests/db-open-state.test.ts +56 -0
  947. package/src/resources/extensions/gsd/tests/db-provider.test.ts +105 -0
  948. package/src/resources/extensions/gsd/tests/db-runtime-kv-schema.test.ts +37 -0
  949. package/src/resources/extensions/gsd/tests/db-schema-metadata.test.ts +115 -0
  950. package/src/resources/extensions/gsd/tests/db-task-slice-rows.test.ts +128 -0
  951. package/src/resources/extensions/gsd/tests/db-transaction.test.ts +110 -0
  952. package/src/resources/extensions/gsd/tests/db-verification-evidence-schema.test.ts +76 -0
  953. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +6 -11
  954. package/src/resources/extensions/gsd/tests/deferred-milestone-dir-4996.test.ts +14 -65
  955. package/src/resources/extensions/gsd/tests/detection.test.ts +140 -0
  956. package/src/resources/extensions/gsd/tests/discuss-headless-rendering.test.ts +37 -0
  957. package/src/resources/extensions/gsd/tests/discuss-tool-scoping.test.ts +44 -37
  958. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +58 -40
  959. package/src/resources/extensions/gsd/tests/dispatch-guard-closed-status.test.ts +25 -15
  960. package/src/resources/extensions/gsd/tests/dispatch-rule-coverage.test.ts +313 -0
  961. package/src/resources/extensions/gsd/tests/dispatcher-stuck-planning.test.ts +35 -17
  962. package/src/resources/extensions/gsd/tests/error-success-mask.test.ts +16 -21
  963. package/src/resources/extensions/gsd/tests/est-annotation-timeout.test.ts +15 -82
  964. package/src/resources/extensions/gsd/tests/exec-history.test.ts +15 -0
  965. package/src/resources/extensions/gsd/tests/exec-sandbox.test.ts +65 -0
  966. package/src/resources/extensions/gsd/tests/execute-task-rendering.test.ts +62 -0
  967. package/src/resources/extensions/gsd/tests/fast-forward-reused-milestone-branch.test.ts +219 -0
  968. package/src/resources/extensions/gsd/tests/finalize-survivor-branch.test.ts +151 -0
  969. package/src/resources/extensions/gsd/tests/fixtures/pr-body/commands-ship-basic.md +52 -0
  970. package/src/resources/extensions/gsd/tests/fixtures/pr-body/commands-ship-empty-optionals.md +42 -0
  971. package/src/resources/extensions/gsd/tests/fixtures/pr-body/swarm-lane-no-blockers.md +55 -0
  972. package/src/resources/extensions/gsd/tests/fixtures/pr-body/swarm-lane-with-blockers.md +60 -0
  973. package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +2 -20
  974. package/src/resources/extensions/gsd/tests/forensics-prompt-rendering.test.ts +36 -0
  975. package/src/resources/extensions/gsd/tests/frontmatter-parse-noise.test.ts +18 -26
  976. package/src/resources/extensions/gsd/tests/graph-operations.test.ts +10 -0
  977. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +44 -0
  978. package/src/resources/extensions/gsd/tests/guided-discuss-milestone-prompt-rendering.test.ts +43 -0
  979. package/src/resources/extensions/gsd/tests/guided-discuss-project-prompt-rendering.test.ts +41 -0
  980. package/src/resources/extensions/gsd/tests/guided-discuss-requirements-prompt-rendering.test.ts +45 -0
  981. package/src/resources/extensions/gsd/tests/has-pending-deep-stage.test.ts +33 -1
  982. package/src/resources/extensions/gsd/tests/init-skip-git.test.ts +9 -12
  983. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +77 -0
  984. package/src/resources/extensions/gsd/tests/integration/commands-eval-review.integration.test.ts +4 -2
  985. package/src/resources/extensions/gsd/tests/integration/git-locale.test.ts +31 -20
  986. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +66 -0
  987. package/src/resources/extensions/gsd/tests/integration/milestone-transition-worktree.test.ts +0 -47
  988. package/src/resources/extensions/gsd/tests/integration/state-machine-live-validation.test.ts +5 -3
  989. package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +60 -202
  990. package/src/resources/extensions/gsd/tests/isolation-none-branch-guard.test.ts +13 -56
  991. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +248 -10
  992. package/src/resources/extensions/gsd/tests/journal-query-tool.test.ts +32 -0
  993. package/src/resources/extensions/gsd/tests/knowledge.test.ts +47 -0
  994. package/src/resources/extensions/gsd/tests/lazy-pi-tui-import.test.ts +44 -6
  995. package/src/resources/extensions/gsd/tests/legacy-component-format-telemetry.test.ts +62 -0
  996. package/src/resources/extensions/gsd/tests/legacy-telemetry.test.ts +144 -0
  997. package/src/resources/extensions/gsd/tests/memory-decay-factor.test.ts +90 -0
  998. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +53 -43
  999. package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +37 -7
  1000. package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +48 -0
  1001. package/src/resources/extensions/gsd/tests/migration-auto-check.test.ts +127 -0
  1002. package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +267 -0
  1003. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +88 -98
  1004. package/src/resources/extensions/gsd/tests/model-router.test.ts +33 -12
  1005. package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +70 -278
  1006. package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +34 -2
  1007. package/src/resources/extensions/gsd/tests/needs-remediation-revalidation.test.ts +37 -30
  1008. package/src/resources/extensions/gsd/tests/note-captures-executed.test.ts +32 -28
  1009. package/src/resources/extensions/gsd/tests/notification-store.test.ts +8 -0
  1010. package/src/resources/extensions/gsd/tests/notification-widget.test.ts +40 -1
  1011. package/src/resources/extensions/gsd/tests/originalbase-path-comparison.test.ts +44 -9
  1012. package/src/resources/extensions/gsd/tests/orphan-merge-bootstrap.test.ts +144 -0
  1013. package/src/resources/extensions/gsd/tests/orphan-stash-audit.test.ts +201 -0
  1014. package/src/resources/extensions/gsd/tests/parallel-orchestrator-fast-forward.test.ts +113 -0
  1015. package/src/resources/extensions/gsd/tests/phantom-ghost-detection.test.ts +24 -37
  1016. package/src/resources/extensions/gsd/tests/phantom-milestone-default-queued.test.ts +9 -24
  1017. package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +95 -75
  1018. package/src/resources/extensions/gsd/tests/plan-milestone-rendering.test.ts +45 -0
  1019. package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +65 -16
  1020. package/src/resources/extensions/gsd/tests/plan-slice.test.ts +50 -0
  1021. package/src/resources/extensions/gsd/tests/plan-task.test.ts +21 -0
  1022. package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +36 -22
  1023. package/src/resources/extensions/gsd/tests/pr-evidence-equivalence.test.ts +102 -0
  1024. package/src/resources/extensions/gsd/tests/pr-evidence-hardening.test.ts +165 -0
  1025. package/src/resources/extensions/gsd/tests/pr-evidence.test.ts +79 -0
  1026. package/src/resources/extensions/gsd/tests/pre-exec-backtick-strip.test.ts +36 -30
  1027. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +45 -5
  1028. package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +74 -4
  1029. package/src/resources/extensions/gsd/tests/preferences-worktree-sync.test.ts +20 -22
  1030. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +130 -32
  1031. package/src/resources/extensions/gsd/tests/process-task-path.test.ts +51 -0
  1032. package/src/resources/extensions/gsd/tests/project-root-cwd-crash.test.ts +18 -36
  1033. package/src/resources/extensions/gsd/tests/projection-no-plan-overwrite.test.ts +35 -73
  1034. package/src/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +76 -138
  1035. package/src/resources/extensions/gsd/tests/prompt-duplication-cuts.test.ts +230 -0
  1036. package/src/resources/extensions/gsd/tests/prompt-path-audit.test.ts +40 -0
  1037. package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +70 -91
  1038. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +59 -161
  1039. package/src/resources/extensions/gsd/tests/query-tools-db-open.test.ts +33 -29
  1040. package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +22 -196
  1041. package/src/resources/extensions/gsd/tests/queue-prompt-rendering.test.ts +37 -0
  1042. package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +23 -93
  1043. package/src/resources/extensions/gsd/tests/quick-external-gsd.test.ts +40 -0
  1044. package/src/resources/extensions/gsd/tests/quick-turn-end-cleanup.test.ts +50 -79
  1045. package/src/resources/extensions/gsd/tests/reassess-default-optin.test.ts +27 -13
  1046. package/src/resources/extensions/gsd/tests/remote-questions.test.ts +151 -251
  1047. package/src/resources/extensions/gsd/tests/resource-loader-import-path.test.ts +41 -29
  1048. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +58 -69
  1049. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +32 -164
  1050. package/src/resources/extensions/gsd/tests/right-sized-workflow-prompts.test.ts +192 -0
  1051. package/src/resources/extensions/gsd/tests/run-uat-replay-cap.test.ts +57 -41
  1052. package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +91 -0
  1053. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +29 -0
  1054. package/src/resources/extensions/gsd/tests/schema-v27-v28-sequence.test.ts +156 -0
  1055. package/src/resources/extensions/gsd/tests/select-resumable-milestone.test.ts +96 -0
  1056. package/src/resources/extensions/gsd/tests/session-model-override.test.ts +14 -9
  1057. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +77 -0
  1058. package/src/resources/extensions/gsd/tests/session-switch-abort-misclassification.test.ts +222 -0
  1059. package/src/resources/extensions/gsd/tests/show-config-command.test.ts +44 -42
  1060. package/src/resources/extensions/gsd/tests/signal-handlers.test.ts +27 -0
  1061. package/src/resources/extensions/gsd/tests/skip-slice-state-rebuild.test.ts +56 -24
  1062. package/src/resources/extensions/gsd/tests/skipped-validation-db-atomicity.test.ts +51 -11
  1063. package/src/resources/extensions/gsd/tests/slice-cadence.test.ts +23 -0
  1064. package/src/resources/extensions/gsd/tests/slice-context-injection.test.ts +66 -50
  1065. package/src/resources/extensions/gsd/tests/slice-parallel-orchestrator.test.ts +68 -107
  1066. package/src/resources/extensions/gsd/tests/slice-sequence-insert.test.ts +115 -42
  1067. package/src/resources/extensions/gsd/tests/smart-entry-complete.test.ts +21 -59
  1068. package/src/resources/extensions/gsd/tests/smart-entry-draft.test.ts +25 -116
  1069. package/src/resources/extensions/gsd/tests/sqlite-unavailable-gate.test.ts +21 -57
  1070. package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +29 -76
  1071. package/src/resources/extensions/gsd/tests/stale-lockfile-recovery.test.ts +33 -24
  1072. package/src/resources/extensions/gsd/tests/stale-slice-rows.test.ts +39 -30
  1073. package/src/resources/extensions/gsd/tests/stalled-tool-recovery.test.ts +49 -1
  1074. package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +101 -2
  1075. package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +6 -4
  1076. package/src/resources/extensions/gsd/tests/status-db-open.test.ts +35 -40
  1077. package/src/resources/extensions/gsd/tests/stop-auto-merge-back.test.ts +48 -46
  1078. package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +14 -102
  1079. package/src/resources/extensions/gsd/tests/subagent-model-dispatch.test.ts +78 -232
  1080. package/src/resources/extensions/gsd/tests/sync-worktree-skip-current.test.ts +32 -35
  1081. package/src/resources/extensions/gsd/tests/system-context-memory.test.ts +112 -0
  1082. package/src/resources/extensions/gsd/tests/system-context-message-routing.test.ts +7 -9
  1083. package/src/resources/extensions/gsd/tests/token-profile.test.ts +84 -309
  1084. package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +291 -0
  1085. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +32 -9
  1086. package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +134 -341
  1087. package/src/resources/extensions/gsd/tests/tui-header-lifecycle.test.ts +210 -0
  1088. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +140 -8
  1089. package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +8 -25
  1090. package/src/resources/extensions/gsd/tests/unit-dispatches.test.ts +80 -1
  1091. package/src/resources/extensions/gsd/tests/unit-runtime.test.ts +37 -0
  1092. package/src/resources/extensions/gsd/tests/unstructured-continue-context-injection.test.ts +5 -99
  1093. package/src/resources/extensions/gsd/tests/uok-kernel-path.test.ts +12 -0
  1094. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +43 -36
  1095. package/src/resources/extensions/gsd/tests/visualizer-data.test.ts +84 -444
  1096. package/src/resources/extensions/gsd/tests/workflow-custom-engine-dispatch-outcome.test.ts +55 -0
  1097. package/src/resources/extensions/gsd/tests/workflow-custom-engine-iteration.test.ts +93 -0
  1098. package/src/resources/extensions/gsd/tests/workflow-custom-engine-reconcile-outcome.test.ts +108 -0
  1099. package/src/resources/extensions/gsd/tests/workflow-custom-engine-reconcile.test.ts +146 -0
  1100. package/src/resources/extensions/gsd/tests/workflow-custom-engine-retry.test.ts +136 -0
  1101. package/src/resources/extensions/gsd/tests/workflow-custom-engine-verify-outcome.test.ts +95 -0
  1102. package/src/resources/extensions/gsd/tests/workflow-dispatch-claim.test.ts +300 -0
  1103. package/src/resources/extensions/gsd/tests/workflow-dispatch-ledger.test.ts +82 -0
  1104. package/src/resources/extensions/gsd/tests/workflow-iteration-completion.test.ts +44 -0
  1105. package/src/resources/extensions/gsd/tests/workflow-journal-reporter.test.ts +49 -0
  1106. package/src/resources/extensions/gsd/tests/workflow-kernel.test.ts +607 -0
  1107. package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +44 -189
  1108. package/src/resources/extensions/gsd/tests/workflow-logger.test.ts +20 -4
  1109. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +2 -57
  1110. package/src/resources/extensions/gsd/tests/workflow-memory-pressure.test.ts +71 -0
  1111. package/src/resources/extensions/gsd/tests/workflow-phase-reporter.test.ts +40 -0
  1112. package/src/resources/extensions/gsd/tests/workflow-protocol-excerpt.test.ts +99 -0
  1113. package/src/resources/extensions/gsd/tests/workflow-session-lock.test.ts +135 -0
  1114. package/src/resources/extensions/gsd/tests/workflow-sidecar-iteration.test.ts +110 -0
  1115. package/src/resources/extensions/gsd/tests/workflow-sidecar-queue.test.ts +116 -0
  1116. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +21 -0
  1117. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +35 -0
  1118. package/src/resources/extensions/gsd/tests/workflow-turn-reporter.test.ts +87 -0
  1119. package/src/resources/extensions/gsd/tests/workflow-unit-dispatch.test.ts +160 -0
  1120. package/src/resources/extensions/gsd/tests/workflow-worker-heartbeat.test.ts +154 -0
  1121. package/src/resources/extensions/gsd/tests/working-output-messages.test.ts +93 -0
  1122. package/src/resources/extensions/gsd/tests/worktree-db-same-file.test.ts +21 -44
  1123. package/src/resources/extensions/gsd/tests/worktree-expected-warnings.test.ts +27 -26
  1124. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +38 -6
  1125. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +50 -31
  1126. package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +434 -0
  1127. package/src/resources/extensions/gsd/tests/worktree-main-branch.test.ts +20 -18
  1128. package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +7 -0
  1129. package/src/resources/extensions/gsd/tests/worktree-nested-git-safety.test.ts +9 -2
  1130. package/src/resources/extensions/gsd/tests/worktree-path-injection.test.ts +22 -19
  1131. package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +66 -0
  1132. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +373 -76
  1133. package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +327 -0
  1134. package/src/resources/extensions/gsd/tests/worktree-state-projection.test.ts +120 -0
  1135. package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +17 -33
  1136. package/src/resources/extensions/gsd/tests/worktree-write-gate.test.ts +179 -0
  1137. package/src/resources/extensions/gsd/tests/write-gate.test.ts +40 -1
  1138. package/src/resources/extensions/gsd/tests/zero-slice-roadmap-guided.test.ts +19 -13
  1139. package/src/resources/extensions/gsd/tool-contract.ts +82 -0
  1140. package/src/resources/extensions/gsd/tools/complete-milestone.ts +29 -24
  1141. package/src/resources/extensions/gsd/tools/complete-task.ts +5 -2
  1142. package/src/resources/extensions/gsd/tools/context-mode-tool-result.ts +25 -0
  1143. package/src/resources/extensions/gsd/tools/exec-search-tool.ts +7 -7
  1144. package/src/resources/extensions/gsd/tools/exec-tool.ts +4 -23
  1145. package/src/resources/extensions/gsd/tools/memory-tools.ts +1 -0
  1146. package/src/resources/extensions/gsd/tools/plan-slice.ts +13 -0
  1147. package/src/resources/extensions/gsd/tools/plan-task.ts +10 -0
  1148. package/src/resources/extensions/gsd/tools/resume-tool.ts +7 -7
  1149. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +7 -2
  1150. package/src/resources/extensions/gsd/unit-context-composer.ts +19 -4
  1151. package/src/resources/extensions/gsd/unit-runtime.ts +25 -0
  1152. package/src/resources/extensions/gsd/uok/kernel.ts +10 -3
  1153. package/src/resources/extensions/gsd/uok/plan-v2.ts +5 -1
  1154. package/src/resources/extensions/gsd/workflow-logger.ts +13 -13
  1155. package/src/resources/extensions/gsd/workflow-manifest.ts +6 -15
  1156. package/src/resources/extensions/gsd/workflow-projections.ts +5 -1
  1157. package/src/resources/extensions/gsd/workflow-protocol.ts +160 -0
  1158. package/src/resources/extensions/gsd/workflow-templates.ts +11 -0
  1159. package/src/resources/extensions/gsd/working-output-messages.ts +120 -0
  1160. package/src/resources/extensions/gsd/worktree-lifecycle.ts +1255 -0
  1161. package/src/resources/extensions/gsd/worktree-manager.ts +15 -4
  1162. package/src/resources/extensions/gsd/worktree-safety.ts +282 -0
  1163. package/src/resources/extensions/gsd/worktree-state-projection.ts +404 -0
  1164. package/src/resources/skills/create-gsd-extension/templates/templates.test.ts +86 -40
  1165. package/src/resources/skills/web-quality-audit/scripts/analyze.sh +0 -0
  1166. package/dist/resources/extensions/gsd/worktree-resolver.js +0 -733
  1167. package/dist/web/standalone/.next/server/chunks/6336.js +0 -1
  1168. package/dist/web/standalone/.next/static/chunks/8336.6f6f30e410419aff.js +0 -10
  1169. package/src/resources/extensions/gsd/tests/sync-layer-scope.test.ts +0 -434
  1170. package/src/resources/extensions/gsd/worktree-resolver.ts +0 -909
  1171. /package/dist/web/standalone/.next/static/{V-3Ehy4B24f9FCGiLPWIM → drLMkgfHQ8lzS229_HWYR}/_buildManifest.js +0 -0
  1172. /package/dist/web/standalone/.next/static/{V-3Ehy4B24f9FCGiLPWIM → drLMkgfHQ8lzS229_HWYR}/_ssgManifest.js +0 -0
@@ -1,32 +1,36 @@
1
1
  import assert from "node:assert/strict";
2
2
  import { describe, it } from "node:test";
3
- import { existsSync, readFileSync } from "node:fs";
4
- import { join } from "node:path";
3
+ import type { Model } from "../types.js";
4
+ import { buildAnthropicClientOptions } from "./anthropic.js";
5
5
 
6
- function resolveSourcePath(fileName: string): string {
7
- const localPath = join(import.meta.dirname, fileName);
8
- if (existsSync(localPath)) return localPath;
9
- return join(import.meta.dirname, "..", "..", "src", "providers", fileName);
6
+ function anthropicModel(overrides: Partial<Model<"anthropic-messages">> = {}): Model<"anthropic-messages"> {
7
+ return {
8
+ id: "claude-sonnet-4",
9
+ name: "Claude Sonnet 4",
10
+ api: "anthropic-messages",
11
+ provider: "anthropic",
12
+ baseUrl: "https://api.anthropic.com",
13
+ reasoning: true,
14
+ input: ["text"],
15
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
16
+ contextWindow: 200000,
17
+ maxTokens: 8192,
18
+ ...overrides,
19
+ };
10
20
  }
11
21
 
12
- const source = readFileSync(resolveSourcePath("anthropic.ts"), "utf-8");
13
-
14
22
  describe("anthropic bearer auth for custom providers (#3874)", () => {
15
23
  it("treats Bearer Authorization headers as authToken-capable providers", () => {
16
- assert.match(
17
- source,
18
- /usesAnthropicBearerAuth\(model\.provider\) \|\| hasBearerAuthorizationHeader\(model\)/,
19
- "custom providers with Authorization headers should opt into bearer auth",
20
- );
21
- assert.match(
22
- source,
23
- /apiKey: usesBearerAuth \? null : apiKey/,
24
- "bearer-auth providers should not send x-api-key",
25
- );
26
- assert.match(
27
- source,
28
- /authToken: usesBearerAuth \? apiKey : undefined/,
29
- "bearer-auth providers should send authToken instead",
24
+ const options = buildAnthropicClientOptions(
25
+ anthropicModel({
26
+ provider: "custom-anthropic-compatible",
27
+ headers: { Authorization: "Bearer upstream-token" },
28
+ }),
29
+ "request-token",
30
+ false,
30
31
  );
32
+
33
+ assert.equal(options.apiKey, null, "custom providers with Authorization headers should not send x-api-key");
34
+ assert.equal(options.authToken, "request-token", "custom providers with Authorization headers should use authToken");
31
35
  });
32
36
  });
@@ -71,14 +71,13 @@ function hasBearerAuthorizationHeader(model: Model<"anthropic-messages">): boole
71
71
  return typeof authHeader === "string" && authHeader.trim().toLowerCase().startsWith("bearer ");
72
72
  }
73
73
 
74
- async function createClient(
74
+ export function buildAnthropicClientOptions(
75
75
  model: Model<"anthropic-messages">,
76
76
  apiKey: string,
77
77
  interleavedThinking: boolean,
78
78
  optionsHeaders?: Record<string, string>,
79
79
  dynamicHeaders?: Record<string, string>,
80
- ): Promise<{ client: Anthropic; isOAuthToken: boolean }> {
81
- const AnthropicClass = await getAnthropicClass();
80
+ ) {
82
81
  // Adaptive thinking models (Opus 4.6, Sonnet 4.6) have interleaved thinking built-in.
83
82
  // The beta header is deprecated on Opus 4.6 and redundant on Sonnet 4.6, so skip it.
84
83
  const needsInterleavedBeta = interleavedThinking && !supportsAdaptiveThinking(model.id);
@@ -90,7 +89,7 @@ async function createClient(
90
89
  betaFeatures.push("interleaved-thinking-2025-05-14");
91
90
  }
92
91
 
93
- const client = new AnthropicClass({
92
+ return {
94
93
  apiKey: null,
95
94
  authToken: apiKey,
96
95
  baseURL: resolveAnthropicBaseUrl(model),
@@ -105,9 +104,7 @@ async function createClient(
105
104
  dynamicHeaders,
106
105
  optionsHeaders,
107
106
  ),
108
- });
109
-
110
- return { client, isOAuthToken: false };
107
+ };
111
108
  }
112
109
 
113
110
  // Skip beta headers for providers that don't support fine-grained-tool-streaming.
@@ -126,7 +123,7 @@ async function createClient(
126
123
  // API key auth (Anthropic OAuth removed per TOS compliance — use API keys or Claude CLI)
127
124
  // Some Anthropic-compatible providers require Bearer auth instead of x-api-key.
128
125
  const usesBearerAuth = usesAnthropicBearerAuth(model.provider) || hasBearerAuthorizationHeader(model);
129
- const client = new AnthropicClass({
126
+ return {
130
127
  apiKey: usesBearerAuth ? null : apiKey,
131
128
  authToken: usesBearerAuth ? apiKey : undefined,
132
129
  baseURL: resolveAnthropicBaseUrl(model),
@@ -140,8 +137,24 @@ async function createClient(
140
137
  model.headers,
141
138
  optionsHeaders,
142
139
  ),
143
- });
140
+ };
141
+ }
144
142
 
143
+ async function createClient(
144
+ model: Model<"anthropic-messages">,
145
+ apiKey: string,
146
+ interleavedThinking: boolean,
147
+ optionsHeaders?: Record<string, string>,
148
+ dynamicHeaders?: Record<string, string>,
149
+ ): Promise<{ client: Anthropic; isOAuthToken: boolean }> {
150
+ const AnthropicClass = await getAnthropicClass();
151
+ const client = new AnthropicClass(buildAnthropicClientOptions(
152
+ model,
153
+ apiKey,
154
+ interleavedThinking,
155
+ optionsHeaders,
156
+ dynamicHeaders,
157
+ ));
145
158
  return { client, isOAuthToken: false };
146
159
  }
147
160
 
@@ -0,0 +1,376 @@
1
+ /**
2
+ * GSD-2 fake LLM provider — deterministic JSONL replay for e2e tests.
3
+ *
4
+ * Activated only when `GSD_FAKE_LLM_TRANSCRIPT` env var is set. Reads a
5
+ * JSONL transcript file (one turn per line) and replays scripted responses
6
+ * sequentially. Each turn carries structural assertions about the incoming
7
+ * request — if the request shape drifts, the provider fails loudly so tests
8
+ * surface it instead of silently consuming wrong inputs.
9
+ *
10
+ * IMPORTANT: env var must be set BEFORE pi-ai is imported. Tests achieve
11
+ * this by setting it on the subprocess they spawn. In-process tests cannot
12
+ * mix fake and real providers in the same Node process.
13
+ *
14
+ * Transcript format (JSONL, one turn per line):
15
+ * {
16
+ * "turn": 1,
17
+ * "expect": {
18
+ * "modelId": "gsd-fake-model",
19
+ * "messageCount": 2, // optional, exact match
20
+ * "lastUserText": "do X", // optional, substring match
21
+ * "systemContains": ["..."], // optional, all must be present
22
+ * "toolNames": ["read_file"], // optional, exact set
23
+ * "hasToolResultFor": "read_file" // optional, last message is a toolResult for this name
24
+ * },
25
+ * "emit": { "kind": "text", "text": "...", "stopReason": "stop" }
26
+ * | { "kind": "tool_use", "calls": [...], "stopReason": "toolUse" }
27
+ * | { "kind": "error_429", "message": "rate limited", "retryAfterMs": 1000 }
28
+ * | { "kind": "malformed" }
29
+ * | { "kind": "timeout", "delayMs": 60000 }
30
+ * }
31
+ */
32
+
33
+ import { readFileSync } from "node:fs";
34
+ import type { ApiProvider } from "../api-registry.js";
35
+ import type {
36
+ AssistantMessage,
37
+ Context,
38
+ Model,
39
+ SimpleStreamOptions,
40
+ StreamOptions,
41
+ ToolCall,
42
+ UserMessage,
43
+ } from "../types.js";
44
+ import { AssistantMessageEventStream } from "../utils/event-stream.js";
45
+
46
+ export const FAKE_API = "fake" as const;
47
+
48
+ interface ExpectFields {
49
+ modelId?: string;
50
+ messageCount?: number;
51
+ lastUserText?: string;
52
+ systemContains?: string[];
53
+ toolNames?: string[];
54
+ hasToolResultFor?: string;
55
+ }
56
+
57
+ type EmitSpec =
58
+ | { kind: "text"; text: string; stopReason?: "stop" | "length" }
59
+ | {
60
+ kind: "tool_use";
61
+ calls: { id?: string; name: string; input: Record<string, unknown> }[];
62
+ stopReason?: "toolUse";
63
+ }
64
+ | { kind: "error_429"; message?: string; retryAfterMs?: number }
65
+ | { kind: "malformed"; message?: string }
66
+ | { kind: "timeout"; delayMs?: number };
67
+
68
+ interface TranscriptTurn {
69
+ turn: number;
70
+ expect?: ExpectFields;
71
+ emit: EmitSpec;
72
+ }
73
+
74
+ function parseTranscript(path: string): TranscriptTurn[] {
75
+ const raw = readFileSync(path, "utf8");
76
+ const lines = raw.split("\n").filter((l) => l.trim().length > 0);
77
+ const turns: TranscriptTurn[] = [];
78
+ for (const [i, line] of lines.entries()) {
79
+ try {
80
+ turns.push(JSON.parse(line));
81
+ } catch (err) {
82
+ throw new Error(
83
+ `fake-llm: failed to parse transcript ${path} line ${i + 1}: ${(err as Error).message}\n line: ${line}`,
84
+ );
85
+ }
86
+ }
87
+ return turns;
88
+ }
89
+
90
+ function lastUserMessage(ctx: Context): UserMessage | undefined {
91
+ for (let i = ctx.messages.length - 1; i >= 0; i--) {
92
+ const m = ctx.messages[i];
93
+ if (m.role === "user") return m;
94
+ }
95
+ return undefined;
96
+ }
97
+
98
+ function userText(m: UserMessage): string {
99
+ if (typeof m.content === "string") return m.content;
100
+ return m.content
101
+ .filter((c): c is { type: "text"; text: string } => c.type === "text")
102
+ .map((c) => c.text)
103
+ .join("\n");
104
+ }
105
+
106
+ function checkExpectations(model: Model<typeof FAKE_API>, ctx: Context, turn: TranscriptTurn): void {
107
+ const e = turn.expect;
108
+ if (!e) return;
109
+ const fail = (msg: string): never => {
110
+ // Surface mismatch with enough context to debug, then throw.
111
+ const detail = {
112
+ turn: turn.turn,
113
+ modelId: model.id,
114
+ messageCount: ctx.messages.length,
115
+ lastUserText: lastUserMessage(ctx) ? userText(lastUserMessage(ctx)!).slice(0, 200) : null,
116
+ toolNames: ctx.tools?.map((t) => t.name) ?? [],
117
+ };
118
+ throw new Error(`fake-llm: turn ${turn.turn} expectation mismatch: ${msg}\n actual: ${JSON.stringify(detail)}`);
119
+ };
120
+
121
+ if (e.modelId !== undefined && model.id !== e.modelId) {
122
+ fail(`expected modelId=${e.modelId}, got ${model.id}`);
123
+ }
124
+ if (e.messageCount !== undefined && ctx.messages.length !== e.messageCount) {
125
+ fail(`expected messageCount=${e.messageCount}, got ${ctx.messages.length}`);
126
+ }
127
+ if (e.lastUserText !== undefined) {
128
+ const last = lastUserMessage(ctx);
129
+ if (!last) fail(`expected lastUserText to contain "${e.lastUserText}", but no user messages found`);
130
+ const text = userText(last!);
131
+ if (!text.includes(e.lastUserText)) {
132
+ fail(`expected lastUserText to contain "${e.lastUserText}", got "${text.slice(0, 200)}"`);
133
+ }
134
+ }
135
+ if (e.systemContains && e.systemContains.length > 0) {
136
+ const sys = ctx.systemPrompt ?? "";
137
+ for (const needle of e.systemContains) {
138
+ if (!sys.includes(needle)) fail(`expected systemPrompt to contain "${needle}"`);
139
+ }
140
+ }
141
+ if (e.toolNames) {
142
+ const actual = (ctx.tools ?? []).map((t) => t.name).sort();
143
+ const expected = [...e.toolNames].sort();
144
+ if (actual.length !== expected.length || actual.some((n, i) => n !== expected[i])) {
145
+ fail(`expected toolNames=${JSON.stringify(expected)}, got ${JSON.stringify(actual)}`);
146
+ }
147
+ }
148
+ if (e.hasToolResultFor !== undefined) {
149
+ const last = ctx.messages[ctx.messages.length - 1];
150
+ if (!last || last.role !== "toolResult" || last.toolName !== e.hasToolResultFor) {
151
+ fail(`expected last message to be a toolResult for "${e.hasToolResultFor}"`);
152
+ }
153
+ }
154
+ }
155
+
156
+ function buildAssistantMessage(
157
+ model: Model<typeof FAKE_API>,
158
+ emit: EmitSpec,
159
+ ): AssistantMessage {
160
+ const content: AssistantMessage["content"] = [];
161
+ let stopReason: AssistantMessage["stopReason"] = "stop";
162
+
163
+ if (emit.kind === "text") {
164
+ content.push({ type: "text", text: emit.text });
165
+ stopReason = emit.stopReason ?? "stop";
166
+ } else if (emit.kind === "tool_use") {
167
+ for (const [i, call] of emit.calls.entries()) {
168
+ const tc: ToolCall = {
169
+ type: "toolCall",
170
+ id: call.id ?? `fake-tool-${Date.now()}-${i}`,
171
+ name: call.name,
172
+ arguments: call.input,
173
+ };
174
+ content.push(tc);
175
+ }
176
+ stopReason = "toolUse";
177
+ }
178
+
179
+ return {
180
+ role: "assistant",
181
+ content,
182
+ api: model.api,
183
+ provider: model.provider,
184
+ model: model.id,
185
+ usage: {
186
+ input: 0,
187
+ output: 0,
188
+ cacheRead: 0,
189
+ cacheWrite: 0,
190
+ totalTokens: 0,
191
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
192
+ },
193
+ stopReason,
194
+ timestamp: Date.now(),
195
+ };
196
+ }
197
+
198
+ /**
199
+ * Create a fake provider bound to a transcript file. Each call to stream()
200
+ * advances the turn cursor by one. Caller is responsible for ensuring the
201
+ * transcript has enough turns.
202
+ */
203
+ export function createFakeProvider(opts: { transcriptPath: string }): ApiProvider<typeof FAKE_API> {
204
+ const transcript = parseTranscript(opts.transcriptPath);
205
+ let cursor = 0;
206
+
207
+ function nextTurn(): TranscriptTurn {
208
+ if (cursor >= transcript.length) {
209
+ throw new Error(
210
+ `fake-llm: provider invoked ${cursor + 1} times but transcript only has ${transcript.length} turns. Add another turn to ${opts.transcriptPath}.`,
211
+ );
212
+ }
213
+ return transcript[cursor++];
214
+ }
215
+
216
+ function streamTurn(model: Model<typeof FAKE_API>, ctx: Context): AssistantMessageEventStream {
217
+ const stream = new AssistantMessageEventStream();
218
+ const turn = nextTurn();
219
+
220
+ // Synchronously validate expectations BEFORE doing any async work — this
221
+ // way drift mismatches are reported with the request that caused them.
222
+ checkExpectations(model, ctx, turn);
223
+
224
+ const emit = turn.emit;
225
+
226
+ queueMicrotask(async () => {
227
+ try {
228
+ if (emit.kind === "error_429") {
229
+ const errorMsg: AssistantMessage = {
230
+ role: "assistant",
231
+ content: [],
232
+ api: model.api,
233
+ provider: model.provider,
234
+ model: model.id,
235
+ usage: {
236
+ input: 0,
237
+ output: 0,
238
+ cacheRead: 0,
239
+ cacheWrite: 0,
240
+ totalTokens: 0,
241
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
242
+ },
243
+ stopReason: "error",
244
+ errorMessage: emit.message ?? "rate_limit_exceeded",
245
+ retryAfterMs: emit.retryAfterMs,
246
+ timestamp: Date.now(),
247
+ };
248
+ stream.push({ type: "error", reason: "error", error: errorMsg });
249
+ stream.end(errorMsg);
250
+ return;
251
+ }
252
+
253
+ if (emit.kind === "malformed") {
254
+ // Simulate a provider that emits a corrupted/incomplete response.
255
+ // The agent loop converts this to stopReason: "error".
256
+ const errorMsg: AssistantMessage = {
257
+ role: "assistant",
258
+ content: [],
259
+ api: model.api,
260
+ provider: model.provider,
261
+ model: model.id,
262
+ usage: {
263
+ input: 0,
264
+ output: 0,
265
+ cacheRead: 0,
266
+ cacheWrite: 0,
267
+ totalTokens: 0,
268
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
269
+ },
270
+ stopReason: "error",
271
+ errorMessage: emit.message ?? "malformed_response",
272
+ timestamp: Date.now(),
273
+ };
274
+ stream.push({ type: "error", reason: "error", error: errorMsg });
275
+ stream.end(errorMsg);
276
+ return;
277
+ }
278
+
279
+ if (emit.kind === "timeout") {
280
+ const delay = emit.delayMs ?? 60_000;
281
+ await new Promise((r) => setTimeout(r, delay));
282
+ // If the caller hasn't already aborted, emit a synthetic timeout error.
283
+ const errorMsg: AssistantMessage = {
284
+ role: "assistant",
285
+ content: [],
286
+ api: model.api,
287
+ provider: model.provider,
288
+ model: model.id,
289
+ usage: {
290
+ input: 0,
291
+ output: 0,
292
+ cacheRead: 0,
293
+ cacheWrite: 0,
294
+ totalTokens: 0,
295
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
296
+ },
297
+ stopReason: "error",
298
+ errorMessage: "timeout",
299
+ timestamp: Date.now(),
300
+ };
301
+ stream.push({ type: "error", reason: "error", error: errorMsg });
302
+ stream.end(errorMsg);
303
+ return;
304
+ }
305
+
306
+ const message = buildAssistantMessage(model, emit);
307
+ stream.push({ type: "start", partial: { ...message, content: [] } });
308
+
309
+ if (emit.kind === "text") {
310
+ stream.push({ type: "text_start", contentIndex: 0, partial: message });
311
+ stream.push({
312
+ type: "text_delta",
313
+ contentIndex: 0,
314
+ delta: emit.text,
315
+ partial: message,
316
+ });
317
+ stream.push({
318
+ type: "text_end",
319
+ contentIndex: 0,
320
+ content: emit.text,
321
+ partial: message,
322
+ });
323
+ } else if (emit.kind === "tool_use") {
324
+ for (const [i, c] of message.content.entries()) {
325
+ if (c.type !== "toolCall") continue;
326
+ stream.push({ type: "toolcall_start", contentIndex: i, partial: message });
327
+ stream.push({
328
+ type: "toolcall_end",
329
+ contentIndex: i,
330
+ toolCall: c,
331
+ partial: message,
332
+ });
333
+ }
334
+ }
335
+
336
+ stream.push({
337
+ type: "done",
338
+ reason: message.stopReason as "stop" | "length" | "toolUse" | "pauseTurn",
339
+ message,
340
+ });
341
+ stream.end(message);
342
+ } catch (err) {
343
+ const errorMsg: AssistantMessage = {
344
+ role: "assistant",
345
+ content: [],
346
+ api: model.api,
347
+ provider: model.provider,
348
+ model: model.id,
349
+ usage: {
350
+ input: 0,
351
+ output: 0,
352
+ cacheRead: 0,
353
+ cacheWrite: 0,
354
+ totalTokens: 0,
355
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
356
+ },
357
+ stopReason: "error",
358
+ errorMessage: (err as Error).message,
359
+ timestamp: Date.now(),
360
+ };
361
+ stream.push({ type: "error", reason: "error", error: errorMsg });
362
+ stream.end(errorMsg);
363
+ }
364
+ });
365
+
366
+ return stream;
367
+ }
368
+
369
+ return {
370
+ api: FAKE_API,
371
+ stream: ((model: Model<typeof FAKE_API>, ctx: Context, _opts?: StreamOptions) =>
372
+ streamTurn(model, ctx)) as ApiProvider<typeof FAKE_API>["stream"],
373
+ streamSimple: ((model: Model<typeof FAKE_API>, ctx: Context, _opts?: SimpleStreamOptions) =>
374
+ streamTurn(model, ctx)) as ApiProvider<typeof FAKE_API>["streamSimple"],
375
+ };
376
+ }
@@ -12,40 +12,53 @@
12
12
  */
13
13
  import test, { describe } from "node:test";
14
14
  import assert from "node:assert/strict";
15
- import { existsSync, readFileSync } from "node:fs";
16
- import { dirname, join } from "node:path";
17
- import { fileURLToPath } from "node:url";
15
+ import { buildAnthropicClientOptions } from "./anthropic.js";
18
16
  import { convertMessages } from "./anthropic-shared.js";
17
+ import type { Model } from "../types.js";
19
18
  import type { AssistantMessage } from "../types.js";
20
19
 
21
- const __dirname = dirname(fileURLToPath(import.meta.url));
22
-
23
- function resolveSourcePath(fileName: string): string {
24
- const localPath = join(__dirname, fileName);
25
- if (existsSync(localPath)) return localPath;
26
- return join(__dirname, "..", "..", "src", "providers", fileName);
20
+ function anthropicModel(overrides: Partial<Model<"anthropic-messages">> = {}): Model<"anthropic-messages"> {
21
+ return {
22
+ id: "claude-sonnet-4",
23
+ name: "Claude Sonnet 4",
24
+ api: "anthropic-messages",
25
+ provider: "anthropic",
26
+ baseUrl: "https://api.anthropic.com",
27
+ reasoning: true,
28
+ input: ["text"],
29
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
30
+ contextWindow: 200000,
31
+ maxTokens: 8192,
32
+ ...overrides,
33
+ };
27
34
  }
28
35
 
29
- const source = readFileSync(resolveSourcePath("anthropic.ts"), "utf-8");
30
-
31
36
  describe("MiniMax fine-grained-tool-streaming exclusion (#4538)", () => {
32
37
  test("minimax is excluded from fine-grained-tool-streaming-2025-05-14 beta", () => {
33
- // The skipBetaHeaders flag must include minimax so it never receives the
34
- // fine-grained-tool-streaming beta that causes empty tool names.
35
- assert.match(
36
- source,
37
- /skipBetaHeaders.*minimax/s,
38
- "minimax must be included in skipBetaHeaders to suppress fine-grained-tool-streaming",
38
+ const options = buildAnthropicClientOptions(anthropicModel({ provider: "minimax" }), "api-key", false);
39
+
40
+ assert.equal(
41
+ options.defaultHeaders["anthropic-beta"],
42
+ undefined,
43
+ "minimax must suppress fine-grained-tool-streaming",
39
44
  );
40
45
  });
41
46
 
42
47
  test("minimax-cn is excluded from fine-grained-tool-streaming-2025-05-14 beta", () => {
43
- assert.match(
44
- source,
45
- /skipBetaHeaders.*minimax-cn/s,
46
- "minimax-cn must be included in skipBetaHeaders to suppress fine-grained-tool-streaming",
48
+ const options = buildAnthropicClientOptions(anthropicModel({ provider: "minimax-cn" }), "api-key", false);
49
+
50
+ assert.equal(
51
+ options.defaultHeaders["anthropic-beta"],
52
+ undefined,
53
+ "minimax-cn must suppress fine-grained-tool-streaming",
47
54
  );
48
55
  });
56
+
57
+ test("standard Anthropic-compatible providers keep fine-grained-tool-streaming enabled", () => {
58
+ const options = buildAnthropicClientOptions(anthropicModel(), "api-key", false);
59
+
60
+ assert.equal(options.defaultHeaders["anthropic-beta"], "fine-grained-tool-streaming-2025-05-14");
61
+ });
49
62
  });
50
63
 
51
64
  describe("empty tool name guard in convertMessages (#4538)", () => {
@@ -1,4 +1,5 @@
1
1
  import { clearApiProviders, registerApiProvider } from "../api-registry.js";
2
+ import { createFakeProvider } from "./fake.js";
2
3
  import type { AssistantMessage, AssistantMessageEvent, Context, Model, SimpleStreamOptions } from "../types.js";
3
4
  import { AssistantMessageEventStream } from "../utils/event-stream.js";
4
5
  import type { BedrockOptions } from "./amazon-bedrock.js";
@@ -188,6 +189,28 @@ function registerBuiltInApiProviders(): void {
188
189
  export function resetApiProviders(): void {
189
190
  clearApiProviders();
190
191
  registerBuiltInApiProviders();
192
+ registerFakeProviderIfEnabled();
193
+ }
194
+
195
+ /**
196
+ * E2E-test-only: when `GSD_FAKE_LLM_TRANSCRIPT` is set, register a
197
+ * deterministic JSONL-replay provider under api "fake". The env var must
198
+ * be set BEFORE this module is imported. Subprocess-spawned e2e tests do
199
+ * this by setting it on the spawn env.
200
+ *
201
+ * Synchronous registration: any failure throws here so the CLI startup
202
+ * fails loudly instead of silently falling through to a real provider.
203
+ */
204
+ function registerFakeProviderIfEnabled(): void {
205
+ const transcriptPath = process.env.GSD_FAKE_LLM_TRANSCRIPT;
206
+ if (!transcriptPath) return;
207
+ try {
208
+ registerApiProvider(createFakeProvider({ transcriptPath }), "fake");
209
+ } catch (err) {
210
+ process.stderr.write(`fake-llm: failed to register: ${(err as Error).message}\n`);
211
+ throw err;
212
+ }
191
213
  }
192
214
 
193
215
  registerBuiltInApiProviders();
216
+ registerFakeProviderIfEnabled();
@@ -1,3 +1,4 @@
1
+ // GSD2 - Shared AI provider type definitions
1
2
  import type { AssistantMessageEventStream } from "./utils/event-stream.js";
2
3
 
3
4
  export type { AssistantMessageEventStream } from "./utils/event-stream.js";
@@ -116,6 +117,8 @@ export type ProviderStreamOptions = StreamOptions & Record<string, unknown>;
116
117
 
117
118
  // Unified options with reasoning passed to streamSimple() and completeSimple()
118
119
  export interface SimpleStreamOptions extends StreamOptions {
120
+ /** Workspace root for providers that spawn local processes. */
121
+ cwd?: string;
119
122
  reasoning?: ThinkingLevel;
120
123
  /** Custom token budgets for thinking levels (token-based providers only) */
121
124
  thinkingBudgets?: ThinkingBudgets;