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,6 +1,6 @@
1
1
  import test, { mock } from "node:test";
2
2
  import assert from "node:assert/strict";
3
- import { mkdtempSync } from "node:fs";
3
+ import { mkdirSync, mkdtempSync, rmSync } from "node:fs";
4
4
  import { tmpdir } from "node:os";
5
5
  import { join } from "node:path";
6
6
 
@@ -10,13 +10,20 @@ import {
10
10
  _resetPendingResolve,
11
11
  _hasPendingResolveForTest,
12
12
  _setActiveSession,
13
+ _setSessionSwitchInFlight,
14
+ _markSessionSwitchAbortGraceWindow,
15
+ _clearSessionSwitchAbortGraceWindow,
16
+ _consumePendingSwitchCancellation,
13
17
  isSessionSwitchInFlight,
18
+ isSessionSwitchAbortGraceActive,
14
19
  } from "../auto/resolve.js";
15
20
  import { runUnit } from "../auto/run-unit.js";
16
21
  import { autoLoop } from "../auto/loop.js";
22
+ import { runDispatch } from "../auto/phases.js";
17
23
  import { detectStuck } from "../auto/detect-stuck.js";
18
24
  import type { UnitResult, AgentEndEvent } from "../auto/types.js";
19
25
  import type { LoopDeps } from "../auto/loop-deps.js";
26
+ import { WorktreeStateProjection } from "../worktree-state-projection.js";
20
27
  import { ModelPolicyDispatchBlockedError } from "../auto-model-selection.js";
21
28
  import type { SessionLockStatus } from "../session-lock.js";
22
29
 
@@ -64,7 +71,7 @@ function makeMockSession(opts?: {
64
71
  verbose: false,
65
72
  basePath: process.cwd(),
66
73
  cmdCtx: {
67
- newSession: (options?: { abortSignal?: AbortSignal }) => {
74
+ newSession: (options?: { abortSignal?: AbortSignal; workspaceRoot?: string }) => {
68
75
  opts?.onNewSessionStart?.(session);
69
76
  if (opts?.newSessionThrows) {
70
77
  return Promise.reject(new Error(opts.newSessionThrows));
@@ -76,7 +83,7 @@ function makeMockSession(opts?: {
76
83
  setTimeout(() => {
77
84
  // Simulate AgentSession.newSession() checking abortSignal after
78
85
  // its internal async work (abort()) completes — this is where the
79
- // real code captures process.cwd() and rebuilds the tool runtime.
86
+ // real code selects a workspace root and rebuilds the tool runtime.
80
87
  // If the signal is aborted, the real code discards the session.
81
88
  opts?.onSignalCheck?.(options?.abortSignal?.aborted ?? false);
82
89
  opts?.onNewSessionSettle?.(session);
@@ -206,6 +213,28 @@ test("runUnit returns cancelled when session creation fails", async () => {
206
213
  assert.equal(pi.calls.length, 0);
207
214
  });
208
215
 
216
+ test("runUnit clears queued switch cancellation when session creation fails", async () => {
217
+ _resetPendingResolve();
218
+
219
+ const ctx = makeMockCtx();
220
+ const pi = makeMockPi();
221
+ const s = makeMockSession({
222
+ newSessionThrows: "connection refused",
223
+ onNewSessionStart: () => {
224
+ resolveAgentEndCancelled({
225
+ message: "Claude Code process aborted by user",
226
+ category: "aborted",
227
+ isTransient: false,
228
+ });
229
+ },
230
+ });
231
+
232
+ const result = await runUnit(ctx, pi, s, "task", "T01", "prompt");
233
+
234
+ assert.equal(result.status, "cancelled");
235
+ assert.equal(_consumePendingSwitchCancellation(), null);
236
+ });
237
+
209
238
  test("runUnit returns cancelled when session creation times out", async () => {
210
239
  _resetPendingResolve();
211
240
 
@@ -221,6 +250,34 @@ test("runUnit returns cancelled when session creation times out", async () => {
221
250
  assert.equal(pi.calls.length, 0);
222
251
  });
223
252
 
253
+ test("runUnit consumes a cancellation queued during session switch before dispatch", async () => {
254
+ _resetPendingResolve();
255
+
256
+ const ctx = makeMockCtx();
257
+ const pi = makeMockPi();
258
+ let cancellationQueued = false;
259
+ const s = makeMockSession({
260
+ newSessionDelayMs: 10,
261
+ onNewSessionStart: () => {
262
+ setTimeout(() => {
263
+ cancellationQueued = !resolveAgentEndCancelled({
264
+ message: "Claude Code process aborted by user",
265
+ category: "aborted",
266
+ isTransient: false,
267
+ });
268
+ }, 0);
269
+ },
270
+ });
271
+
272
+ const result = await runUnit(ctx, pi, s, "plan-slice", "M009/S01", "prompt");
273
+
274
+ assert.equal(cancellationQueued, true);
275
+ assert.equal(result.status, "cancelled");
276
+ assert.equal(result.errorContext?.category, "aborted");
277
+ assert.equal(result.errorContext?.message, "Claude Code process aborted by user");
278
+ assert.equal(pi.calls.length, 0, "queued switch cancellation must prevent prompt dispatch");
279
+ });
280
+
224
281
  test("runUnit keeps the session-switch guard across a late newSession settlement", async () => {
225
282
  _resetPendingResolve();
226
283
  mock.timers.enable();
@@ -496,10 +553,9 @@ test("runUnit proceeds when isProviderRequestReady throws (defensive) (#4555)",
496
553
  assert.equal(pi.calls.length, 0);
497
554
  });
498
555
 
499
- test("late-resolving newSession() after timeout receives aborted signal so tool runtime is not configured with root cwd (#3731)", async () => {
500
- // When newSession() times out in runUnit(), auto-mode restores cwd to project
501
- // root. If newSession() later resolves, it must NOT use process.cwd() to
502
- // configure the tool runtime (which would give it root cwd, not worktree cwd).
556
+ test("late-resolving newSession() after timeout receives aborted signal so tool runtime is not configured with stale workspace root (#3731)", async () => {
557
+ // When newSession() times out in runUnit(), a late resolution must not
558
+ // configure the tool runtime against a stale workspace root.
503
559
  //
504
560
  // The fix: runUnit creates an AbortController, aborts it on timeout, and passes
505
561
  // the signal to newSession(). AgentSession.newSession() checks the signal after
@@ -514,8 +570,8 @@ test("late-resolving newSession() after timeout receives aborted signal so tool
514
570
 
515
571
  // newSession mock simulates AgentSession.newSession() behavior:
516
572
  // after an internal delay (representing await this.abort()), it checks the
517
- // abortSignal that's where the real code would capture process.cwd() and
518
- // call _buildRuntime. If aborted, the real code must discard the session.
573
+ // abortSignal before selecting the workspace root and calling _buildRuntime.
574
+ // If aborted, the real code must discard the session.
519
575
  const s = makeMockSession({
520
576
  newSessionDelayMs: 200_000, // longer than NEW_SESSION_TIMEOUT_MS (120s)
521
577
  onSignalCheck: (aborted) => {
@@ -548,7 +604,7 @@ test("late-resolving newSession() after timeout receives aborted signal so tool
548
604
  abortedWhenLateSessionSettled,
549
605
  true,
550
606
  "runUnit must pass an aborted AbortSignal to newSession() when it resolves after the session-creation timeout (#3731). " +
551
- "Without this, AgentSession.newSession() captures root process.cwd() and rebuilds the tool runtime with wrong cwd.",
607
+ "Without this, AgentSession.newSession() can rebuild the tool runtime with a stale workspace root.",
552
608
  );
553
609
  } finally {
554
610
  mock.timers.reset();
@@ -613,7 +669,6 @@ function makeMockDeps(
613
669
  preferences: { uok: { plan_v2: { enabled: false } } },
614
670
  }),
615
671
  preDispatchHealthGate: async () => ({ proceed: true, fixesApplied: [] }),
616
- syncProjectRootToWorktree: () => {},
617
672
  checkResourcesStale: () => null,
618
673
  validateSessionLock: () => ({ valid: true } as SessionLockStatus),
619
674
  updateSessionLock: () => {
@@ -637,7 +692,11 @@ function makeMockDeps(
637
692
  resolveMilestoneFile: () => null,
638
693
  reconcileMergeState: () => "clean",
639
694
  preflightCleanRoot: () => ({ stashPushed: false, summary: "" }),
640
- postflightPopStash: () => {},
695
+ postflightPopStash: () => ({
696
+ restored: true,
697
+ needsManualRecovery: false,
698
+ message: "restored",
699
+ }),
641
700
  getLedger: () => null,
642
701
  getProjectTotals: () => ({ cost: 0 }),
643
702
  formatCost: (c: number) => `$${c.toFixed(2)}`,
@@ -673,21 +732,15 @@ function makeMockDeps(
673
732
  readFileSync: () => "",
674
733
  atomicWriteSync: () => {},
675
734
  GitServiceImpl: class {} as any,
676
- resolver: {
677
- get workPath() {
678
- return "/tmp/project";
679
- },
680
- get projectRoot() {
681
- return "/tmp/project";
682
- },
683
- get lockPath() {
684
- return "/tmp/project";
685
- },
686
- enterMilestone: () => {},
687
- exitMilestone: () => {},
688
- mergeAndExit: () => {},
689
- mergeAndEnterNext: () => {},
735
+ lifecycle: {
736
+ enterMilestone: () => ({ ok: true, mode: "worktree", path: "/tmp/project" }),
737
+ exitMilestone: (_mid: string, opts: { merge: boolean }) => ({
738
+ ok: true,
739
+ merged: opts.merge,
740
+ codeFilesChanged: false,
741
+ }),
690
742
  } as any,
743
+ worktreeProjection: new WorktreeStateProjection(),
691
744
  postUnitPreVerification: async () => {
692
745
  callLog.push("postUnitPreVerification");
693
746
  return "continue" as const;
@@ -805,6 +858,139 @@ test("autoLoop exits on terminal complete state", async (t) => {
805
858
  );
806
859
  });
807
860
 
861
+ test("autoLoop stops before success notification when postflight stash restore needs recovery", async () => {
862
+ _resetPendingResolve();
863
+
864
+ const notifications: Array<{ msg: string; level: string }> = [];
865
+ const ctx = makeMockCtx();
866
+ ctx.ui.setStatus = () => {};
867
+ ctx.ui.notify = (msg: string, level: string) => {
868
+ notifications.push({ msg, level });
869
+ };
870
+ const pi = makeMockPi();
871
+ const s = makeLoopSession();
872
+ let stopReason = "";
873
+
874
+ const deps = makeMockDeps({
875
+ deriveState: async () => {
876
+ deps.callLog.push("deriveState");
877
+ return {
878
+ phase: "complete",
879
+ activeMilestone: { id: "M001", title: "Test", status: "complete" },
880
+ activeSlice: null,
881
+ activeTask: null,
882
+ registry: [{ id: "M001", status: "complete" }],
883
+ blockers: [],
884
+ } as any;
885
+ },
886
+ preflightCleanRoot: () => ({
887
+ stashPushed: true,
888
+ stashMarker: "gsd-preflight-stash:M001:test",
889
+ summary: "stashed",
890
+ }),
891
+ postflightPopStash: () => ({
892
+ restored: false,
893
+ needsManualRecovery: true,
894
+ message: "git stash pop stash@{0} failed after merge of milestone M001",
895
+ stashRef: "stash@{0}",
896
+ }),
897
+ sendDesktopNotification: () => {
898
+ deps.callLog.push("sendDesktopNotification");
899
+ },
900
+ logCmuxEvent: () => {
901
+ deps.callLog.push("logCmuxEvent");
902
+ },
903
+ stopAuto: async (_ctx, _pi, reason) => {
904
+ deps.callLog.push("stopAuto");
905
+ stopReason = reason ?? "";
906
+ },
907
+ });
908
+
909
+ await autoLoop(ctx, pi, s, deps);
910
+
911
+ assert.equal(stopReason, "Post-merge stash restore failed for milestone M001");
912
+ assert.ok(
913
+ notifications.some(
914
+ (n) => n.level === "error" && n.msg.includes("Post-merge stash restore failed for milestone M001"),
915
+ ),
916
+ "failed postflight restore must be surfaced as an error",
917
+ );
918
+ assert.ok(
919
+ !deps.callLog.includes("sendDesktopNotification"),
920
+ "must not emit milestone success desktop notification after stash restore failure",
921
+ );
922
+ assert.ok(
923
+ !deps.callLog.includes("logCmuxEvent"),
924
+ "must not emit milestone success cmux event after stash restore failure",
925
+ );
926
+ });
927
+
928
+ test("autoLoop marks transition merge complete before postflight recovery stop", async () => {
929
+ _resetPendingResolve();
930
+
931
+ const ctx = makeMockCtx();
932
+ ctx.ui.setStatus = () => {};
933
+ ctx.ui.notify = () => {};
934
+ const pi = makeMockPi();
935
+ const s = makeLoopSession();
936
+ let mergeCalls = 0;
937
+ let stopReason = "";
938
+
939
+ const deps = makeMockDeps({
940
+ deriveState: async () => {
941
+ deps.callLog.push("deriveState");
942
+ return {
943
+ phase: "executing",
944
+ activeMilestone: { id: "M002", title: "Next", status: "active" },
945
+ activeSlice: null,
946
+ activeTask: null,
947
+ registry: [
948
+ { id: "M001", title: "Done", status: "complete" },
949
+ { id: "M002", title: "Next", status: "active" },
950
+ ],
951
+ blockers: [],
952
+ } as any;
953
+ },
954
+ preflightCleanRoot: () => ({
955
+ stashPushed: true,
956
+ stashMarker: "gsd-preflight-stash:M001:test",
957
+ summary: "stashed",
958
+ }),
959
+ postflightPopStash: () => ({
960
+ restored: false,
961
+ needsManualRecovery: true,
962
+ message: "git stash pop stash@{0} failed after merge of milestone M001",
963
+ stashRef: "stash@{0}",
964
+ }),
965
+ lifecycle: {
966
+ enterMilestone: () => {
967
+ assert.fail("must not enter the next milestone after postflight recovery fails");
968
+ },
969
+ exitMilestone: (_mid: string, opts: { merge: boolean }) => {
970
+ if (opts.merge) mergeCalls += 1;
971
+ return { ok: true, merged: opts.merge, codeFilesChanged: false };
972
+ },
973
+ } as any,
974
+ stopAuto: async (_ctx, _pi, reason) => {
975
+ deps.callLog.push("stopAuto");
976
+ stopReason = reason ?? "";
977
+ if (!s.milestoneMergedInPhases) {
978
+ deps.lifecycle.exitMilestone(
979
+ "M001",
980
+ { merge: true },
981
+ { notify: ctx.ui.notify.bind(ctx.ui) },
982
+ );
983
+ }
984
+ },
985
+ });
986
+
987
+ await autoLoop(ctx, pi, s, deps);
988
+
989
+ assert.equal(stopReason, "Post-merge stash restore failed for milestone M001");
990
+ assert.equal(s.milestoneMergedInPhases, true);
991
+ assert.equal(mergeCalls, 1, "postflight recovery stop must not re-run an already completed transition merge");
992
+ });
993
+
808
994
  test("autoLoop pauses when provider readiness cancels before dispatch", async () => {
809
995
  _resetPendingResolve();
810
996
 
@@ -879,6 +1065,123 @@ test("autoLoop passes structured session-lock failure details to the handler", a
879
1065
  );
880
1066
  });
881
1067
 
1068
+ // Regression for #5308: the iteration prelude must dequeue sidecar items
1069
+ // (popping the queue and emitting the `sidecar-dequeue` journal event) BEFORE
1070
+ // validateSessionLock + break-on-invalid. Inverting that order silently drops
1071
+ // queued sidecar work on lock-loss. Covers first-iteration and mid-session.
1072
+ test("autoLoop dequeues sidecar item before session-lock break (first iteration, #5308)", async () => {
1073
+ _resetPendingResolve();
1074
+
1075
+ const ctx = makeMockCtx();
1076
+ ctx.ui.setStatus = () => {};
1077
+ const pi = makeMockPi();
1078
+ const s = makeLoopSession();
1079
+ s.sidecarQueue.push({
1080
+ kind: "hook" as const,
1081
+ unitType: "hook/review",
1082
+ unitId: "M001/S01/T01/review",
1083
+ prompt: "review the code",
1084
+ });
1085
+
1086
+ const journalEvents: string[] = [];
1087
+ const deps = makeMockDeps({
1088
+ validateSessionLock: () =>
1089
+ ({
1090
+ valid: false,
1091
+ failureReason: "compromised",
1092
+ expectedPid: process.pid,
1093
+ }) as SessionLockStatus,
1094
+ handleLostSessionLock: () => {
1095
+ deps.callLog.push("handleLostSessionLock");
1096
+ },
1097
+ emitJournalEvent: (entry) => {
1098
+ journalEvents.push(entry.eventType);
1099
+ },
1100
+ });
1101
+
1102
+ await autoLoop(ctx, pi, s, deps);
1103
+
1104
+ assert.equal(
1105
+ s.sidecarQueue.length,
1106
+ 0,
1107
+ "sidecar item must be popped on lock-loss iteration (pre-#5308 ordering)",
1108
+ );
1109
+ assert.ok(
1110
+ journalEvents.includes("sidecar-dequeue"),
1111
+ "sidecar-dequeue journal event must be emitted before session-lock break",
1112
+ );
1113
+ assert.ok(
1114
+ deps.callLog.includes("handleLostSessionLock"),
1115
+ "session lock handler must still fire after sidecar dequeue",
1116
+ );
1117
+ assert.ok(!deps.callLog.includes("deriveState"), "lock loss should stop before deriving state");
1118
+ });
1119
+
1120
+ test("autoLoop dequeues sidecar item before session-lock break (mid-session, #5308)", async () => {
1121
+ _resetPendingResolve();
1122
+
1123
+ const ctx = makeMockCtx();
1124
+ ctx.ui.setStatus = () => {};
1125
+ const pi = makeMockPi();
1126
+ const s = makeLoopSession();
1127
+
1128
+ const journalEvents: string[] = [];
1129
+ let lockCheckCount = 0;
1130
+ const deps = makeMockDeps({
1131
+ // First iteration: lock valid; second iteration: lock invalidates.
1132
+ validateSessionLock: () => {
1133
+ lockCheckCount += 1;
1134
+ if (lockCheckCount === 1) {
1135
+ return { valid: true } as SessionLockStatus;
1136
+ }
1137
+ return {
1138
+ valid: false,
1139
+ failureReason: "compromised",
1140
+ expectedPid: process.pid,
1141
+ } as SessionLockStatus;
1142
+ },
1143
+ handleLostSessionLock: () => {
1144
+ deps.callLog.push("handleLostSessionLock");
1145
+ },
1146
+ emitJournalEvent: (entry) => {
1147
+ journalEvents.push(entry.eventType);
1148
+ },
1149
+ // Enqueue a sidecar item at the end of iteration 1, so iteration 2 begins
1150
+ // with a non-empty queue and an invalid lock.
1151
+ postUnitPostVerification: async () => {
1152
+ deps.callLog.push("postUnitPostVerification");
1153
+ s.sidecarQueue.push({
1154
+ kind: "hook" as const,
1155
+ unitType: "run-uat",
1156
+ unitId: "M001/S01/T01/review",
1157
+ prompt: "review the code",
1158
+ });
1159
+ return "continue" as const;
1160
+ },
1161
+ });
1162
+
1163
+ const loopPromise = autoLoop(ctx, pi, s, deps);
1164
+ // Allow the loop to reach runUnit's await on iteration 1.
1165
+ await new Promise((r) => setTimeout(r, 50));
1166
+ resolveAgentEnd(makeEvent());
1167
+ await loopPromise;
1168
+
1169
+ assert.ok(lockCheckCount >= 2, "lock validator must run on iteration 2");
1170
+ assert.equal(
1171
+ s.sidecarQueue.length,
1172
+ 0,
1173
+ "queued sidecar item must be popped on the lock-loss iteration",
1174
+ );
1175
+ assert.ok(
1176
+ journalEvents.includes("sidecar-dequeue"),
1177
+ "sidecar-dequeue journal event must be emitted before session-lock break",
1178
+ );
1179
+ assert.ok(
1180
+ deps.callLog.includes("handleLostSessionLock"),
1181
+ "lock-loss handler must still fire on iteration 2",
1182
+ );
1183
+ });
1184
+
882
1185
  test("autoLoop exits on terminal blocked state", async (t) => {
883
1186
  _resetPendingResolve();
884
1187
 
@@ -1336,7 +1639,7 @@ test("autoLoop drains sidecar queue after postUnitPostVerification enqueues item
1336
1639
  // First call (main unit): enqueue a sidecar item
1337
1640
  s.sidecarQueue.push({
1338
1641
  kind: "hook" as const,
1339
- unitType: "hook/review",
1642
+ unitType: "run-uat",
1340
1643
  unitId: "M001/S01/T01/review",
1341
1644
  prompt: "review the code",
1342
1645
  });
@@ -1358,11 +1661,17 @@ test("autoLoop drains sidecar queue after postUnitPostVerification enqueues item
1358
1661
  const loopPromise = autoLoop(ctx, pi, s, deps);
1359
1662
 
1360
1663
  // Wait for main unit's runUnit to be awaiting
1361
- await new Promise((r) => setTimeout(r, 50));
1664
+ for (let i = 0; !_hasPendingResolveForTest() && i < 100; i++) {
1665
+ await new Promise((r) => setTimeout(r, 5));
1666
+ }
1667
+ assert.equal(_hasPendingResolveForTest(), true, "main unit should be awaiting agent_end");
1362
1668
  resolveAgentEnd(makeEvent()); // resolve main unit
1363
1669
 
1364
1670
  // Wait for the sidecar unit's runUnit to be awaiting
1365
- await new Promise((r) => setTimeout(r, 50));
1671
+ for (let i = 0; !_hasPendingResolveForTest() && postVerCallCount < 2 && i < 100; i++) {
1672
+ await new Promise((r) => setTimeout(r, 5));
1673
+ }
1674
+ assert.equal(_hasPendingResolveForTest(), true, "sidecar unit should be awaiting agent_end");
1366
1675
  resolveAgentEnd(makeEvent()); // resolve sidecar unit
1367
1676
 
1368
1677
  await loopPromise;
@@ -1781,7 +2090,7 @@ test("autoLoop lifecycle: advances through research → plan → execute → ver
1781
2090
  { unitType: "research-slice", unitId: "M001/S01", prompt: "research" },
1782
2091
  { unitType: "plan-slice", unitId: "M001/S01", prompt: "plan" },
1783
2092
  { unitType: "execute-task", unitId: "M001/S01/T01", prompt: "execute" },
1784
- { unitType: "verify-slice", unitId: "M001/S01", prompt: "verify" },
2093
+ { unitType: "run-uat", unitId: "M001/S01", prompt: "verify" },
1785
2094
  { unitType: "complete-slice", unitId: "M001/S01", prompt: "complete" },
1786
2095
  ];
1787
2096
 
@@ -1851,8 +2160,8 @@ test("autoLoop lifecycle: advances through research → plan → execute → ver
1851
2160
  `should have dispatched execute-task, got: ${dispatchedUnitTypes.join(", ")}`,
1852
2161
  );
1853
2162
  assert.ok(
1854
- dispatchedUnitTypes.includes("verify-slice"),
1855
- `should have dispatched verify-slice, got: ${dispatchedUnitTypes.join(", ")}`,
2163
+ dispatchedUnitTypes.includes("run-uat"),
2164
+ `should have dispatched run-uat, got: ${dispatchedUnitTypes.join(", ")}`,
1856
2165
  );
1857
2166
  assert.ok(
1858
2167
  dispatchedUnitTypes.includes("complete-slice"),
@@ -1884,7 +2193,7 @@ test("autoLoop lifecycle: advances through research → plan → execute → ver
1884
2193
  "research-slice",
1885
2194
  "plan-slice",
1886
2195
  "execute-task",
1887
- "verify-slice",
2196
+ "run-uat",
1888
2197
  "complete-slice",
1889
2198
  ],
1890
2199
  "dispatched unit types should follow the full lifecycle sequence",
@@ -1972,6 +2281,37 @@ test("resolveAgentEndCancelled without args produces no errorContext field", asy
1972
2281
  assert.equal(resolved.errorContext, undefined, "errorContext must not be present when no args passed");
1973
2282
  });
1974
2283
 
2284
+ test("resolveAgentEndCancelled queues cancellation that arrives during session switch", () => {
2285
+ _resetPendingResolve();
2286
+
2287
+ _setSessionSwitchInFlight(true);
2288
+ const resolved = resolveAgentEndCancelled({
2289
+ message: "Claude Code process aborted by user",
2290
+ category: "aborted",
2291
+ isTransient: false,
2292
+ });
2293
+
2294
+ assert.equal(resolved, false);
2295
+ const pending = _consumePendingSwitchCancellation();
2296
+ assert.ok(pending?.errorContext, "queued cancellation should preserve errorContext");
2297
+ assert.equal(pending.errorContext.category, "aborted");
2298
+ assert.equal(pending.errorContext.message, "Claude Code process aborted by user");
2299
+ assert.equal(_consumePendingSwitchCancellation(), null);
2300
+ _resetPendingResolve();
2301
+ });
2302
+
2303
+ test("session-switch abort grace window is short-lived and resettable", () => {
2304
+ _resetPendingResolve();
2305
+
2306
+ _markSessionSwitchAbortGraceWindow(1_000);
2307
+
2308
+ assert.equal(isSessionSwitchAbortGraceActive(Date.now()), true);
2309
+ assert.equal(isSessionSwitchAbortGraceActive(Date.now() + 10_000), false);
2310
+
2311
+ _clearSessionSwitchAbortGraceWindow();
2312
+ assert.equal(isSessionSwitchAbortGraceActive(), false);
2313
+ });
2314
+
1975
2315
  // ─── #1571: artifact verification retry ──────────────────────────────────────
1976
2316
 
1977
2317
  test("autoLoop re-iterates when postUnitPreVerification returns retry (#1571)", async () => {
@@ -2348,7 +2688,7 @@ test("autoLoop rejects complete-slice with 0 tool calls as context-exhausted (#2
2348
2688
 
2349
2689
  // ─── Worktree health check (#1833) ────────────────────────────────────────
2350
2690
 
2351
- test("autoLoop stops when worktree has no .git for execute-task (#1833)", async () => {
2691
+ test("autoLoop stops when Worktree Safety finds no .git marker for execute-task (#1833)", async (t) => {
2352
2692
  _resetPendingResolve();
2353
2693
 
2354
2694
  const ctx = makeMockCtx();
@@ -2359,7 +2699,16 @@ test("autoLoop stops when worktree has no .git for execute-task (#1833)", async
2359
2699
  const notifications: string[] = [];
2360
2700
  ctx.ui.notify = (msg: string) => { notifications.push(msg); };
2361
2701
 
2362
- const s = makeLoopSession({ basePath: "/tmp/broken-worktree" });
2702
+ const projectRoot = mkdtempSync(join(tmpdir(), "gsd-wt-safety-loop-"));
2703
+ const worktreeRoot = join(projectRoot, ".gsd", "worktrees", "M001");
2704
+ mkdirSync(worktreeRoot, { recursive: true });
2705
+ t.after(() => rmSync(projectRoot, { recursive: true, force: true }));
2706
+
2707
+ const s = makeLoopSession({
2708
+ basePath: worktreeRoot,
2709
+ originalBasePath: projectRoot,
2710
+ canonicalProjectRoot: projectRoot,
2711
+ });
2363
2712
 
2364
2713
  const deps = makeMockDeps({
2365
2714
  deriveState: async () => {
@@ -2373,8 +2722,7 @@ test("autoLoop stops when worktree has no .git for execute-task (#1833)", async
2373
2722
  blockers: [],
2374
2723
  } as any;
2375
2724
  },
2376
- // .git does not exist in the broken worktree
2377
- existsSync: (p: string) => !p.endsWith(".git"),
2725
+ getIsolationMode: () => "worktree",
2378
2726
  });
2379
2727
 
2380
2728
  await autoLoop(ctx, pi, s, deps);
@@ -2384,11 +2732,283 @@ test("autoLoop stops when worktree has no .git for execute-task (#1833)", async
2384
2732
  "should stop auto-mode when worktree is invalid",
2385
2733
  );
2386
2734
  const healthNotification = notifications.find(
2387
- (n) => n.includes("Worktree health check failed") && n.includes("no .git"),
2735
+ (n) => n.includes("Worktree Safety failed") && n.includes("worktree-git-marker-missing"),
2388
2736
  );
2389
2737
  assert.ok(
2390
2738
  healthNotification,
2391
- "should notify about missing .git in worktree",
2739
+ "should notify about missing worktree .git marker",
2740
+ );
2741
+ });
2742
+
2743
+ test("dispatch Worktree Safety wins before stuck detection for execute-task without .git", async (t) => {
2744
+ _resetPendingResolve();
2745
+
2746
+ const ctx = makeMockCtx();
2747
+ const pi = makeMockPi();
2748
+ const notifications: string[] = [];
2749
+ ctx.ui.notify = (msg: string) => { notifications.push(msg); };
2750
+
2751
+ const projectRoot = mkdtempSync(join(tmpdir(), "gsd-wt-safety-dispatch-"));
2752
+ const worktreeRoot = join(projectRoot, ".gsd", "worktrees", "M001");
2753
+ mkdirSync(worktreeRoot, { recursive: true });
2754
+ t.after(() => rmSync(projectRoot, { recursive: true, force: true }));
2755
+
2756
+ const s = makeLoopSession({
2757
+ basePath: worktreeRoot,
2758
+ originalBasePath: projectRoot,
2759
+ canonicalProjectRoot: projectRoot,
2760
+ });
2761
+ const deps = makeMockDeps({
2762
+ getIsolationMode: () => "worktree",
2763
+ });
2764
+ const result = await runDispatch(
2765
+ {
2766
+ ctx,
2767
+ pi,
2768
+ s,
2769
+ deps,
2770
+ prefs: undefined,
2771
+ iteration: 1,
2772
+ flowId: "test-flow",
2773
+ nextSeq: () => 1,
2774
+ },
2775
+ {
2776
+ state: {
2777
+ phase: "executing",
2778
+ activeMilestone: { id: "M001", title: "Test", status: "active" },
2779
+ activeSlice: { id: "S01", title: "Slice 1" },
2780
+ activeTask: { id: "T01" },
2781
+ registry: [{ id: "M001", status: "active" }],
2782
+ blockers: [],
2783
+ } as any,
2784
+ mid: "M001",
2785
+ midTitle: "Test",
2786
+ },
2787
+ {
2788
+ recentUnits: [
2789
+ { key: "execute-task/M001/S01/T01" },
2790
+ { key: "execute-task/M001/S01/T01" },
2791
+ ],
2792
+ stuckRecoveryAttempts: 1,
2793
+ consecutiveFinalizeTimeouts: 0,
2794
+ },
2795
+ );
2796
+
2797
+ assert.equal(result.action, "break");
2798
+ assert.equal(result.reason, "worktree-git-marker-missing");
2799
+ assert.ok(deps.callLog.includes("stopAuto"), "should stop through Worktree Safety");
2800
+ assert.ok(
2801
+ notifications.some((n) => n.includes("Worktree Safety failed") && n.includes("worktree-git-marker-missing")),
2802
+ "should notify about missing worktree .git marker",
2803
+ );
2804
+ assert.ok(
2805
+ !notifications.some((n) => n.includes("Stuck on execute-task")),
2806
+ "stuck-loop message must not mask the worktree health failure",
2807
+ );
2808
+ });
2809
+
2810
+ test("dispatch Worktree Safety stops unknown unit types with missing Tool Contract", async (t) => {
2811
+ _resetPendingResolve();
2812
+
2813
+ const ctx = makeMockCtx();
2814
+ const pi = makeMockPi();
2815
+ const notifications: string[] = [];
2816
+ ctx.ui.notify = (msg: string) => { notifications.push(msg); };
2817
+
2818
+ const projectRoot = mkdtempSync(join(tmpdir(), "gsd-wt-safety-missing-contract-"));
2819
+ const worktreeRoot = join(projectRoot, ".gsd", "worktrees", "M001");
2820
+ mkdirSync(worktreeRoot, { recursive: true });
2821
+ t.after(() => rmSync(projectRoot, { recursive: true, force: true }));
2822
+
2823
+ const s = makeLoopSession({
2824
+ basePath: worktreeRoot,
2825
+ originalBasePath: projectRoot,
2826
+ canonicalProjectRoot: projectRoot,
2827
+ });
2828
+ const deps = makeMockDeps({
2829
+ getIsolationMode: () => "worktree",
2830
+ resolveDispatch: async () => {
2831
+ deps.callLog.push("resolveDispatch");
2832
+ return {
2833
+ action: "dispatch" as const,
2834
+ unitType: "new-source-writing-unit-without-manifest",
2835
+ unitId: "M001/S01/T01",
2836
+ prompt: "do the thing",
2837
+ };
2838
+ },
2839
+ });
2840
+
2841
+ const result = await runDispatch(
2842
+ {
2843
+ ctx,
2844
+ pi,
2845
+ s,
2846
+ deps,
2847
+ prefs: undefined,
2848
+ iteration: 1,
2849
+ flowId: "test-flow",
2850
+ nextSeq: () => 1,
2851
+ },
2852
+ {
2853
+ state: {
2854
+ phase: "executing",
2855
+ activeMilestone: { id: "M001", title: "Test", status: "active" },
2856
+ activeSlice: { id: "S01", title: "Slice 1" },
2857
+ activeTask: { id: "T01" },
2858
+ registry: [{ id: "M001", status: "active" }],
2859
+ blockers: [],
2860
+ } as any,
2861
+ mid: "M001",
2862
+ midTitle: "Test",
2863
+ },
2864
+ {
2865
+ recentUnits: [],
2866
+ stuckRecoveryAttempts: 0,
2867
+ consecutiveFinalizeTimeouts: 0,
2868
+ },
2869
+ );
2870
+
2871
+ assert.equal(result.action, "break");
2872
+ assert.equal(result.reason, "missing-tool-contract");
2873
+ assert.ok(deps.callLog.includes("stopAuto"), "should stop when the Tool Contract is missing");
2874
+ assert.ok(
2875
+ notifications.some((n) => n.includes("missing Tool Contract for new-source-writing-unit-without-manifest")),
2876
+ "should notify with an actionable missing Tool Contract reason",
2877
+ );
2878
+ });
2879
+
2880
+ test("pre-dispatch skip resolves before dispatch health and stuck accounting", async () => {
2881
+ _resetPendingResolve();
2882
+
2883
+ const ctx = makeMockCtx();
2884
+ const pi = makeMockPi();
2885
+ const notifications: string[] = [];
2886
+ ctx.ui.notify = (msg: string) => { notifications.push(msg); };
2887
+
2888
+ const s = makeLoopSession({ basePath: "/tmp/broken-worktree" });
2889
+ const deps = makeMockDeps({
2890
+ existsSync: (p: string) => !p.endsWith(".git"),
2891
+ runPreDispatchHooks: () => ({ firedHooks: ["skip-execute"], action: "skip" }),
2892
+ });
2893
+ const loopState = {
2894
+ recentUnits: [
2895
+ { key: "execute-task/M001/S01/T01" },
2896
+ { key: "execute-task/M001/S01/T01" },
2897
+ ],
2898
+ stuckRecoveryAttempts: 1,
2899
+ consecutiveFinalizeTimeouts: 0,
2900
+ };
2901
+
2902
+ const result = await runDispatch(
2903
+ {
2904
+ ctx,
2905
+ pi,
2906
+ s,
2907
+ deps,
2908
+ prefs: undefined,
2909
+ iteration: 1,
2910
+ flowId: "test-flow",
2911
+ nextSeq: () => 1,
2912
+ },
2913
+ {
2914
+ state: {
2915
+ phase: "executing",
2916
+ activeMilestone: { id: "M001", title: "Test", status: "active" },
2917
+ activeSlice: { id: "S01", title: "Slice 1" },
2918
+ activeTask: { id: "T01" },
2919
+ registry: [{ id: "M001", status: "active" }],
2920
+ blockers: [],
2921
+ } as any,
2922
+ mid: "M001",
2923
+ midTitle: "Test",
2924
+ },
2925
+ loopState,
2926
+ );
2927
+
2928
+ assert.equal(result.action, "continue");
2929
+ assert.ok(!deps.callLog.includes("stopAuto"), "skip hook should not stop on worktree health");
2930
+ assert.equal(loopState.recentUnits.length, 2, "skip hook should not update stuck accounting");
2931
+ assert.ok(
2932
+ notifications.some((n) => n.includes("Skipping execute-task M001/S01/T01")),
2933
+ "should notify about the skip hook",
2934
+ );
2935
+ assert.ok(
2936
+ !notifications.some((n) => n.includes("Worktree health check failed") || n.includes("Stuck on execute-task")),
2937
+ "health and stuck notifications must not run before skip hook resolution",
2938
+ );
2939
+ });
2940
+
2941
+ test("pre-dispatch replace resolves final unit before dispatch health and stuck accounting", async () => {
2942
+ _resetPendingResolve();
2943
+
2944
+ const ctx = makeMockCtx();
2945
+ const pi = makeMockPi();
2946
+ const notifications: string[] = [];
2947
+ ctx.ui.notify = (msg: string) => { notifications.push(msg); };
2948
+
2949
+ const s = makeLoopSession({ basePath: "/tmp/broken-worktree" });
2950
+ const deps = makeMockDeps({
2951
+ existsSync: (p: string) => !p.endsWith(".git"),
2952
+ runPreDispatchHooks: () => ({
2953
+ firedHooks: ["review"],
2954
+ action: "replace",
2955
+ unitType: "run-uat",
2956
+ prompt: "review before executing",
2957
+ model: "review-model",
2958
+ }),
2959
+ });
2960
+ const loopState = {
2961
+ recentUnits: [
2962
+ { key: "execute-task/M001/S01/T01" },
2963
+ { key: "execute-task/M001/S01/T01" },
2964
+ ],
2965
+ stuckRecoveryAttempts: 1,
2966
+ consecutiveFinalizeTimeouts: 0,
2967
+ };
2968
+
2969
+ const result = await runDispatch(
2970
+ {
2971
+ ctx,
2972
+ pi,
2973
+ s,
2974
+ deps,
2975
+ prefs: undefined,
2976
+ iteration: 1,
2977
+ flowId: "test-flow",
2978
+ nextSeq: () => 1,
2979
+ },
2980
+ {
2981
+ state: {
2982
+ phase: "executing",
2983
+ activeMilestone: { id: "M001", title: "Test", status: "active" },
2984
+ activeSlice: { id: "S01", title: "Slice 1" },
2985
+ activeTask: { id: "T01" },
2986
+ registry: [{ id: "M001", status: "active" }],
2987
+ blockers: [],
2988
+ } as any,
2989
+ mid: "M001",
2990
+ midTitle: "Test",
2991
+ },
2992
+ loopState,
2993
+ );
2994
+
2995
+ assert.equal(result.action, "next");
2996
+ assert.equal(result.data?.unitType, "run-uat");
2997
+ assert.equal(result.data?.finalPrompt, "review before executing");
2998
+ assert.equal(result.data?.hookModelOverride, "review-model");
2999
+ assert.ok(!deps.callLog.includes("stopAuto"), "replace hook should not stop on execute-task health");
3000
+ assert.deepEqual(
3001
+ loopState.recentUnits.map((u) => u.key),
3002
+ [
3003
+ "execute-task/M001/S01/T01",
3004
+ "execute-task/M001/S01/T01",
3005
+ "run-uat/M001/S01/T01",
3006
+ ],
3007
+ "stuck accounting should record the final replaced unit",
3008
+ );
3009
+ assert.ok(
3010
+ !notifications.some((n) => n.includes("Worktree health check failed") || n.includes("Stuck on execute-task")),
3011
+ "health and stuck notifications must use the final replaced unit",
2392
3012
  );
2393
3013
  });
2394
3014
 
@@ -2439,7 +3059,7 @@ test("autoLoop warns but proceeds for greenfield project (no project files) (#18
2439
3059
  "should not stop with health check failure for greenfield project",
2440
3060
  );
2441
3061
  const greenfieldWarning = notifications.find(
2442
- (n) => n.includes("no recognized project files") && n.includes("greenfield"),
3062
+ (n) => n.includes("no project content yet") && n.includes("greenfield"),
2443
3063
  );
2444
3064
  assert.ok(
2445
3065
  greenfieldWarning,