gsd-pi 2.76.0 → 2.77.0-dev.538325aea

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 (1182) hide show
  1. package/README.md +32 -30
  2. package/dist/claude-cli-check.js +32 -3
  3. package/dist/cli.js +13 -21
  4. package/dist/extension-registry.js +1 -1
  5. package/dist/headless-ui.d.ts +1 -1
  6. package/dist/headless.js +2 -4
  7. package/dist/loader.js +0 -1
  8. package/dist/mcp-server.d.ts +7 -0
  9. package/dist/mcp-server.js +35 -1
  10. package/dist/onboarding.js +50 -5
  11. package/dist/provider-migrations.d.ts +2 -2
  12. package/dist/provider-migrations.js +2 -1
  13. package/dist/remote-questions-config.js +1 -1
  14. package/dist/resource-loader.d.ts +1 -1
  15. package/dist/resource-loader.js +2 -8
  16. package/dist/resources/agents/researcher.md +1 -1
  17. package/dist/resources/extensions/async-jobs/async-bash-tool.js +1 -1
  18. package/dist/resources/extensions/aws-auth/index.js +2 -1
  19. package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.js +6 -9
  20. package/dist/resources/extensions/bg-shell/process-manager.js +2 -1
  21. package/dist/resources/extensions/browser-tools/index.js +0 -1
  22. package/dist/resources/extensions/claude-code-cli/index.js +1 -1
  23. package/dist/resources/extensions/claude-code-cli/partial-builder.js +106 -17
  24. package/dist/resources/extensions/claude-code-cli/readiness.js +31 -8
  25. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +94 -27
  26. package/dist/resources/extensions/gsd/auto/loop.js +9 -0
  27. package/dist/resources/extensions/gsd/auto/phases.js +104 -11
  28. package/dist/resources/extensions/gsd/auto/run-unit.js +38 -2
  29. package/dist/resources/extensions/gsd/auto/session.js +22 -1
  30. package/dist/resources/extensions/gsd/auto-dispatch.js +56 -17
  31. package/dist/resources/extensions/gsd/auto-model-selection.js +53 -16
  32. package/dist/resources/extensions/gsd/auto-post-unit.js +59 -2
  33. package/dist/resources/extensions/gsd/auto-prompts.js +14 -0
  34. package/dist/resources/extensions/gsd/auto-recovery.js +69 -1
  35. package/dist/resources/extensions/gsd/auto-start.js +74 -59
  36. package/dist/resources/extensions/gsd/auto-verification.js +33 -0
  37. package/dist/resources/extensions/gsd/auto-worktree.js +51 -53
  38. package/dist/resources/extensions/gsd/auto.js +70 -28
  39. package/dist/resources/extensions/gsd/blocked-models.js +68 -0
  40. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +93 -1
  41. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +39 -9
  42. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +93 -0
  43. package/dist/resources/extensions/gsd/bootstrap/memory-tools.js +3 -0
  44. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +12 -0
  45. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +52 -6
  46. package/dist/resources/extensions/gsd/bootstrap/system-context.js +84 -23
  47. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +34 -2
  48. package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
  49. package/dist/resources/extensions/gsd/commands-extract-learnings.js +54 -89
  50. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
  51. package/dist/resources/extensions/gsd/compaction-snapshot.js +121 -0
  52. package/dist/resources/extensions/gsd/complexity-classifier.js +5 -3
  53. package/dist/resources/extensions/gsd/db-writer.js +88 -16
  54. package/dist/resources/extensions/gsd/dispatch-guard.js +44 -3
  55. package/dist/resources/extensions/gsd/doctor-git-checks.js +23 -29
  56. package/dist/resources/extensions/gsd/doctor-providers.js +51 -5
  57. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +1 -0
  58. package/dist/resources/extensions/gsd/error-classifier.js +31 -3
  59. package/dist/resources/extensions/gsd/exec-history.js +120 -0
  60. package/dist/resources/extensions/gsd/exec-sandbox.js +258 -0
  61. package/dist/resources/extensions/gsd/gitignore.js +1 -0
  62. package/dist/resources/extensions/gsd/gsd-db.js +168 -23
  63. package/dist/resources/extensions/gsd/guided-flow.js +191 -2
  64. package/dist/resources/extensions/gsd/health-widget.js +4 -1
  65. package/dist/resources/extensions/gsd/hook-emitter.js +108 -0
  66. package/dist/resources/extensions/gsd/init-wizard.js +15 -1
  67. package/dist/resources/extensions/gsd/key-manager.js +28 -0
  68. package/dist/resources/extensions/gsd/memory-backfill.js +126 -0
  69. package/dist/resources/extensions/gsd/memory-store.js +19 -0
  70. package/dist/resources/extensions/gsd/model-router.js +36 -3
  71. package/dist/resources/extensions/gsd/pre-execution-checks.js +44 -9
  72. package/dist/resources/extensions/gsd/preferences-types.js +9 -0
  73. package/dist/resources/extensions/gsd/preferences-validation.js +83 -0
  74. package/dist/resources/extensions/gsd/preferences.js +17 -17
  75. package/dist/resources/extensions/gsd/prompt-loader.js +22 -7
  76. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  77. package/dist/resources/extensions/gsd/prompts/complete-slice.md +2 -2
  78. package/dist/resources/extensions/gsd/prompts/debug-diagnose.md +2 -0
  79. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +8 -0
  80. package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
  81. package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
  82. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  83. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -0
  84. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -0
  85. package/dist/resources/extensions/gsd/prompts/system.md +1 -0
  86. package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
  87. package/dist/resources/extensions/gsd/safety/file-change-validator.js +13 -5
  88. package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
  89. package/dist/resources/extensions/gsd/state.js +43 -4
  90. package/dist/resources/extensions/gsd/token-counter.js +22 -5
  91. package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
  92. package/dist/resources/extensions/gsd/tools/exec-search-tool.js +59 -0
  93. package/dist/resources/extensions/gsd/tools/exec-tool.js +126 -0
  94. package/dist/resources/extensions/gsd/tools/memory-tools.js +26 -1
  95. package/dist/resources/extensions/gsd/tools/resume-tool.js +23 -0
  96. package/dist/resources/extensions/gsd/uok/plan-v2.js +20 -3
  97. package/dist/resources/extensions/gsd/workflow-mcp.js +3 -0
  98. package/dist/resources/extensions/gsd/workflow-templates/spike.md +6 -0
  99. package/dist/resources/extensions/gsd/worktree-resolver.js +50 -10
  100. package/dist/resources/extensions/mcp-client/index.js +1 -1
  101. package/dist/resources/extensions/ollama/index.js +1 -2
  102. package/dist/resources/extensions/ollama/ollama-chat-provider.js +5 -15
  103. package/dist/resources/extensions/remote-questions/config.js +12 -1
  104. package/dist/resources/extensions/search-the-web/command-search-provider.js +5 -4
  105. package/dist/resources/extensions/search-the-web/native-search.js +45 -13
  106. package/dist/resources/extensions/universal-config/index.js +1 -1
  107. package/dist/resources/skills/api-design/SKILL.md +190 -0
  108. package/dist/resources/skills/create-mcp-server/SKILL.md +121 -0
  109. package/dist/resources/skills/decompose-into-slices/SKILL.md +139 -0
  110. package/dist/resources/skills/dependency-upgrade/SKILL.md +158 -0
  111. package/dist/resources/skills/design-an-interface/SKILL.md +102 -0
  112. package/dist/resources/skills/forensics/SKILL.md +153 -0
  113. package/dist/resources/skills/grill-me/SKILL.md +93 -0
  114. package/dist/resources/skills/handoff/SKILL.md +121 -0
  115. package/dist/resources/skills/observability/SKILL.md +174 -0
  116. package/dist/resources/skills/security-review/SKILL.md +181 -0
  117. package/dist/resources/skills/spike-wrap-up/SKILL.md +138 -0
  118. package/dist/resources/skills/tdd/SKILL.md +112 -0
  119. package/dist/resources/skills/verify-before-complete/SKILL.md +98 -0
  120. package/dist/resources/skills/write-docs/SKILL.md +82 -0
  121. package/dist/resources/skills/write-milestone-brief/SKILL.md +135 -0
  122. package/dist/security-overrides.d.ts +4 -1
  123. package/dist/security-overrides.js +16 -3
  124. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  125. package/dist/web/standalone/.next/BUILD_ID +1 -1
  126. package/dist/web/standalone/.next/app-path-routes-manifest.json +11 -11
  127. package/dist/web/standalone/.next/build-manifest.json +4 -4
  128. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  129. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  130. package/dist/web/standalone/.next/required-server-files.json +4 -4
  131. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  132. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  133. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  134. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  135. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  136. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  137. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  138. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  139. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  140. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  141. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  142. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  143. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  144. package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
  145. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  146. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  147. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  148. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  149. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  150. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  151. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  152. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  153. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  154. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  155. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  156. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  157. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  158. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  159. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  160. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  161. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  162. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  163. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  164. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  165. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  166. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  167. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  168. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  169. package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
  170. package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
  171. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  172. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  173. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  174. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  175. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  176. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  177. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  178. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  179. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  180. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  181. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  182. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  183. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  184. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  185. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  186. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  187. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  188. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  189. package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
  190. package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
  191. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  192. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  193. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  194. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  195. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  196. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  197. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  198. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  199. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
  200. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  201. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  202. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  203. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  204. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  205. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  206. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  207. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  208. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  209. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  210. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  211. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  212. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  213. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  214. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  216. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  217. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  218. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
  219. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
  220. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  221. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  222. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  223. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  224. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  225. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
  226. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  228. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  229. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  230. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  232. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  233. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  234. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  235. package/dist/web/standalone/.next/server/app/index.html +1 -1
  236. package/dist/web/standalone/.next/server/app/index.rsc +4 -4
  237. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  238. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
  239. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  240. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
  241. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  242. package/dist/web/standalone/.next/server/app/page.js +2 -2
  243. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  244. package/dist/web/standalone/.next/server/app-paths-manifest.json +11 -11
  245. package/dist/web/standalone/.next/server/chunks/63.js +3 -3
  246. package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
  247. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  248. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  249. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  250. package/dist/web/standalone/.next/server/middleware.js +2 -2
  251. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  252. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  253. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  254. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  255. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  256. package/dist/web/standalone/.next/static/chunks/2826.d445fb428ef41fa1.js +9 -0
  257. package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
  258. package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
  259. package/dist/web/standalone/.next/static/chunks/app/page-5b113fd32bc2a1c3.js +1 -0
  260. package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
  261. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  262. package/dist/web/standalone/.next/static/chunks/{webpack-5fc74f13a25fa1bb.js → webpack-1832629448831fdc.js} +1 -1
  263. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  264. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  265. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  266. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  267. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  268. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  269. package/dist/web/standalone/server.js +1 -1
  270. package/dist/web-mode.js +1 -1
  271. package/dist/welcome-screen.js +19 -15
  272. package/dist/wizard.js +4 -5
  273. package/package.json +25 -7
  274. package/packages/daemon/package.json +2 -2
  275. package/packages/gsd-agent-core/dist/agent-session.d.ts +716 -0
  276. package/packages/gsd-agent-core/dist/agent-session.d.ts.map +1 -0
  277. package/packages/gsd-agent-core/dist/agent-session.js +2595 -0
  278. package/packages/gsd-agent-core/dist/agent-session.js.map +1 -0
  279. package/packages/gsd-agent-core/dist/artifact-manager.d.ts +52 -0
  280. package/packages/gsd-agent-core/dist/artifact-manager.d.ts.map +1 -0
  281. package/packages/gsd-agent-core/dist/artifact-manager.js +118 -0
  282. package/packages/gsd-agent-core/dist/artifact-manager.js.map +1 -0
  283. package/packages/gsd-agent-core/dist/bash-executor.d.ts +57 -0
  284. package/packages/gsd-agent-core/dist/bash-executor.d.ts.map +1 -0
  285. package/packages/gsd-agent-core/dist/bash-executor.js +282 -0
  286. package/packages/gsd-agent-core/dist/bash-executor.js.map +1 -0
  287. package/packages/gsd-agent-core/dist/blob-store.d.ts +39 -0
  288. package/packages/gsd-agent-core/dist/blob-store.d.ts.map +1 -0
  289. package/packages/gsd-agent-core/dist/blob-store.js +151 -0
  290. package/packages/gsd-agent-core/dist/blob-store.js.map +1 -0
  291. package/packages/gsd-agent-core/dist/compaction/branch-summarization.d.ts +90 -0
  292. package/packages/gsd-agent-core/dist/compaction/branch-summarization.d.ts.map +1 -0
  293. package/packages/gsd-agent-core/dist/compaction/branch-summarization.js +207 -0
  294. package/packages/gsd-agent-core/dist/compaction/branch-summarization.js.map +1 -0
  295. package/packages/gsd-agent-core/dist/compaction/compaction.d.ts +137 -0
  296. package/packages/gsd-agent-core/dist/compaction/compaction.d.ts.map +1 -0
  297. package/packages/gsd-agent-core/dist/compaction/compaction.js +621 -0
  298. package/packages/gsd-agent-core/dist/compaction/compaction.js.map +1 -0
  299. package/packages/gsd-agent-core/dist/compaction/index.d.ts +7 -0
  300. package/packages/gsd-agent-core/dist/compaction/index.d.ts.map +1 -0
  301. package/packages/gsd-agent-core/dist/compaction/index.js +7 -0
  302. package/packages/gsd-agent-core/dist/compaction/index.js.map +1 -0
  303. package/packages/gsd-agent-core/dist/compaction/utils.d.ts +78 -0
  304. package/packages/gsd-agent-core/dist/compaction/utils.d.ts.map +1 -0
  305. package/packages/gsd-agent-core/dist/compaction/utils.js +263 -0
  306. package/packages/gsd-agent-core/dist/compaction/utils.js.map +1 -0
  307. package/packages/gsd-agent-core/dist/compaction-orchestrator.d.ts +90 -0
  308. package/packages/gsd-agent-core/dist/compaction-orchestrator.d.ts.map +1 -0
  309. package/packages/gsd-agent-core/dist/compaction-orchestrator.js +338 -0
  310. package/packages/gsd-agent-core/dist/compaction-orchestrator.js.map +1 -0
  311. package/packages/gsd-agent-core/dist/contextual-tips.d.ts +43 -0
  312. package/packages/gsd-agent-core/dist/contextual-tips.d.ts.map +1 -0
  313. package/packages/gsd-agent-core/dist/contextual-tips.js +208 -0
  314. package/packages/gsd-agent-core/dist/contextual-tips.js.map +1 -0
  315. package/packages/gsd-agent-core/dist/export-html/ansi-to-html.d.ts +18 -0
  316. package/packages/gsd-agent-core/dist/export-html/ansi-to-html.d.ts.map +1 -0
  317. package/packages/gsd-agent-core/dist/export-html/ansi-to-html.js +250 -0
  318. package/packages/gsd-agent-core/dist/export-html/ansi-to-html.js.map +1 -0
  319. package/packages/gsd-agent-core/dist/export-html/index.d.ts +37 -0
  320. package/packages/gsd-agent-core/dist/export-html/index.d.ts.map +1 -0
  321. package/packages/gsd-agent-core/dist/export-html/index.js +257 -0
  322. package/packages/gsd-agent-core/dist/export-html/index.js.map +1 -0
  323. package/packages/gsd-agent-core/dist/export-html/template.css +971 -0
  324. package/packages/gsd-agent-core/dist/export-html/template.html +54 -0
  325. package/packages/gsd-agent-core/dist/export-html/template.js +1583 -0
  326. package/packages/gsd-agent-core/dist/export-html/tool-renderer.d.ts +38 -0
  327. package/packages/gsd-agent-core/dist/export-html/tool-renderer.d.ts.map +1 -0
  328. package/packages/gsd-agent-core/dist/export-html/tool-renderer.js +70 -0
  329. package/packages/gsd-agent-core/dist/export-html/tool-renderer.js.map +1 -0
  330. package/packages/gsd-agent-core/dist/export-html/vendor/highlight.min.js +1213 -0
  331. package/packages/gsd-agent-core/dist/export-html/vendor/marked.min.js +6 -0
  332. package/packages/gsd-agent-core/dist/fallback-resolver.d.ts +75 -0
  333. package/packages/gsd-agent-core/dist/fallback-resolver.d.ts.map +1 -0
  334. package/packages/gsd-agent-core/dist/fallback-resolver.js +118 -0
  335. package/packages/gsd-agent-core/dist/fallback-resolver.js.map +1 -0
  336. package/packages/gsd-agent-core/dist/image-overflow-recovery.d.ts +44 -0
  337. package/packages/gsd-agent-core/dist/image-overflow-recovery.d.ts.map +1 -0
  338. package/packages/gsd-agent-core/dist/image-overflow-recovery.js +99 -0
  339. package/packages/gsd-agent-core/dist/image-overflow-recovery.js.map +1 -0
  340. package/packages/gsd-agent-core/dist/index.d.ts +14 -0
  341. package/packages/gsd-agent-core/dist/index.d.ts.map +1 -0
  342. package/packages/gsd-agent-core/dist/index.js +19 -0
  343. package/packages/gsd-agent-core/dist/index.js.map +1 -0
  344. package/packages/gsd-agent-core/dist/keybindings.d.ts +47 -0
  345. package/packages/gsd-agent-core/dist/keybindings.d.ts.map +1 -0
  346. package/packages/gsd-agent-core/dist/keybindings.js +156 -0
  347. package/packages/gsd-agent-core/dist/keybindings.js.map +1 -0
  348. package/packages/gsd-agent-core/dist/lifecycle-hooks.d.ts +42 -0
  349. package/packages/gsd-agent-core/dist/lifecycle-hooks.d.ts.map +1 -0
  350. package/packages/gsd-agent-core/dist/lifecycle-hooks.js +204 -0
  351. package/packages/gsd-agent-core/dist/lifecycle-hooks.js.map +1 -0
  352. package/packages/gsd-agent-core/dist/retry-handler.d.ts +128 -0
  353. package/packages/gsd-agent-core/dist/retry-handler.d.ts.map +1 -0
  354. package/packages/gsd-agent-core/dist/retry-handler.js +518 -0
  355. package/packages/gsd-agent-core/dist/retry-handler.js.map +1 -0
  356. package/packages/gsd-agent-core/dist/sdk.d.ts +159 -0
  357. package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -0
  358. package/packages/gsd-agent-core/dist/sdk.js +375 -0
  359. package/packages/gsd-agent-core/dist/sdk.js.map +1 -0
  360. package/packages/gsd-agent-core/dist/system-prompt.d.ts +28 -0
  361. package/packages/gsd-agent-core/dist/system-prompt.d.ts.map +1 -0
  362. package/packages/gsd-agent-core/dist/system-prompt.js +201 -0
  363. package/packages/gsd-agent-core/dist/system-prompt.js.map +1 -0
  364. package/packages/gsd-agent-core/package.json +25 -0
  365. package/packages/gsd-agent-core/scripts/copy-assets.cjs +43 -0
  366. package/packages/gsd-agent-core/src/agent-session.test.ts +169 -0
  367. package/packages/gsd-agent-core/src/agent-session.ts +3358 -0
  368. package/packages/gsd-agent-core/src/artifact-manager.ts +126 -0
  369. package/packages/gsd-agent-core/src/bash-executor.ts +352 -0
  370. package/packages/gsd-agent-core/src/blob-store.ts +154 -0
  371. package/packages/gsd-agent-core/src/compaction/branch-summarization.ts +317 -0
  372. package/packages/gsd-agent-core/src/compaction/compaction.ts +855 -0
  373. package/packages/gsd-agent-core/src/compaction/index.ts +7 -0
  374. package/packages/gsd-agent-core/src/compaction/utils.ts +312 -0
  375. package/packages/gsd-agent-core/src/compaction-orchestrator.ts +449 -0
  376. package/packages/gsd-agent-core/src/contextual-tips.ts +232 -0
  377. package/packages/gsd-agent-core/src/export-html/ansi-to-html.ts +259 -0
  378. package/packages/gsd-agent-core/src/export-html/index.ts +345 -0
  379. package/packages/gsd-agent-core/src/export-html/template.css +971 -0
  380. package/packages/gsd-agent-core/src/export-html/template.html +54 -0
  381. package/packages/gsd-agent-core/src/export-html/template.js +1583 -0
  382. package/packages/gsd-agent-core/src/export-html/tool-renderer.ts +114 -0
  383. package/packages/gsd-agent-core/src/export-html/vendor/highlight.min.js +1213 -0
  384. package/packages/gsd-agent-core/src/export-html/vendor/marked.min.js +6 -0
  385. package/packages/gsd-agent-core/src/fallback-resolver.ts +193 -0
  386. package/packages/gsd-agent-core/src/image-overflow-recovery.ts +120 -0
  387. package/packages/gsd-agent-core/src/index.ts +68 -0
  388. package/packages/gsd-agent-core/src/keybindings.ts +220 -0
  389. package/packages/gsd-agent-core/src/lifecycle-hooks.ts +284 -0
  390. package/packages/gsd-agent-core/src/retry-handler.ts +620 -0
  391. package/packages/gsd-agent-core/src/sdk.ts +550 -0
  392. package/packages/gsd-agent-core/src/system-prompt.ts +270 -0
  393. package/packages/gsd-agent-core/tsconfig.json +28 -0
  394. package/packages/gsd-agent-core/tsconfig.tsbuildinfo +1 -0
  395. package/packages/gsd-agent-modes/dist/cli/args.d.ts +58 -0
  396. package/packages/gsd-agent-modes/dist/cli/args.d.ts.map +1 -0
  397. package/packages/gsd-agent-modes/dist/cli/args.js +324 -0
  398. package/packages/gsd-agent-modes/dist/cli/args.js.map +1 -0
  399. package/packages/gsd-agent-modes/dist/cli/config-selector.d.ts +13 -0
  400. package/packages/gsd-agent-modes/dist/cli/config-selector.d.ts.map +1 -0
  401. package/packages/gsd-agent-modes/dist/cli/config-selector.js +32 -0
  402. package/packages/gsd-agent-modes/dist/cli/config-selector.js.map +1 -0
  403. package/packages/gsd-agent-modes/dist/cli/file-processor.d.ts +15 -0
  404. package/packages/gsd-agent-modes/dist/cli/file-processor.d.ts.map +1 -0
  405. package/packages/gsd-agent-modes/dist/cli/file-processor.js +86 -0
  406. package/packages/gsd-agent-modes/dist/cli/file-processor.js.map +1 -0
  407. package/packages/gsd-agent-modes/dist/cli/list-models.d.ts +21 -0
  408. package/packages/gsd-agent-modes/dist/cli/list-models.d.ts.map +1 -0
  409. package/packages/gsd-agent-modes/dist/cli/list-models.js +114 -0
  410. package/packages/gsd-agent-modes/dist/cli/list-models.js.map +1 -0
  411. package/packages/gsd-agent-modes/dist/cli/session-picker.d.ts +10 -0
  412. package/packages/gsd-agent-modes/dist/cli/session-picker.d.ts.map +1 -0
  413. package/packages/gsd-agent-modes/dist/cli/session-picker.js +37 -0
  414. package/packages/gsd-agent-modes/dist/cli/session-picker.js.map +1 -0
  415. package/packages/gsd-agent-modes/dist/index.d.ts +7 -0
  416. package/packages/gsd-agent-modes/dist/index.d.ts.map +1 -0
  417. package/packages/gsd-agent-modes/dist/index.js +7 -0
  418. package/packages/gsd-agent-modes/dist/index.js.map +1 -0
  419. package/packages/gsd-agent-modes/dist/main.d.ts +8 -0
  420. package/packages/gsd-agent-modes/dist/main.d.ts.map +1 -0
  421. package/packages/gsd-agent-modes/dist/main.js +491 -0
  422. package/packages/gsd-agent-modes/dist/main.js.map +1 -0
  423. package/packages/gsd-agent-modes/dist/modes/interactive/components/armin.d.ts +34 -0
  424. package/packages/gsd-agent-modes/dist/modes/interactive/components/armin.d.ts.map +1 -0
  425. package/packages/gsd-agent-modes/dist/modes/interactive/components/armin.js +330 -0
  426. package/packages/gsd-agent-modes/dist/modes/interactive/components/armin.js.map +1 -0
  427. package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.d.ts +29 -0
  428. package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.d.ts.map +1 -0
  429. package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.js +141 -0
  430. package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.js.map +1 -0
  431. package/packages/gsd-agent-modes/dist/modes/interactive/components/bash-execution.d.ts +36 -0
  432. package/packages/gsd-agent-modes/dist/modes/interactive/components/bash-execution.d.ts.map +1 -0
  433. package/packages/gsd-agent-modes/dist/modes/interactive/components/bash-execution.js +157 -0
  434. package/packages/gsd-agent-modes/dist/modes/interactive/components/bash-execution.js.map +1 -0
  435. package/packages/gsd-agent-modes/dist/modes/interactive/components/bordered-loader.d.ts +16 -0
  436. package/packages/gsd-agent-modes/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -0
  437. package/packages/gsd-agent-modes/dist/modes/interactive/components/bordered-loader.js +48 -0
  438. package/packages/gsd-agent-modes/dist/modes/interactive/components/bordered-loader.js.map +1 -0
  439. package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.d.ts +16 -0
  440. package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -0
  441. package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.js +43 -0
  442. package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.js.map +1 -0
  443. package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-frame.d.ts +11 -0
  444. package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-frame.d.ts.map +1 -0
  445. package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-frame.js +47 -0
  446. package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-frame.js.map +1 -0
  447. package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.d.ts +16 -0
  448. package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -0
  449. package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.js +44 -0
  450. package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.js.map +1 -0
  451. package/packages/gsd-agent-modes/dist/modes/interactive/components/config-selector.d.ts +71 -0
  452. package/packages/gsd-agent-modes/dist/modes/interactive/components/config-selector.d.ts.map +1 -0
  453. package/packages/gsd-agent-modes/dist/modes/interactive/components/config-selector.js +474 -0
  454. package/packages/gsd-agent-modes/dist/modes/interactive/components/config-selector.js.map +1 -0
  455. package/packages/gsd-agent-modes/dist/modes/interactive/components/countdown-timer.d.ts +15 -0
  456. package/packages/gsd-agent-modes/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -0
  457. package/packages/gsd-agent-modes/dist/modes/interactive/components/countdown-timer.js +32 -0
  458. package/packages/gsd-agent-modes/dist/modes/interactive/components/countdown-timer.js.map +1 -0
  459. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.d.ts +22 -0
  460. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.d.ts.map +1 -0
  461. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.js +70 -0
  462. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.js.map +1 -0
  463. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-message.d.ts +20 -0
  464. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-message.d.ts.map +1 -0
  465. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-message.js +75 -0
  466. package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-message.js.map +1 -0
  467. package/packages/gsd-agent-modes/dist/modes/interactive/components/daxnuts.d.ts +23 -0
  468. package/packages/gsd-agent-modes/dist/modes/interactive/components/daxnuts.d.ts.map +1 -0
  469. package/packages/gsd-agent-modes/dist/modes/interactive/components/daxnuts.js +140 -0
  470. package/packages/gsd-agent-modes/dist/modes/interactive/components/daxnuts.js.map +1 -0
  471. package/packages/gsd-agent-modes/dist/modes/interactive/components/diff.d.ts +12 -0
  472. package/packages/gsd-agent-modes/dist/modes/interactive/components/diff.d.ts.map +1 -0
  473. package/packages/gsd-agent-modes/dist/modes/interactive/components/diff.js +133 -0
  474. package/packages/gsd-agent-modes/dist/modes/interactive/components/diff.js.map +1 -0
  475. package/packages/gsd-agent-modes/dist/modes/interactive/components/dynamic-border.d.ts +33 -0
  476. package/packages/gsd-agent-modes/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -0
  477. package/packages/gsd-agent-modes/dist/modes/interactive/components/dynamic-border.js +82 -0
  478. package/packages/gsd-agent-modes/dist/modes/interactive/components/dynamic-border.js.map +1 -0
  479. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-editor.d.ts +20 -0
  480. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-editor.d.ts.map +1 -0
  481. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-editor.js +111 -0
  482. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-editor.js.map +1 -0
  483. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-input.d.ts +24 -0
  484. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-input.d.ts.map +1 -0
  485. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-input.js +63 -0
  486. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-input.js.map +1 -0
  487. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-selector.d.ts +33 -0
  488. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-selector.d.ts.map +1 -0
  489. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-selector.js +118 -0
  490. package/packages/gsd-agent-modes/dist/modes/interactive/components/extension-selector.js.map +1 -0
  491. package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.d.ts +32 -0
  492. package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.d.ts.map +1 -0
  493. package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.js +230 -0
  494. package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.js.map +1 -0
  495. package/packages/gsd-agent-modes/dist/modes/interactive/components/index.d.ts +34 -0
  496. package/packages/gsd-agent-modes/dist/modes/interactive/components/index.d.ts.map +1 -0
  497. package/packages/gsd-agent-modes/dist/modes/interactive/components/index.js +36 -0
  498. package/packages/gsd-agent-modes/dist/modes/interactive/components/index.js.map +1 -0
  499. package/packages/gsd-agent-modes/dist/modes/interactive/components/keybinding-hints.d.ts +48 -0
  500. package/packages/gsd-agent-modes/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -0
  501. package/packages/gsd-agent-modes/dist/modes/interactive/components/keybinding-hints.js +72 -0
  502. package/packages/gsd-agent-modes/dist/modes/interactive/components/keybinding-hints.js.map +1 -0
  503. package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.d.ts +63 -0
  504. package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.d.ts.map +1 -0
  505. package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.js +213 -0
  506. package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.js.map +1 -0
  507. package/packages/gsd-agent-modes/dist/modes/interactive/components/model-selector.d.ts +86 -0
  508. package/packages/gsd-agent-modes/dist/modes/interactive/components/model-selector.d.ts.map +1 -0
  509. package/packages/gsd-agent-modes/dist/modes/interactive/components/model-selector.js +536 -0
  510. package/packages/gsd-agent-modes/dist/modes/interactive/components/model-selector.js.map +1 -0
  511. package/packages/gsd-agent-modes/dist/modes/interactive/components/oauth-selector.d.ts +19 -0
  512. package/packages/gsd-agent-modes/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -0
  513. package/packages/gsd-agent-modes/dist/modes/interactive/components/oauth-selector.js +93 -0
  514. package/packages/gsd-agent-modes/dist/modes/interactive/components/oauth-selector.js.map +1 -0
  515. package/packages/gsd-agent-modes/dist/modes/interactive/components/provider-manager.d.ts +30 -0
  516. package/packages/gsd-agent-modes/dist/modes/interactive/components/provider-manager.d.ts.map +1 -0
  517. package/packages/gsd-agent-modes/dist/modes/interactive/components/provider-manager.js +169 -0
  518. package/packages/gsd-agent-modes/dist/modes/interactive/components/provider-manager.js.map +1 -0
  519. package/packages/gsd-agent-modes/dist/modes/interactive/components/scoped-models-selector.d.ts +49 -0
  520. package/packages/gsd-agent-modes/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -0
  521. package/packages/gsd-agent-modes/dist/modes/interactive/components/scoped-models-selector.js +267 -0
  522. package/packages/gsd-agent-modes/dist/modes/interactive/components/scoped-models-selector.js.map +1 -0
  523. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector-search.d.ts +21 -0
  524. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -0
  525. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector-search.js +155 -0
  526. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector-search.js.map +1 -0
  527. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector.d.ts +97 -0
  528. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector.d.ts.map +1 -0
  529. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector.js +810 -0
  530. package/packages/gsd-agent-modes/dist/modes/interactive/components/session-selector.js.map +1 -0
  531. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +71 -0
  532. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -0
  533. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +320 -0
  534. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -0
  535. package/packages/gsd-agent-modes/dist/modes/interactive/components/show-images-selector.d.ts +10 -0
  536. package/packages/gsd-agent-modes/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -0
  537. package/packages/gsd-agent-modes/dist/modes/interactive/components/show-images-selector.js +34 -0
  538. package/packages/gsd-agent-modes/dist/modes/interactive/components/show-images-selector.js.map +1 -0
  539. package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.d.ts +17 -0
  540. package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -0
  541. package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.js +46 -0
  542. package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.js.map +1 -0
  543. package/packages/gsd-agent-modes/dist/modes/interactive/components/theme-selector.d.ts +11 -0
  544. package/packages/gsd-agent-modes/dist/modes/interactive/components/theme-selector.d.ts.map +1 -0
  545. package/packages/gsd-agent-modes/dist/modes/interactive/components/theme-selector.js +45 -0
  546. package/packages/gsd-agent-modes/dist/modes/interactive/components/theme-selector.js.map +1 -0
  547. package/packages/gsd-agent-modes/dist/modes/interactive/components/thinking-selector.d.ts +11 -0
  548. package/packages/gsd-agent-modes/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -0
  549. package/packages/gsd-agent-modes/dist/modes/interactive/components/thinking-selector.js +46 -0
  550. package/packages/gsd-agent-modes/dist/modes/interactive/components/thinking-selector.js.map +1 -0
  551. package/packages/gsd-agent-modes/dist/modes/interactive/components/timestamp.d.ts +15 -0
  552. package/packages/gsd-agent-modes/dist/modes/interactive/components/timestamp.d.ts.map +1 -0
  553. package/packages/gsd-agent-modes/dist/modes/interactive/components/timestamp.js +40 -0
  554. package/packages/gsd-agent-modes/dist/modes/interactive/components/timestamp.js.map +1 -0
  555. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +111 -0
  556. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -0
  557. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +984 -0
  558. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -0
  559. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-render-utils.d.ts +44 -0
  560. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-render-utils.d.ts.map +1 -0
  561. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-render-utils.js +61 -0
  562. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-render-utils.js.map +1 -0
  563. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-selector.d.ts +109 -0
  564. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-selector.d.ts.map +1 -0
  565. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-selector.js +1035 -0
  566. package/packages/gsd-agent-modes/dist/modes/interactive/components/tree-selector.js.map +1 -0
  567. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message-selector.d.ts +30 -0
  568. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -0
  569. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message-selector.js +112 -0
  570. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message-selector.js.map +1 -0
  571. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.d.ts +12 -0
  572. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.d.ts.map +1 -0
  573. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.js +38 -0
  574. package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.js.map +1 -0
  575. package/packages/gsd-agent-modes/dist/modes/interactive/components/visual-truncate.d.ts +24 -0
  576. package/packages/gsd-agent-modes/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -0
  577. package/packages/gsd-agent-modes/dist/modes/interactive/components/visual-truncate.js +33 -0
  578. package/packages/gsd-agent-modes/dist/modes/interactive/components/visual-truncate.js.map +1 -0
  579. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts +27 -0
  580. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -0
  581. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +793 -0
  582. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -0
  583. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.d.ts +4 -0
  584. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.d.ts.map +1 -0
  585. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.js +62 -0
  586. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.js.map +1 -0
  587. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts +22 -0
  588. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -0
  589. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +118 -0
  590. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -0
  591. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/model-controller.d.ts +7 -0
  592. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/model-controller.d.ts.map +1 -0
  593. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/model-controller.js +68 -0
  594. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/model-controller.js.map +1 -0
  595. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.d.ts +50 -0
  596. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.d.ts.map +1 -0
  597. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.js +2 -0
  598. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.js.map +1 -0
  599. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +358 -0
  600. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -0
  601. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +3409 -0
  602. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -0
  603. package/packages/gsd-agent-modes/dist/modes/interactive/slash-command-handlers.d.ts +77 -0
  604. package/packages/gsd-agent-modes/dist/modes/interactive/slash-command-handlers.d.ts.map +1 -0
  605. package/packages/gsd-agent-modes/dist/modes/interactive/slash-command-handlers.js +529 -0
  606. package/packages/gsd-agent-modes/dist/modes/interactive/slash-command-handlers.js.map +1 -0
  607. package/packages/gsd-agent-modes/dist/modes/interactive/utils/shorten-path.d.ts +6 -0
  608. package/packages/gsd-agent-modes/dist/modes/interactive/utils/shorten-path.d.ts.map +1 -0
  609. package/packages/gsd-agent-modes/dist/modes/interactive/utils/shorten-path.js +15 -0
  610. package/packages/gsd-agent-modes/dist/modes/interactive/utils/shorten-path.js.map +1 -0
  611. package/packages/gsd-agent-modes/dist/modes/print-mode.d.ts +28 -0
  612. package/packages/gsd-agent-modes/dist/modes/print-mode.d.ts.map +1 -0
  613. package/packages/gsd-agent-modes/dist/modes/print-mode.js +84 -0
  614. package/packages/gsd-agent-modes/dist/modes/print-mode.js.map +1 -0
  615. package/packages/gsd-agent-modes/dist/modes/rpc/jsonl.d.ts +17 -0
  616. package/packages/gsd-agent-modes/dist/modes/rpc/jsonl.d.ts.map +1 -0
  617. package/packages/gsd-agent-modes/dist/modes/rpc/jsonl.js +49 -0
  618. package/packages/gsd-agent-modes/dist/modes/rpc/jsonl.js.map +1 -0
  619. package/packages/gsd-agent-modes/dist/modes/rpc/remote-terminal.d.ts +37 -0
  620. package/packages/gsd-agent-modes/dist/modes/rpc/remote-terminal.d.ts.map +1 -0
  621. package/packages/gsd-agent-modes/dist/modes/rpc/remote-terminal.js +84 -0
  622. package/packages/gsd-agent-modes/dist/modes/rpc/remote-terminal.js.map +1 -0
  623. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-client.d.ts +243 -0
  624. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-client.d.ts.map +1 -0
  625. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-client.js +464 -0
  626. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-client.js.map +1 -0
  627. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts +25 -0
  628. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -0
  629. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +750 -0
  630. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -0
  631. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-types.d.ts +511 -0
  632. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-types.d.ts.map +1 -0
  633. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-types.js +8 -0
  634. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-types.js.map +1 -0
  635. package/packages/gsd-agent-modes/dist/modes/shared/command-context-actions.d.ts +19 -0
  636. package/packages/gsd-agent-modes/dist/modes/shared/command-context-actions.d.ts.map +1 -0
  637. package/packages/gsd-agent-modes/dist/modes/shared/command-context-actions.js +45 -0
  638. package/packages/gsd-agent-modes/dist/modes/shared/command-context-actions.js.map +1 -0
  639. package/packages/gsd-agent-modes/dist/pi-coding-agent-compat.d.ts +22 -0
  640. package/packages/gsd-agent-modes/dist/pi-coding-agent-compat.d.ts.map +1 -0
  641. package/packages/gsd-agent-modes/dist/pi-coding-agent-compat.js +21 -0
  642. package/packages/gsd-agent-modes/dist/pi-coding-agent-compat.js.map +1 -0
  643. package/packages/gsd-agent-modes/dist/pi-tui-compat.d.ts +4 -0
  644. package/packages/gsd-agent-modes/dist/pi-tui-compat.d.ts.map +1 -0
  645. package/packages/gsd-agent-modes/dist/pi-tui-compat.js +3 -0
  646. package/packages/gsd-agent-modes/dist/pi-tui-compat.js.map +1 -0
  647. package/packages/gsd-agent-modes/dist/theme.d.ts +15 -0
  648. package/packages/gsd-agent-modes/dist/theme.d.ts.map +1 -0
  649. package/packages/gsd-agent-modes/dist/theme.js +23 -0
  650. package/packages/gsd-agent-modes/dist/theme.js.map +1 -0
  651. package/packages/gsd-agent-modes/dist/utils/theme.d.ts +16 -0
  652. package/packages/gsd-agent-modes/dist/utils/theme.d.ts.map +1 -0
  653. package/packages/gsd-agent-modes/dist/utils/theme.js +11 -0
  654. package/packages/gsd-agent-modes/dist/utils/theme.js.map +1 -0
  655. package/packages/gsd-agent-modes/package.json +23 -0
  656. package/packages/gsd-agent-modes/src/cli/args.ts +350 -0
  657. package/packages/gsd-agent-modes/src/cli/config-selector.ts +54 -0
  658. package/packages/gsd-agent-modes/src/cli/file-processor.ts +107 -0
  659. package/packages/gsd-agent-modes/src/cli/list-models.ts +141 -0
  660. package/packages/gsd-agent-modes/src/cli/session-picker.ts +59 -0
  661. package/packages/gsd-agent-modes/src/index.ts +6 -0
  662. package/packages/gsd-agent-modes/src/main.ts +614 -0
  663. package/packages/gsd-agent-modes/src/modes/interactive/components/__tests__/login-dialog.test.ts +24 -0
  664. package/packages/gsd-agent-modes/src/modes/interactive/components/__tests__/provider-display-name.test.ts +18 -0
  665. package/packages/gsd-agent-modes/src/modes/interactive/components/__tests__/timestamp.test.ts +38 -0
  666. package/packages/gsd-agent-modes/src/modes/interactive/components/__tests__/tool-execution.test.ts +171 -0
  667. package/packages/gsd-agent-modes/src/modes/interactive/components/armin.ts +382 -0
  668. package/packages/gsd-agent-modes/src/modes/interactive/components/assistant-message.ts +178 -0
  669. package/packages/gsd-agent-modes/src/modes/interactive/components/bash-execution.ts +212 -0
  670. package/packages/gsd-agent-modes/src/modes/interactive/components/bordered-loader.ts +66 -0
  671. package/packages/gsd-agent-modes/src/modes/interactive/components/branch-summary-message.ts +59 -0
  672. package/packages/gsd-agent-modes/src/modes/interactive/components/chat-frame.ts +67 -0
  673. package/packages/gsd-agent-modes/src/modes/interactive/components/compaction-summary-message.ts +60 -0
  674. package/packages/gsd-agent-modes/src/modes/interactive/components/config-selector.ts +597 -0
  675. package/packages/gsd-agent-modes/src/modes/interactive/components/countdown-timer.ts +41 -0
  676. package/packages/gsd-agent-modes/src/modes/interactive/components/custom-editor.ts +88 -0
  677. package/packages/gsd-agent-modes/src/modes/interactive/components/custom-message.ts +100 -0
  678. package/packages/gsd-agent-modes/src/modes/interactive/components/daxnuts.ts +165 -0
  679. package/packages/gsd-agent-modes/src/modes/interactive/components/diff.ts +147 -0
  680. package/packages/gsd-agent-modes/src/modes/interactive/components/dynamic-border.test.ts +73 -0
  681. package/packages/gsd-agent-modes/src/modes/interactive/components/dynamic-border.ts +89 -0
  682. package/packages/gsd-agent-modes/src/modes/interactive/components/extension-editor.ts +151 -0
  683. package/packages/gsd-agent-modes/src/modes/interactive/components/extension-input.ts +100 -0
  684. package/packages/gsd-agent-modes/src/modes/interactive/components/extension-selector.ts +156 -0
  685. package/packages/gsd-agent-modes/src/modes/interactive/components/footer.ts +257 -0
  686. package/packages/gsd-agent-modes/src/modes/interactive/components/index.ts +35 -0
  687. package/packages/gsd-agent-modes/src/modes/interactive/components/keybinding-hints.ts +84 -0
  688. package/packages/gsd-agent-modes/src/modes/interactive/components/login-dialog.ts +257 -0
  689. package/packages/gsd-agent-modes/src/modes/interactive/components/model-selector.ts +656 -0
  690. package/packages/gsd-agent-modes/src/modes/interactive/components/oauth-selector.ts +122 -0
  691. package/packages/gsd-agent-modes/src/modes/interactive/components/provider-manager.ts +210 -0
  692. package/packages/gsd-agent-modes/src/modes/interactive/components/scoped-models-selector.ts +342 -0
  693. package/packages/gsd-agent-modes/src/modes/interactive/components/session-selector-search.ts +194 -0
  694. package/packages/gsd-agent-modes/src/modes/interactive/components/session-selector.ts +1011 -0
  695. package/packages/gsd-agent-modes/src/modes/interactive/components/settings-selector.ts +452 -0
  696. package/packages/gsd-agent-modes/src/modes/interactive/components/show-images-selector.ts +45 -0
  697. package/packages/gsd-agent-modes/src/modes/interactive/components/skill-invocation-message.ts +56 -0
  698. package/packages/gsd-agent-modes/src/modes/interactive/components/theme-selector.ts +63 -0
  699. package/packages/gsd-agent-modes/src/modes/interactive/components/thinking-selector.ts +64 -0
  700. package/packages/gsd-agent-modes/src/modes/interactive/components/timestamp.ts +48 -0
  701. package/packages/gsd-agent-modes/src/modes/interactive/components/tool-execution.ts +1157 -0
  702. package/packages/gsd-agent-modes/src/modes/interactive/components/tree-render-utils.ts +81 -0
  703. package/packages/gsd-agent-modes/src/modes/interactive/components/tree-selector.ts +1208 -0
  704. package/packages/gsd-agent-modes/src/modes/interactive/components/user-message-selector.ts +145 -0
  705. package/packages/gsd-agent-modes/src/modes/interactive/components/user-message.ts +44 -0
  706. package/packages/gsd-agent-modes/src/modes/interactive/components/visual-truncate.ts +50 -0
  707. package/packages/gsd-agent-modes/src/modes/interactive/controllers/chat-controller-ordering.test.ts +1430 -0
  708. package/packages/gsd-agent-modes/src/modes/interactive/controllers/chat-controller.test.ts +71 -0
  709. package/packages/gsd-agent-modes/src/modes/interactive/controllers/chat-controller.ts +957 -0
  710. package/packages/gsd-agent-modes/src/modes/interactive/controllers/extension-ui-controller.ts +63 -0
  711. package/packages/gsd-agent-modes/src/modes/interactive/controllers/input-controller.test.ts +183 -0
  712. package/packages/gsd-agent-modes/src/modes/interactive/controllers/input-controller.ts +140 -0
  713. package/packages/gsd-agent-modes/src/modes/interactive/controllers/model-controller.ts +77 -0
  714. package/packages/gsd-agent-modes/src/modes/interactive/interactive-mode-ordering.test.ts +44 -0
  715. package/packages/gsd-agent-modes/src/modes/interactive/interactive-mode-state.ts +49 -0
  716. package/packages/gsd-agent-modes/src/modes/interactive/interactive-mode.ts +4195 -0
  717. package/packages/gsd-agent-modes/src/modes/interactive/slash-command-handlers.ts +670 -0
  718. package/packages/gsd-agent-modes/src/modes/interactive/utils/shorten-path.ts +14 -0
  719. package/packages/gsd-agent-modes/src/modes/print-mode.ts +106 -0
  720. package/packages/gsd-agent-modes/src/modes/rpc/jsonl.ts +58 -0
  721. package/packages/gsd-agent-modes/src/modes/rpc/remote-terminal.ts +109 -0
  722. package/packages/gsd-agent-modes/src/modes/rpc/rpc-client.ts +572 -0
  723. package/packages/gsd-agent-modes/src/modes/rpc/rpc-mode.ts +902 -0
  724. package/packages/gsd-agent-modes/src/modes/rpc/rpc-protocol-v2.test.ts +971 -0
  725. package/packages/gsd-agent-modes/src/modes/rpc/rpc-types.ts +335 -0
  726. package/packages/gsd-agent-modes/src/modes/shared/command-context-actions.ts +53 -0
  727. package/packages/gsd-agent-modes/src/pi-coding-agent-compat.ts +42 -0
  728. package/packages/gsd-agent-modes/src/pi-tui-compat.ts +4 -0
  729. package/packages/gsd-agent-modes/src/theme.ts +25 -0
  730. package/packages/gsd-agent-modes/src/utils/theme.ts +24 -0
  731. package/packages/gsd-agent-modes/tsconfig.json +28 -0
  732. package/packages/gsd-agent-modes/tsconfig.tsbuildinfo +1 -0
  733. package/packages/gsd-agent-types/dist/index.d.ts +176 -0
  734. package/packages/gsd-agent-types/dist/index.d.ts.map +1 -0
  735. package/packages/gsd-agent-types/dist/index.js +24 -0
  736. package/packages/gsd-agent-types/dist/index.js.map +1 -0
  737. package/packages/gsd-agent-types/package.json +24 -0
  738. package/packages/gsd-agent-types/src/index.ts +206 -0
  739. package/packages/gsd-agent-types/tsconfig.json +25 -0
  740. package/packages/gsd-agent-types/tsconfig.tsbuildinfo +1 -0
  741. package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
  742. package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
  743. package/packages/mcp-server/dist/remote-questions.js +732 -0
  744. package/packages/mcp-server/dist/remote-questions.js.map +1 -0
  745. package/packages/mcp-server/dist/server.d.ts +7 -0
  746. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  747. package/packages/mcp-server/dist/server.js +77 -11
  748. package/packages/mcp-server/dist/server.js.map +1 -1
  749. package/packages/mcp-server/dist/session-manager.d.ts +14 -0
  750. package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
  751. package/packages/mcp-server/dist/session-manager.js +49 -1
  752. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  753. package/packages/mcp-server/dist/workflow-tools.d.ts +1 -1
  754. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  755. package/packages/mcp-server/dist/workflow-tools.js +163 -25
  756. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  757. package/packages/mcp-server/package.json +4 -3
  758. package/packages/mcp-server/src/mcp-server.test.ts +67 -0
  759. package/packages/mcp-server/src/remote-questions.test.ts +294 -0
  760. package/packages/mcp-server/src/remote-questions.ts +916 -0
  761. package/packages/mcp-server/src/server.ts +94 -18
  762. package/packages/mcp-server/src/session-manager.ts +43 -1
  763. package/packages/mcp-server/src/workflow-tools.test.ts +146 -1
  764. package/packages/mcp-server/src/workflow-tools.ts +215 -43
  765. package/packages/mcp-server/tsconfig.test.json +19 -0
  766. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  767. package/packages/native/dist/tsconfig.tsbuildinfo +1 -0
  768. package/packages/native/package.json +1 -1
  769. package/packages/native/tsconfig.json +2 -1
  770. package/packages/pi-agent-core/dist/agent-loop.js +12 -0
  771. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  772. package/packages/pi-agent-core/dist/types.d.ts +30 -0
  773. package/packages/pi-agent-core/dist/types.d.ts.map +1 -1
  774. package/packages/pi-agent-core/dist/types.js.map +1 -1
  775. package/packages/pi-agent-core/package.json +1 -1
  776. package/packages/pi-agent-core/src/agent-loop.ts +14 -0
  777. package/packages/pi-agent-core/src/types.ts +34 -0
  778. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  779. package/packages/pi-ai/dist/models/custom.d.ts +38 -0
  780. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
  781. package/packages/pi-ai/dist/models/custom.js +41 -0
  782. package/packages/pi-ai/dist/models/custom.js.map +1 -1
  783. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
  784. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  785. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.d.ts +2 -0
  786. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.d.ts.map +1 -0
  787. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js +13 -0
  788. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js.map +1 -0
  789. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  790. package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
  791. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  792. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  793. package/packages/pi-ai/dist/providers/anthropic.js +13 -4
  794. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  795. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
  796. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
  797. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
  798. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
  799. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  800. package/packages/pi-ai/dist/providers/openai-completions.js +60 -15
  801. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  802. package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
  803. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  804. package/packages/pi-ai/dist/providers/simple-options.js +16 -1
  805. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  806. package/packages/pi-ai/dist/providers/think-tag-parser.d.ts +17 -0
  807. package/packages/pi-ai/dist/providers/think-tag-parser.d.ts.map +1 -0
  808. package/packages/pi-ai/dist/providers/think-tag-parser.js +75 -0
  809. package/packages/pi-ai/dist/providers/think-tag-parser.js.map +1 -0
  810. package/packages/pi-ai/dist/providers/think-tag-parser.test.d.ts +2 -0
  811. package/packages/pi-ai/dist/providers/think-tag-parser.test.d.ts.map +1 -0
  812. package/packages/pi-ai/dist/providers/think-tag-parser.test.js +41 -0
  813. package/packages/pi-ai/dist/providers/think-tag-parser.test.js.map +1 -0
  814. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  815. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +12 -2
  816. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  817. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js +164 -14
  818. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js.map +1 -1
  819. package/packages/pi-ai/dist/utils/oauth/google-antigravity.d.ts.map +1 -1
  820. package/packages/pi-ai/dist/utils/oauth/google-antigravity.js +15 -3
  821. package/packages/pi-ai/dist/utils/oauth/google-antigravity.js.map +1 -1
  822. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.d.ts +2 -0
  823. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.d.ts.map +1 -0
  824. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js +67 -0
  825. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js.map +1 -0
  826. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.d.ts.map +1 -1
  827. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.js +16 -3
  828. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.js.map +1 -1
  829. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.d.ts +2 -0
  830. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.d.ts.map +1 -0
  831. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js +67 -0
  832. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js.map +1 -0
  833. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts +2 -0
  834. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts.map +1 -0
  835. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js +289 -0
  836. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js.map +1 -0
  837. package/packages/pi-ai/package.json +1 -1
  838. package/packages/pi-ai/src/models/custom.ts +42 -0
  839. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
  840. package/packages/pi-ai/src/providers/anthropic-bearer-auth.test.ts +26 -0
  841. package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
  842. package/packages/pi-ai/src/providers/anthropic.ts +15 -4
  843. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
  844. package/packages/pi-ai/src/providers/openai-completions.ts +57 -16
  845. package/packages/pi-ai/src/providers/simple-options.ts +17 -1
  846. package/packages/pi-ai/src/providers/think-tag-parser.test.ts +44 -0
  847. package/packages/pi-ai/src/providers/think-tag-parser.ts +94 -0
  848. package/packages/pi-ai/src/utils/oauth/github-copilot.test.ts +200 -23
  849. package/packages/pi-ai/src/utils/oauth/github-copilot.ts +12 -2
  850. package/packages/pi-ai/src/utils/oauth/google-antigravity.test.ts +84 -0
  851. package/packages/pi-ai/src/utils/oauth/google-antigravity.ts +15 -5
  852. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.test.ts +84 -0
  853. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.ts +16 -5
  854. package/packages/pi-ai/src/utils/oauth/oauth-providers.test.ts +363 -0
  855. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  856. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +3 -2
  857. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  858. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  859. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  860. package/packages/pi-coding-agent/dist/core/agent-session.js +32 -2
  861. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  862. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  863. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  864. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  865. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  866. package/packages/pi-coding-agent/dist/core/extensions/loader.js +4 -0
  867. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  868. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +35 -2
  869. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  870. package/packages/pi-coding-agent/dist/core/extensions/runner.js +233 -0
  871. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  872. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +205 -2
  873. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  874. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  875. package/packages/pi-coding-agent/dist/core/hooks-runner.d.ts +53 -0
  876. package/packages/pi-coding-agent/dist/core/hooks-runner.d.ts.map +1 -0
  877. package/packages/pi-coding-agent/dist/core/hooks-runner.js +337 -0
  878. package/packages/pi-coding-agent/dist/core/hooks-runner.js.map +1 -0
  879. package/packages/pi-coding-agent/dist/core/hooks-runner.test.d.ts +2 -0
  880. package/packages/pi-coding-agent/dist/core/hooks-runner.test.d.ts.map +1 -0
  881. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js +234 -0
  882. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js.map +1 -0
  883. package/packages/pi-coding-agent/dist/core/index.d.ts +1 -0
  884. package/packages/pi-coding-agent/dist/core/index.d.ts.map +1 -1
  885. package/packages/pi-coding-agent/dist/core/index.js +1 -0
  886. package/packages/pi-coding-agent/dist/core/index.js.map +1 -1
  887. package/packages/pi-coding-agent/dist/core/model-discovery.d.ts +3 -1
  888. package/packages/pi-coding-agent/dist/core/model-discovery.d.ts.map +1 -1
  889. package/packages/pi-coding-agent/dist/core/model-discovery.js +92 -12
  890. package/packages/pi-coding-agent/dist/core/model-discovery.js.map +1 -1
  891. package/packages/pi-coding-agent/dist/core/model-discovery.test.js +16 -1
  892. package/packages/pi-coding-agent/dist/core/model-discovery.test.js.map +1 -1
  893. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.d.ts +2 -0
  894. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.d.ts.map +1 -0
  895. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.js +40 -0
  896. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.js.map +1 -0
  897. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
  898. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
  899. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
  900. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
  901. package/packages/pi-coding-agent/dist/core/model-registry-discovery.test.js +61 -1
  902. package/packages/pi-coding-agent/dist/core/model-registry-discovery.test.js.map +1 -1
  903. package/packages/pi-coding-agent/dist/core/model-registry.d.ts +5 -0
  904. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  905. package/packages/pi-coding-agent/dist/core/model-registry.js +90 -10
  906. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  907. package/packages/pi-coding-agent/dist/core/redact-secrets.d.ts +2 -0
  908. package/packages/pi-coding-agent/dist/core/redact-secrets.d.ts.map +1 -0
  909. package/packages/pi-coding-agent/dist/core/redact-secrets.js +49 -0
  910. package/packages/pi-coding-agent/dist/core/redact-secrets.js.map +1 -0
  911. package/packages/pi-coding-agent/dist/core/redact-secrets.test.d.ts +2 -0
  912. package/packages/pi-coding-agent/dist/core/redact-secrets.test.d.ts.map +1 -0
  913. package/packages/pi-coding-agent/dist/core/redact-secrets.test.js +67 -0
  914. package/packages/pi-coding-agent/dist/core/redact-secrets.test.js.map +1 -0
  915. package/packages/pi-coding-agent/dist/core/session-manager.d.ts.map +1 -1
  916. package/packages/pi-coding-agent/dist/core/session-manager.js +10 -6
  917. package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  918. package/packages/pi-coding-agent/dist/core/session-manager.test.js +45 -1
  919. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  920. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +55 -0
  921. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  922. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  923. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  924. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  925. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  926. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +1 -1
  927. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -1
  928. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +5 -4
  929. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -1
  930. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.d.ts.map +1 -1
  931. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.js +13 -7
  932. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.js.map +1 -1
  933. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts +7 -6
  934. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -1
  935. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js +29 -21
  936. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js.map +1 -1
  937. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  938. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +13 -1
  939. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  940. package/packages/pi-coding-agent/package.json +1 -1
  941. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +3 -2
  942. package/packages/pi-coding-agent/src/core/agent-session.ts +38 -2
  943. package/packages/pi-coding-agent/src/core/extensions/index.ts +16 -0
  944. package/packages/pi-coding-agent/src/core/extensions/loader.ts +5 -0
  945. package/packages/pi-coding-agent/src/core/extensions/runner.ts +351 -0
  946. package/packages/pi-coding-agent/src/core/extensions/types.ts +258 -0
  947. package/packages/pi-coding-agent/src/core/hooks-runner.test.ts +269 -0
  948. package/packages/pi-coding-agent/src/core/hooks-runner.ts +460 -0
  949. package/packages/pi-coding-agent/src/core/index.ts +10 -0
  950. package/packages/pi-coding-agent/src/core/model-discovery.test.ts +19 -0
  951. package/packages/pi-coding-agent/src/core/model-discovery.ts +99 -12
  952. package/packages/pi-coding-agent/src/core/model-registry-auth-header.test.ts +44 -0
  953. package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
  954. package/packages/pi-coding-agent/src/core/model-registry-discovery.test.ts +75 -0
  955. package/packages/pi-coding-agent/src/core/model-registry.ts +102 -10
  956. package/packages/pi-coding-agent/src/core/redact-secrets.test.ts +86 -0
  957. package/packages/pi-coding-agent/src/core/redact-secrets.ts +58 -0
  958. package/packages/pi-coding-agent/src/core/session-manager.test.ts +65 -1
  959. package/packages/pi-coding-agent/src/core/session-manager.ts +10 -6
  960. package/packages/pi-coding-agent/src/core/settings-manager.ts +57 -0
  961. package/packages/pi-coding-agent/src/index.ts +16 -0
  962. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +6 -6
  963. package/packages/pi-coding-agent/src/modes/interactive/components/provider-manager.ts +16 -7
  964. package/packages/pi-coding-agent/src/modes/interactive/components/skill-invocation-message.ts +36 -22
  965. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +13 -1
  966. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  967. package/packages/pi-tui/package.json +1 -1
  968. package/packages/rpc-client/package.json +1 -1
  969. package/pkg/dist/core/export-html/ansi-to-html.d.ts.map +1 -1
  970. package/pkg/dist/core/export-html/ansi-to-html.js +1 -0
  971. package/pkg/dist/core/export-html/ansi-to-html.js.map +1 -1
  972. package/pkg/dist/core/export-html/index.d.ts +1 -1
  973. package/pkg/dist/core/export-html/index.d.ts.map +1 -1
  974. package/pkg/dist/core/export-html/index.js +39 -5
  975. package/pkg/dist/core/export-html/index.js.map +1 -1
  976. package/pkg/dist/core/export-html/tool-renderer.d.ts +2 -2
  977. package/pkg/dist/core/export-html/tool-renderer.d.ts.map +1 -1
  978. package/pkg/dist/core/export-html/tool-renderer.js.map +1 -1
  979. package/pkg/package.json +1 -1
  980. package/scripts/ensure-workspace-builds.cjs +2 -0
  981. package/scripts/install.js +512 -0
  982. package/scripts/link-workspace-packages.cjs +3 -0
  983. package/scripts/postinstall.js +9 -178
  984. package/src/resources/agents/researcher.md +1 -1
  985. package/src/resources/extensions/async-jobs/async-bash-tool.ts +1 -1
  986. package/src/resources/extensions/aws-auth/index.ts +2 -1
  987. package/src/resources/extensions/bg-shell/bg-shell-lifecycle.ts +4 -7
  988. package/src/resources/extensions/bg-shell/index.ts +2 -1
  989. package/src/resources/extensions/bg-shell/process-manager.ts +2 -1
  990. package/src/resources/extensions/browser-tools/index.ts +2 -1
  991. package/src/resources/extensions/claude-code-cli/index.ts +1 -1
  992. package/src/resources/extensions/claude-code-cli/partial-builder.ts +115 -23
  993. package/src/resources/extensions/claude-code-cli/readiness.ts +32 -8
  994. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +97 -26
  995. package/src/resources/extensions/claude-code-cli/tests/provider-registration.test.ts +27 -0
  996. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +176 -8
  997. package/src/resources/extensions/gsd/auto/loop-deps.ts +14 -0
  998. package/src/resources/extensions/gsd/auto/loop.ts +9 -0
  999. package/src/resources/extensions/gsd/auto/phases.ts +131 -10
  1000. package/src/resources/extensions/gsd/auto/run-unit.ts +40 -2
  1001. package/src/resources/extensions/gsd/auto/session.ts +35 -2
  1002. package/src/resources/extensions/gsd/auto-dispatch.ts +59 -16
  1003. package/src/resources/extensions/gsd/auto-model-selection.ts +71 -15
  1004. package/src/resources/extensions/gsd/auto-post-unit.ts +62 -3
  1005. package/src/resources/extensions/gsd/auto-prompts.ts +28 -1
  1006. package/src/resources/extensions/gsd/auto-recovery.ts +62 -1
  1007. package/src/resources/extensions/gsd/auto-start.ts +80 -74
  1008. package/src/resources/extensions/gsd/auto-verification.ts +33 -0
  1009. package/src/resources/extensions/gsd/auto-worktree.ts +62 -63
  1010. package/src/resources/extensions/gsd/auto.ts +73 -28
  1011. package/src/resources/extensions/gsd/blocked-models.ts +98 -0
  1012. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +120 -1
  1013. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +40 -9
  1014. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +109 -0
  1015. package/src/resources/extensions/gsd/bootstrap/memory-tools.ts +5 -0
  1016. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +15 -0
  1017. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +54 -6
  1018. package/src/resources/extensions/gsd/bootstrap/system-context.ts +89 -26
  1019. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +35 -2
  1020. package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
  1021. package/src/resources/extensions/gsd/commands-extract-learnings.ts +55 -90
  1022. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
  1023. package/src/resources/extensions/gsd/compaction-snapshot.ts +165 -0
  1024. package/src/resources/extensions/gsd/complexity-classifier.ts +5 -3
  1025. package/src/resources/extensions/gsd/db-writer.ts +88 -17
  1026. package/src/resources/extensions/gsd/dispatch-guard.ts +44 -2
  1027. package/src/resources/extensions/gsd/doctor-git-checks.ts +23 -27
  1028. package/src/resources/extensions/gsd/doctor-providers.ts +59 -6
  1029. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +2 -0
  1030. package/src/resources/extensions/gsd/error-classifier.ts +36 -3
  1031. package/src/resources/extensions/gsd/exec-history.ts +153 -0
  1032. package/src/resources/extensions/gsd/exec-sandbox.ts +326 -0
  1033. package/src/resources/extensions/gsd/gitignore.ts +1 -1
  1034. package/src/resources/extensions/gsd/gsd-db.ts +186 -23
  1035. package/src/resources/extensions/gsd/guided-flow.ts +223 -2
  1036. package/src/resources/extensions/gsd/health-widget.ts +3 -1
  1037. package/src/resources/extensions/gsd/hook-emitter.ts +188 -0
  1038. package/src/resources/extensions/gsd/init-wizard.ts +15 -1
  1039. package/src/resources/extensions/gsd/journal.ts +2 -1
  1040. package/src/resources/extensions/gsd/key-manager.ts +28 -0
  1041. package/src/resources/extensions/gsd/memory-backfill.ts +140 -0
  1042. package/src/resources/extensions/gsd/memory-store.ts +26 -0
  1043. package/src/resources/extensions/gsd/model-router.ts +42 -1
  1044. package/src/resources/extensions/gsd/pre-execution-checks.ts +46 -10
  1045. package/src/resources/extensions/gsd/preferences-types.ts +46 -0
  1046. package/src/resources/extensions/gsd/preferences-validation.ts +79 -0
  1047. package/src/resources/extensions/gsd/preferences.ts +17 -17
  1048. package/src/resources/extensions/gsd/prompt-loader.ts +30 -7
  1049. package/src/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  1050. package/src/resources/extensions/gsd/prompts/complete-slice.md +2 -2
  1051. package/src/resources/extensions/gsd/prompts/debug-diagnose.md +2 -0
  1052. package/src/resources/extensions/gsd/prompts/discuss-headless.md +8 -0
  1053. package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
  1054. package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
  1055. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  1056. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -0
  1057. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -0
  1058. package/src/resources/extensions/gsd/prompts/system.md +1 -0
  1059. package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
  1060. package/src/resources/extensions/gsd/safety/file-change-validator.ts +17 -4
  1061. package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
  1062. package/src/resources/extensions/gsd/state.ts +45 -4
  1063. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +188 -2
  1064. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +95 -1
  1065. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
  1066. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +122 -0
  1067. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
  1068. package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +63 -0
  1069. package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +33 -3
  1070. package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +38 -0
  1071. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
  1072. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +98 -0
  1073. package/src/resources/extensions/gsd/tests/bundled-skill-triggers.test.ts +54 -0
  1074. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
  1075. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +68 -66
  1076. package/src/resources/extensions/gsd/tests/compaction-snapshot.test.ts +123 -0
  1077. package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +15 -0
  1078. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
  1079. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  1080. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  1081. package/src/resources/extensions/gsd/tests/complexity-classifier.test.ts +3 -3
  1082. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +2 -0
  1083. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +42 -0
  1084. package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +8 -4
  1085. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +9 -9
  1086. package/src/resources/extensions/gsd/tests/dispatch-guard-summary-db-mismatch.test.ts +77 -0
  1087. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +148 -3
  1088. package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +1 -1
  1089. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +306 -1
  1090. package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
  1091. package/src/resources/extensions/gsd/tests/exec-history.test.ts +237 -0
  1092. package/src/resources/extensions/gsd/tests/exec-sandbox.test.ts +210 -0
  1093. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +58 -0
  1094. package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +40 -9
  1095. package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +62 -0
  1096. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +447 -1
  1097. package/src/resources/extensions/gsd/tests/init-wizard.test.ts +27 -0
  1098. package/src/resources/extensions/gsd/tests/integration/doctor-git-symlink-cwd.test.ts +11 -0
  1099. package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +78 -0
  1100. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +1 -0
  1101. package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
  1102. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
  1103. package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +11 -0
  1104. package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +1 -1
  1105. package/src/resources/extensions/gsd/tests/isolation-none-branch-guard.test.ts +1 -1
  1106. package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
  1107. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +37 -0
  1108. package/src/resources/extensions/gsd/tests/key-manager.test.ts +9 -0
  1109. package/src/resources/extensions/gsd/tests/load-memory-block.test.ts +36 -0
  1110. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  1111. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
  1112. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  1113. package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +3 -3
  1114. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +19 -0
  1115. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
  1116. package/src/resources/extensions/gsd/tests/pre-exec-backtick-strip.test.ts +14 -0
  1117. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
  1118. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +356 -0
  1119. package/src/resources/extensions/gsd/tests/preferences.test.ts +110 -0
  1120. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
  1121. package/src/resources/extensions/gsd/tests/prompt-loader-extension-dir.test.ts +49 -0
  1122. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +103 -4
  1123. package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
  1124. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +9 -3
  1125. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
  1126. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
  1127. package/src/resources/extensions/gsd/tests/save-gate-result-render.test.ts +95 -0
  1128. package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
  1129. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
  1130. package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
  1131. package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
  1132. package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
  1133. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +23 -0
  1134. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +136 -8
  1135. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
  1136. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +35 -0
  1137. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
  1138. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
  1139. package/src/resources/extensions/gsd/tests/write-gate.test.ts +64 -0
  1140. package/src/resources/extensions/gsd/tests/zombie-gsd-state.test.ts +3 -1
  1141. package/src/resources/extensions/gsd/token-counter.ts +22 -5
  1142. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  1143. package/src/resources/extensions/gsd/tools/exec-search-tool.ts +81 -0
  1144. package/src/resources/extensions/gsd/tools/exec-tool.ts +183 -0
  1145. package/src/resources/extensions/gsd/tools/memory-tools.ts +31 -1
  1146. package/src/resources/extensions/gsd/tools/resume-tool.ts +40 -0
  1147. package/src/resources/extensions/gsd/uok/plan-v2.ts +26 -3
  1148. package/src/resources/extensions/gsd/workflow-logger.ts +4 -1
  1149. package/src/resources/extensions/gsd/workflow-mcp.ts +3 -0
  1150. package/src/resources/extensions/gsd/workflow-templates/spike.md +6 -0
  1151. package/src/resources/extensions/gsd/worktree-resolver.ts +54 -9
  1152. package/src/resources/extensions/mcp-client/index.ts +1 -1
  1153. package/src/resources/extensions/ollama/index.ts +3 -3
  1154. package/src/resources/extensions/ollama/ollama-chat-provider.ts +6 -18
  1155. package/src/resources/extensions/remote-questions/config.ts +15 -4
  1156. package/src/resources/extensions/search-the-web/command-search-provider.ts +5 -4
  1157. package/src/resources/extensions/search-the-web/index.ts +2 -1
  1158. package/src/resources/extensions/search-the-web/native-search.ts +48 -12
  1159. package/src/resources/extensions/shared/tests/format-utils.test.ts +5 -3
  1160. package/src/resources/extensions/universal-config/index.ts +1 -1
  1161. package/src/resources/skills/api-design/SKILL.md +190 -0
  1162. package/src/resources/skills/create-mcp-server/SKILL.md +121 -0
  1163. package/src/resources/skills/decompose-into-slices/SKILL.md +139 -0
  1164. package/src/resources/skills/dependency-upgrade/SKILL.md +158 -0
  1165. package/src/resources/skills/design-an-interface/SKILL.md +102 -0
  1166. package/src/resources/skills/forensics/SKILL.md +153 -0
  1167. package/src/resources/skills/grill-me/SKILL.md +93 -0
  1168. package/src/resources/skills/handoff/SKILL.md +121 -0
  1169. package/src/resources/skills/observability/SKILL.md +174 -0
  1170. package/src/resources/skills/security-review/SKILL.md +181 -0
  1171. package/src/resources/skills/spike-wrap-up/SKILL.md +138 -0
  1172. package/src/resources/skills/tdd/SKILL.md +112 -0
  1173. package/src/resources/skills/verify-before-complete/SKILL.md +98 -0
  1174. package/src/resources/skills/write-docs/SKILL.md +82 -0
  1175. package/src/resources/skills/write-milestone-brief/SKILL.md +135 -0
  1176. package/dist/web/standalone/.next/static/chunks/2826.e59e8578e2e28639.js +0 -9
  1177. package/dist/web/standalone/.next/static/chunks/app/page-151349214571e2b6.js +0 -1
  1178. package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
  1179. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
  1180. package/packages/native/tsconfig.tsbuildinfo +0 -1
  1181. /package/dist/web/standalone/.next/static/{ssX7BLv3Dw9Fb4CtrCGeR → gy6_foLMsEzdGBT19c3hr}/_buildManifest.js +0 -0
  1182. /package/dist/web/standalone/.next/static/{ssX7BLv3Dw9Fb4CtrCGeR → gy6_foLMsEzdGBT19c3hr}/_ssgManifest.js +0 -0
@@ -26,12 +26,12 @@ export { resolveAllSkillReferences } from "./preferences-skills.js";
26
26
  // These lived in preferences-skills.ts but imported loadEffectiveGSDPreferences
27
27
  // back from this file, creating a circular dependency. Moved here since they
28
28
  // are trivial wrappers over loadEffectiveGSDPreferences.
29
- export function resolveSkillDiscoveryMode() {
30
- const prefs = loadEffectiveGSDPreferences();
29
+ export function resolveSkillDiscoveryMode(basePath) {
30
+ const prefs = loadEffectiveGSDPreferences(basePath);
31
31
  return prefs?.preferences.skill_discovery ?? "suggest";
32
32
  }
33
- export function resolveSkillStalenessDays() {
34
- const prefs = loadEffectiveGSDPreferences();
33
+ export function resolveSkillStalenessDays(basePath) {
34
+ const prefs = loadEffectiveGSDPreferences(basePath);
35
35
  return prefs?.preferences.skill_staleness_days ?? 60;
36
36
  }
37
37
  // ─── Re-exports: models ─────────────────────────────────────────────────────
@@ -46,16 +46,16 @@ function globalPreferencesPath() {
46
46
  function legacyGlobalPreferencesPath() {
47
47
  return join(homedir(), ".pi", "agent", "gsd-preferences.md");
48
48
  }
49
- function projectPreferencesPath() {
50
- return join(gsdRoot(process.cwd()), "PREFERENCES.md");
49
+ function projectPreferencesPath(basePath = process.cwd()) {
50
+ return join(gsdRoot(basePath), "PREFERENCES.md");
51
51
  }
52
52
  // Legacy lowercase files can still exist in older projects. Keep them as a
53
53
  // compatibility-only fallback, but route new reads/writes through PREFERENCES.md.
54
54
  function legacyGlobalPreferencesPathLowercase() {
55
55
  return join(gsdHome(), "preferences.md");
56
56
  }
57
- function legacyProjectPreferencesPathLowercase() {
58
- return join(gsdRoot(process.cwd()), "preferences.md");
57
+ function legacyProjectPreferencesPathLowercase(basePath = process.cwd()) {
58
+ return join(gsdRoot(basePath), "preferences.md");
59
59
  }
60
60
  export function getGlobalGSDPreferencesPath() {
61
61
  return globalPreferencesPath();
@@ -63,8 +63,8 @@ export function getGlobalGSDPreferencesPath() {
63
63
  export function getLegacyGlobalGSDPreferencesPath() {
64
64
  return legacyGlobalPreferencesPath();
65
65
  }
66
- export function getProjectGSDPreferencesPath() {
67
- return projectPreferencesPath();
66
+ export function getProjectGSDPreferencesPath(basePath) {
67
+ return projectPreferencesPath(basePath);
68
68
  }
69
69
  // ─── Loading ────────────────────────────────────────────────────────────────
70
70
  export function loadGlobalGSDPreferences() {
@@ -72,13 +72,13 @@ export function loadGlobalGSDPreferences() {
72
72
  ?? loadPreferencesFile(legacyGlobalPreferencesPathLowercase(), "global")
73
73
  ?? loadPreferencesFile(legacyGlobalPreferencesPath(), "global");
74
74
  }
75
- export function loadProjectGSDPreferences() {
76
- return loadPreferencesFile(projectPreferencesPath(), "project")
77
- ?? loadPreferencesFile(legacyProjectPreferencesPathLowercase(), "project");
75
+ export function loadProjectGSDPreferences(basePath) {
76
+ return loadPreferencesFile(projectPreferencesPath(basePath), "project")
77
+ ?? loadPreferencesFile(legacyProjectPreferencesPathLowercase(basePath), "project");
78
78
  }
79
- export function loadEffectiveGSDPreferences() {
79
+ export function loadEffectiveGSDPreferences(basePath) {
80
80
  const globalPreferences = loadGlobalGSDPreferences();
81
- const projectPreferences = loadProjectGSDPreferences();
81
+ const projectPreferences = loadProjectGSDPreferences(basePath);
82
82
  if (!globalPreferences && !projectPreferences)
83
83
  return null;
84
84
  let result;
@@ -489,8 +489,8 @@ export function resolvePreDispatchHooks() {
489
489
  * Worktree isolation requires explicit opt-in because it depends on git
490
490
  * branch infrastructure that must be set up before use.
491
491
  */
492
- export function getIsolationMode() {
493
- const prefs = loadEffectiveGSDPreferences()?.preferences?.git;
492
+ export function getIsolationMode(basePath) {
493
+ const prefs = loadEffectiveGSDPreferences(basePath)?.preferences?.git;
494
494
  if (prefs?.isolation === "worktree")
495
495
  return "worktree";
496
496
  if (prefs?.isolation === "branch")
@@ -22,6 +22,27 @@ import { join, dirname } from "node:path";
22
22
  import { fileURLToPath } from "node:url";
23
23
  import { homedir } from "node:os";
24
24
  import { logWarning } from "./workflow-logger.js";
25
+ function hasRequiredExtensionAssets(rootDir, exists = existsSync) {
26
+ return (exists(join(rootDir, "prompts")) &&
27
+ exists(join(rootDir, "templates", "task-summary.md")));
28
+ }
29
+ export function resolveExtensionDirFromCandidates(moduleDir, agentGsdDir, exists = existsSync) {
30
+ const moduleUsable = hasRequiredExtensionAssets(moduleDir, exists);
31
+ const agentUsable = hasRequiredExtensionAssets(agentGsdDir, exists);
32
+ // Prefer the user-local extension tree when both are valid. This avoids
33
+ // leaking npm/global-install paths into prompts on Windows.
34
+ if (agentUsable)
35
+ return agentGsdDir;
36
+ if (moduleUsable)
37
+ return moduleDir;
38
+ // Degraded fallback: if required template is missing in both locations,
39
+ // keep previous behavior and prefer whichever still has prompts/.
40
+ if (exists(join(moduleDir, "prompts")))
41
+ return moduleDir;
42
+ if (exists(join(agentGsdDir, "prompts")))
43
+ return agentGsdDir;
44
+ return moduleDir;
45
+ }
25
46
  /**
26
47
  * Resolve the GSD extension directory.
27
48
  *
@@ -34,15 +55,9 @@ import { logWarning } from "./workflow-logger.js";
34
55
  */
35
56
  function resolveExtensionDir() {
36
57
  const moduleDir = dirname(fileURLToPath(import.meta.url));
37
- if (existsSync(join(moduleDir, "prompts")))
38
- return moduleDir;
39
- // Fallback: user-local agent directory
40
58
  const gsdHome = process.env.GSD_HOME || join(homedir(), ".gsd");
41
59
  const agentGsdDir = join(gsdHome, "agent", "extensions", "gsd");
42
- if (existsSync(join(agentGsdDir, "prompts")))
43
- return agentGsdDir;
44
- // Last resort: return the module dir (warmCache will silently handle the miss)
45
- return moduleDir;
60
+ return resolveExtensionDirFromCandidates(moduleDir, agentGsdDir);
46
61
  }
47
62
  const __extensionDir = resolveExtensionDir();
48
63
  const promptsDir = join(__extensionDir, "prompts");
@@ -59,7 +59,7 @@ Then:
59
59
  - `followUps` (string) — Follow-up items for future milestones
60
60
  - `deviations` (string) — Deviations from the original plan
61
61
  11. Update `.gsd/PROJECT.md`: use the `write` tool with `path: ".gsd/PROJECT.md"` and `content` containing the full updated document reflecting milestone completion and current project state. Do NOT use the `edit` tool for this — PROJECT.md is a full-document refresh.
62
- 12. Extract structured learnings from this milestone and persist them to the cross-session knowledge surfaces. Follow the procedure block immediately below — it writes `{{milestoneId}}-LEARNINGS.md`, appends Patterns and Lessons to `.gsd/KNOWLEDGE.md`, and persists Decisions via the `gsd_save_decision` MCP tool.
62
+ 12. Extract structured learnings from this milestone and persist them to the GSD memory store. Follow the procedure block immediately below — it writes `{{milestoneId}}-LEARNINGS.md` as the audit trail and persists Patterns, Lessons, and Decisions via `capture_thought` (categories: pattern, gotcha/convention, architecture). The memory store is the single source of truth for cross-session durable knowledge (ADR-013).
63
63
 
64
64
  {{extractLearningsSteps}}
65
65
 
@@ -29,8 +29,8 @@ Then:
29
29
  6. If this slice produced evidence that a requirement changed status (Active → Validated, Active → Deferred, etc.), call `gsd_requirement_update` with the requirement ID, updated `status`, and `validation` evidence. Do NOT write `.gsd/REQUIREMENTS.md` directly — the engine renders it from the database.
30
30
  7. Prepare the slice completion content you will pass to `gsd_complete_slice` using the camelCase fields `milestoneId`, `sliceId`, `sliceTitle`, `oneLiner`, `narrative`, `verification`, and `uatContent`. Do **not** manually write `{{sliceSummaryPath}}`. Do **not** manually write `{{sliceUatPath}}` — the DB-backed tool is the canonical write path for both artifacts.
31
31
  8. Draft the UAT content you will pass as `uatContent` — a concrete UAT script with real test cases derived from the slice plan and task summaries. Include preconditions, numbered steps with expected outcomes, and edge cases. This must NOT be a placeholder or generic template — tailor every test case to what this slice actually built.
32
- 9. Review task summaries for `key_decisions`. Append any significant decisions to `.gsd/DECISIONS.md` if missing.
33
- 10. Review task summaries for patterns, gotchas, or non-obvious lessons learned. If any would save future agents from repeating investigation or hitting the same issues, append them to `.gsd/KNOWLEDGE.md`. Only add entries that are genuinely useful don't pad with obvious observations.
32
+ 9. Review task summaries for `key_decisions`. For each significant decision, call `capture_thought` with `category: "architecture"` (or `"pattern"`) and a `structuredFields` payload of `{ scope, decision, choice, rationale, made_by: "agent", revisable }`.
33
+ 10. Review task summaries for patterns, gotchas, or non-obvious lessons learned. For each one that would save future agents from repeating investigation, call `capture_thought` with the matching category (`gotcha`, `convention`, `pattern`, `environment`). The memory store is the single source of truth (ADR-013); do not append to `.gsd/DECISIONS.md` or `.gsd/KNOWLEDGE.md` directly.
34
34
  11. Call `gsd_complete_slice` with the camelCase fields `milestoneId`, `sliceId`, `sliceTitle`, `oneLiner`, `narrative`, `verification`, and `uatContent`, plus any optional enrichment fields you have. Do NOT manually mark the roadmap checkbox — the tool writes to the DB, renders `{{sliceSummaryPath}}` and `{{sliceUatPath}}`, and updates the ROADMAP.md projection automatically.
35
35
  12. Do not run git commands — the system commits your changes and handles any merge after this unit succeeds.
36
36
  13. Update `.gsd/PROJECT.md` if it exists — refresh current state if needed: use the `write` tool with `path: ".gsd/PROJECT.md"` and `content` containing the full updated document reflecting current project state. Do NOT use the `edit` tool for this — PROJECT.md is a full-document refresh.
@@ -18,8 +18,10 @@ Goal semantics:
18
18
  ## Instructions
19
19
 
20
20
  1. Read `.gsd/debug/sessions/{{slug}}.json` for any prior session context.
21
+ 1a. Call `memory_query` with keywords from the issue (error text, subsystem, file paths). A prior session may have captured this exact gotcha — finding it now saves the investigation.
21
22
  2. Investigate the reported issue in `{{workingDirectory}}`.
22
23
  3. Follow the goal constraint above strictly.
23
24
  4. When complete, surface a clear summary: what failed, why, and what was done (or what a fix would require for root-cause-only mode).
25
+ 5. Once root cause is identified, call `capture_thought` with `category: "gotcha"` so future debug sessions can find it via `memory_query`. Keep the content to 1–3 sentences — the symptom, the root cause, and the fix or guard.
24
26
 
25
27
  {{skillActivation}}
@@ -162,6 +162,10 @@ Preserve the specification's exact terminology, emphasis, and specific framing.
162
162
  6. For each architectural or pattern decision, call `gsd_decision_save` — the tool auto-assigns IDs and regenerates `.gsd/DECISIONS.md` automatically.
163
163
  7. {{commitInstruction}}
164
164
 
165
+ ### Ready-phrase pre-condition (NON-BYPASSABLE)
166
+
167
+ Before emitting the ready phrase, verify in the CURRENT turn that you have written `.gsd/PROJECT.md`, `.gsd/REQUIREMENTS.md`, `{{contextPath}}`, and called `gsd_plan_milestone`. If any is missing, **STOP** — emit the missing tool calls in this same turn. The system rejects premature ready signals and retries are capped.
168
+
165
169
  After writing the files, say exactly: "Milestone {{milestoneId}} ready." — nothing else. Auto-mode will start automatically.
166
170
 
167
171
  ### Multi-Milestone
@@ -234,6 +238,10 @@ For single-milestone projects, do NOT write this file.
234
238
 
235
239
  7. {{multiMilestoneCommitInstruction}}
236
240
 
241
+ ### Ready-phrase pre-condition (NON-BYPASSABLE)
242
+
243
+ Before emitting the ready phrase, verify in the CURRENT turn that you have written `.gsd/PROJECT.md`, `.gsd/REQUIREMENTS.md`, the primary `CONTEXT.md`, called `gsd_plan_milestone` for the primary milestone, and written `.gsd/DISCUSSION-MANIFEST.json` with `gates_completed === total`. If any is missing, **STOP** — emit the missing tool calls in this same turn. The system rejects premature ready signals and retries are capped.
244
+
237
245
  After writing the files, say exactly: "Milestone {{milestoneId}} ready." — nothing else. Auto-mode will start automatically.
238
246
 
239
247
  ## Critical Rules
@@ -339,7 +339,20 @@ These sections are in addition to whatever other context the discussion surfaced
339
339
  6. For each architectural or pattern decision made during discussion, call `gsd_decision_save` — the tool auto-assigns IDs and regenerates `.gsd/DECISIONS.md` automatically.
340
340
  7. {{commitInstruction}}
341
341
 
342
- After writing the files, say exactly: "Milestone {{milestoneId}} ready." — nothing else. Auto-mode will start automatically.
342
+ ### Ready-phrase pre-condition (NON-BYPASSABLE)
343
+
344
+ Before emitting the ready phrase, verify in the CURRENT turn that you have:
345
+
346
+ - [ ] Written `.gsd/PROJECT.md` (step 2)
347
+ - [ ] Written `.gsd/REQUIREMENTS.md` (step 3)
348
+ - [ ] Written `{{contextPath}}` (step 4)
349
+ - [ ] Called `gsd_plan_milestone` (step 5)
350
+
351
+ If ANY box is unchecked, **STOP**. Do NOT emit the ready phrase. Emit the missing tool calls in this same turn. The system detects missing artifacts and will reject premature ready signals — you will be asked again and retries are capped.
352
+
353
+ Do not announce the ready phrase as something you are "about to" do. Do not narrate "now writing the files" as a substitute for actually writing them. The ready phrase is a post-write signal, not an intent signal.
354
+
355
+ After completing steps 1–7 above, say exactly: "Milestone {{milestoneId}} ready." — nothing else. Auto-mode will start automatically.
343
356
 
344
357
  ### Multi-Milestone
345
358
 
@@ -418,6 +431,20 @@ For single-milestone projects, do NOT write this file — it is only for multi-m
418
431
 
419
432
  7. {{multiMilestoneCommitInstruction}}
420
433
 
421
- After writing the files, say exactly: "Milestone M001 ready." — nothing else. Auto-mode will start automatically.
434
+ ### Ready-phrase pre-condition (NON-BYPASSABLE)
435
+
436
+ Before emitting the ready phrase, verify in the CURRENT turn that you have:
437
+
438
+ - [ ] Written `.gsd/PROJECT.md` (Phase 1)
439
+ - [ ] Written `.gsd/REQUIREMENTS.md` (Phase 1)
440
+ - [ ] Written primary-milestone `CONTEXT.md` (Phase 2)
441
+ - [ ] Called `gsd_plan_milestone` for the primary milestone (Phase 2)
442
+ - [ ] Written `.gsd/DISCUSSION-MANIFEST.json` with `gates_completed === total` (Phase 3)
443
+
444
+ If ANY box is unchecked, **STOP**. Do NOT emit the ready phrase. Emit the missing tool calls in this same turn. The system detects missing artifacts and will reject premature ready signals — you will be asked again and retries are capped.
445
+
446
+ Do not announce the ready phrase as something you are "about to" do. Do not narrate "now writing the files" as a substitute for actually writing them. The ready phrase is a post-write signal, not an intent signal.
447
+
448
+ After completing all phases above, say exactly: "Milestone M001 ready." — nothing else. Auto-mode will start automatically.
422
449
 
423
450
  {{inlinedTemplates}}
@@ -32,6 +32,7 @@ A researcher explored the codebase and a planner decomposed the work — you are
32
32
 
33
33
  Then:
34
34
  0. Narrate step transitions, key implementation decisions, and verification outcomes as you work. Keep it terse — one line between tool-call clusters, not between every call — but write complete sentences in user-facing prose, not shorthand notes or scratchpad fragments.
35
+ 0a. Call `memory_query` with 2-4 keywords drawn from the task title and the files it touches. Surface any prior gotchas, conventions, or architectural decisions before you start changing code. Skip only if the task is trivially mechanical.
35
36
  1. {{skillActivation}} Follow any activated skills before writing code. If no skills match this task, skip this step.
36
37
  2. Execute the steps in the inlined task plan, adapting minor local mismatches when the surrounding code differs from the planner's snapshot
37
38
  3. Before any `Write` that creates an artifact or output file, check whether that path already exists. If it does, read it first and decide whether the work is already done, should be extended, or truly needs replacement. "Create" in the plan does **not** mean the file is missing — a prior session may already have started it.
@@ -81,8 +82,8 @@ Then:
81
82
  **Scope:** Escalation is instrumented only in `execute-task`. Refine-slice escalation is deferred. Reactive-execute batches run to completion before escalations are surfaced — the dispatch pause happens on the next loop iteration, not mid-batch.
82
83
 
83
84
  The `escalation` payload is ignored unless `phases.mid_execution_escalation` is enabled; populate it anyway for audit logs.
84
- 17. If you made an architectural, pattern, library, or observability decision during this task that downstream work should know about, append it to `.gsd/DECISIONS.md` (read the template at `~/.gsd/agent/extensions/gsd/templates/decisions.md` if the file doesn't exist yet). Not every task produces decisions — only append when a meaningful choice was made.
85
- 18. If you discover a non-obvious rule, recurring gotcha, or useful pattern during execution, append it to `.gsd/KNOWLEDGE.md`. Only add entries that would save future agents from repeating your investigation. Don't add obvious things.
85
+ 17. If you made an architectural, pattern, library, or observability decision during this task that downstream work should know about, call `capture_thought` with `category: "architecture"` (or `"pattern"`). For decisions, populate `structuredFields` with `{ scope, decision, choice, rationale, made_by: "agent", revisable }` so future projection back to a human-visible decisions register stays lossless. Not every task produces decisions — only capture when a meaningful choice was made.
86
+ 18. If you discover a non-obvious rule, recurring gotcha, or useful pattern during execution, call `capture_thought` with `category: "gotcha"`, `"convention"`, `"pattern"`, or `"environment"` as appropriate. Only capture entries that would save future agents from repeating your investigation — don't capture obvious things. The memory store is the single source of truth for cross-session knowledge (ADR-013); do not append to `.gsd/DECISIONS.md` or `.gsd/KNOWLEDGE.md` directly.
86
87
  19. Read the template at `~/.gsd/agent/extensions/gsd/templates/task-summary.md`
87
88
  20. Use that template to prepare the completion content you will pass to `gsd_complete_task` using the camelCase fields `milestoneId`, `sliceId`, `taskId`, `oneLiner`, `narrative`, `verification`, and `verificationEvidence`. Do **not** manually write `{{taskSummaryPath}}` — the DB-backed tool is the canonical write path and renders the summary file for you.
88
89
  21. Call `gsd_complete_task` with milestoneId, sliceId, taskId, and the completion fields derived from the template. This is your final required step — do NOT manually edit PLAN.md checkboxes. The tool marks the task complete, updates the DB, renders `{{taskSummaryPath}}`, and updates PLAN.md automatically.
@@ -15,8 +15,11 @@ Dispatch ALL slices simultaneously using the `subagent` tool in **parallel mode*
15
15
  1. Call `subagent` with `tasks: [...]` containing one entry per slice below
16
16
  2. Wait for ALL subagents to complete
17
17
  3. Verify each slice's RESEARCH file was written (check the `.gsd/{{mid}}/` directory)
18
- 4. If any subagent failed to write its RESEARCH file, re-run it individually
19
- 5. Report which slices completed research and which (if any) failed
18
+ 4. If a subagent failed to write its RESEARCH file, retry it **once** individually
19
+ 5. If it fails a second time, write a partial RESEARCH file for that slice with a `## BLOCKER` section explaining the failure — do NOT retry again
20
+ 6. Report which slices completed research and which (if any) needed a blocker note
21
+
22
+ **Important**: Each failed slice gets exactly one retry. After that, write the blocker and move on. Never retry the same slice more than once.
20
23
 
21
24
  ## Subagent Prompts
22
25
 
@@ -44,6 +44,7 @@ Narrate your decomposition reasoning — why you're grouping work this way, what
44
44
 
45
45
  Then:
46
46
  0. If `REQUIREMENTS.md` was preloaded above, identify which Active requirements the roadmap says this slice owns or supports. These are the requirements this plan must deliver — every owned requirement needs at least one task that directly advances it, and verification must prove the requirement is met.
47
+ 0a. Call `memory_query` with keywords from the slice title and the source files listed below. Prior architectural decisions, conventions, and gotchas in this area should inform task decomposition — not be re-derived during execution.
47
48
  1. Read the templates:
48
49
  - `~/.gsd/agent/extensions/gsd/templates/plan.md`
49
50
  - `~/.gsd/agent/extensions/gsd/templates/task-plan.md`
@@ -42,6 +42,7 @@ An honest "this is straightforward, here's the pattern to follow" is more valuab
42
42
 
43
43
  Research what this slice needs. Narrate key findings and surprises as you go — what exists, what's missing, what constrains the approach.
44
44
  0. If `REQUIREMENTS.md` was preloaded above, identify which Active requirements this slice owns or supports. Research should target these requirements — surfacing risks, unknowns, and implementation constraints that could affect whether the slice actually delivers them.
45
+ 0a. Call `memory_query` with keywords from the slice title and scope. Prior slices may have captured architecture notes, conventions, or gotchas in subsystems you're about to explore — pulling them now prevents re-discovering known constraints.
45
46
  1. {{skillActivation}} Reference specific rules from loaded skills in your findings where they inform the implementation approach.
46
47
  2. **Skill Discovery ({{skillDiscoveryMode}}):**{{skillDiscoveryInstructions}}
47
48
  3. Explore relevant code for this slice's scope. For targeted exploration, use `rg`, `find`, and reads. For broad or unfamiliar subsystems, use `scout` to map the relevant area first.
@@ -213,6 +213,7 @@ Fix the root cause, not symptoms. When applying a temporary mitigation, label it
213
213
  - State uncertainty plainly: "Not sure this handles X - testing it." No performed confidence, no hedging paragraphs.
214
214
  - All user-visible narration must be grammatical English. Do not emit compressed planner notes like "Need inspect X" or "Maybe read Y first". If it would look acceptable in a commit comment or standup note, it's acceptable here.
215
215
  - When debugging, stay curious. Problems are puzzles. Say what's interesting about the failure before reaching for fixes.
216
+ - After completing a task, give a brief completion summary and present 2-4 contextual next-step options as a numbered list (the last option is always "Other"). This reduces cognitive load by letting the user pick rather than formulate what's next. Omit the numbered list when the response must follow a strict output format (JSON, patches, commit messages, structured data).
216
217
 
217
218
  Good narration: "Three existing handlers follow a middleware pattern - using that instead of a custom wrapper."
218
219
  Good narration: "Tests pass. Running slice-level verification."
@@ -3,9 +3,17 @@
3
3
  * Tracks every bash command, file write, and file edit during a unit execution.
4
4
  * Evidence is compared against LLM completion claims in evidence-cross-ref.ts.
5
5
  *
6
+ * Evidence is persisted to .gsd/safety/evidence-<mid>-<sid>-<tid>.json so it
7
+ * survives session restarts (pause/resume, crash recovery). On unit start,
8
+ * call resetEvidence() then loadEvidenceFromDisk(). On every new tool call,
9
+ * saveEvidenceToDisk() is called automatically by recordToolCall/recordToolResult.
10
+ *
6
11
  * Follows the same module-level Map pattern as auto-tool-tracking.ts.
7
12
  * Copyright (c) 2026 Jeremy McSpadden <jeremy@fluxlabs.net>
8
13
  */
14
+ import { existsSync, mkdirSync, readFileSync, writeFileSync, renameSync, unlinkSync, } from "node:fs";
15
+ import { join, dirname } from "node:path";
16
+ import { randomBytes } from "node:crypto";
9
17
  // ─── Module State ───────────────────────────────────────────────────────────
10
18
  let unitEvidence = [];
11
19
  // ─── Public API ─────────────────────────────────────────────────────────────
@@ -27,6 +35,94 @@ export function getFilePaths() {
27
35
  .filter((e) => e.kind === "write" || e.kind === "edit")
28
36
  .map(e => e.path);
29
37
  }
38
+ // ─── Persistence (Bug #4385 — evidence must survive session restarts) ────────
39
+ /**
40
+ * Build the path for the evidence JSON file for a given unit.
41
+ * Lives under .gsd/safety/ which is gitignored and session-scoped.
42
+ */
43
+ function evidencePath(basePath, milestoneId, sliceId, taskId) {
44
+ return join(basePath, ".gsd", "safety", `evidence-${milestoneId}-${sliceId}-${taskId}.json`);
45
+ }
46
+ /**
47
+ * Validate that a parsed value is an array of EvidenceEntry objects.
48
+ * Rejects corrupt / schema-mismatch data rather than letting it poison state.
49
+ */
50
+ function isEvidenceArray(data) {
51
+ if (!Array.isArray(data))
52
+ return false;
53
+ return data.every((e) => {
54
+ if (e === null || typeof e !== "object")
55
+ return false;
56
+ const rec = e;
57
+ if (typeof rec.toolCallId !== "string")
58
+ return false;
59
+ if (typeof rec.timestamp !== "number")
60
+ return false;
61
+ if (rec.kind === "bash") {
62
+ return (typeof rec.command === "string" &&
63
+ typeof rec.exitCode === "number" &&
64
+ typeof rec.outputSnippet === "string");
65
+ }
66
+ if (rec.kind === "write" || rec.kind === "edit") {
67
+ return typeof rec.path === "string";
68
+ }
69
+ return false;
70
+ });
71
+ }
72
+ /**
73
+ * Persist the current in-memory evidence to disk so it survives a session
74
+ * restart. Called from saveEvidenceToDisk after recordToolCall/recordToolResult.
75
+ * Non-fatal — persistence failures must never break unit execution.
76
+ */
77
+ export function saveEvidenceToDisk(basePath, milestoneId, sliceId, taskId) {
78
+ try {
79
+ const path = evidencePath(basePath, milestoneId, sliceId, taskId);
80
+ mkdirSync(dirname(path), { recursive: true });
81
+ const tmp = `${path}.tmp.${randomBytes(4).toString("hex")}`;
82
+ writeFileSync(tmp, JSON.stringify(unitEvidence, null, 2) + "\n", "utf-8");
83
+ renameSync(tmp, path);
84
+ }
85
+ catch {
86
+ // Non-fatal — don't let persistence failures break unit execution
87
+ }
88
+ }
89
+ /**
90
+ * Load persisted evidence from disk into the in-memory array.
91
+ * Call after resetEvidence() on session resume to restore context for a
92
+ * partially-executed unit. If the file does not exist (fresh unit), this
93
+ * is a no-op — getEvidence() will return [] which is correct.
94
+ */
95
+ export function loadEvidenceFromDisk(basePath, milestoneId, sliceId, taskId) {
96
+ try {
97
+ const path = evidencePath(basePath, milestoneId, sliceId, taskId);
98
+ if (!existsSync(path))
99
+ return;
100
+ const raw = readFileSync(path, "utf-8");
101
+ const parsed = JSON.parse(raw);
102
+ if (isEvidenceArray(parsed)) {
103
+ unitEvidence = parsed;
104
+ }
105
+ }
106
+ catch {
107
+ // Non-fatal — corrupt / missing file is treated as empty evidence
108
+ }
109
+ }
110
+ /**
111
+ * Delete the persisted evidence file for a unit after it has been fully
112
+ * processed. Prevents stale evidence from affecting future retries of
113
+ * the same unit ID.
114
+ */
115
+ export function clearEvidenceFromDisk(basePath, milestoneId, sliceId, taskId) {
116
+ try {
117
+ const path = evidencePath(basePath, milestoneId, sliceId, taskId);
118
+ if (existsSync(path)) {
119
+ unlinkSync(path);
120
+ }
121
+ }
122
+ catch {
123
+ // Non-fatal
124
+ }
125
+ }
30
126
  // ─── Recording (called from register-hooks.ts) ─────────────────────────────
31
127
  /**
32
128
  * Record a tool call at dispatch time (before execution).
@@ -4,13 +4,18 @@
4
4
  *
5
5
  * Uses tasks.expected_output (DB column, populated from per-task ## Expected Output)
6
6
  * and tasks.files (from slice PLAN.md - Files: subline) as the expected set.
7
- * Compares against git diff HEAD~1 --name-only after auto-commit.
7
+ * Compares against `git diff-tree --root --no-commit-id -r --name-only HEAD` after auto-commit.
8
+ * Using diff-tree --root handles initial commits, shallow clones, and merge commits correctly
9
+ * (Bug #4385 — git diff HEAD~1 failed on initial commits).
8
10
  *
9
11
  * Copyright (c) 2026 Jeremy McSpadden <jeremy@fluxlabs.net>
10
12
  */
13
+ import { createRequire } from "node:module";
11
14
  import { execFileSync } from "node:child_process";
12
15
  import { normalizePlannedFileReference } from "../files.js";
13
16
  import { logWarning } from "../workflow-logger.js";
17
+ const _require = createRequire(import.meta.url);
18
+ const picomatch = _require("picomatch");
14
19
  // ─── Public API ─────────────────────────────────────────────────────────────
15
20
  /**
16
21
  * Validate file changes after auto-commit for an execute-task unit.
@@ -20,7 +25,7 @@ import { logWarning } from "../workflow-logger.js";
20
25
  * @param expectedOutput - JSON array from tasks.expected_output DB column
21
26
  * @param plannedFiles - JSON array from tasks.files DB column
22
27
  */
23
- export function validateFileChanges(basePath, expectedOutput, plannedFiles) {
28
+ export function validateFileChanges(basePath, expectedOutput, plannedFiles, fileChangeAllowlist = []) {
24
29
  const allExpected = new Set([...expectedOutput, ...plannedFiles]);
25
30
  // If no expected files were planned, skip validation
26
31
  if (allExpected.size === 0)
@@ -33,8 +38,11 @@ export function validateFileChanges(basePath, expectedOutput, plannedFiles) {
33
38
  const projectFiles = actualFiles.filter(f => !f.startsWith(".gsd/") && !f.startsWith(".gsd\\"));
34
39
  // Normalize expected paths (strip leading ./ or /)
35
40
  const normalizedExpected = new Set([...allExpected].map((f) => normalizePlannedFileReference(f).replace(/^\.\//, "").replace(/^\//, "")));
36
- // Compute symmetric difference
37
- const unexpectedFiles = projectFiles.filter(f => !normalizedExpected.has(f));
41
+ // Build allowlist matchers once (dot: true so patterns like `**/.hidden` work).
42
+ const allowlistMatchers = fileChangeAllowlist.map(p => picomatch(p, { dot: true }));
43
+ const isAllowlisted = (f) => allowlistMatchers.some(m => m(f));
44
+ // Compute symmetric difference, excluding allowlisted files
45
+ const unexpectedFiles = projectFiles.filter(f => !normalizedExpected.has(f) && !isAllowlisted(f));
38
46
  const missingFiles = [...normalizedExpected].filter(f => !projectFiles.includes(f));
39
47
  const violations = [];
40
48
  for (const f of unexpectedFiles) {
@@ -62,7 +70,7 @@ export function validateFileChanges(basePath, expectedOutput, plannedFiles) {
62
70
  // ─── Internals ──────────────────────────────────────────────────────────────
63
71
  function getChangedFilesFromLastCommit(basePath) {
64
72
  try {
65
- const result = execFileSync("git", ["diff", "--name-only", "HEAD~1", "HEAD"], { cwd: basePath, stdio: ["ignore", "pipe", "pipe"], encoding: "utf-8" }).trim();
73
+ const result = execFileSync("git", ["diff-tree", "--root", "--no-commit-id", "-r", "--name-only", "HEAD"], { cwd: basePath, stdio: ["ignore", "pipe", "pipe"], encoding: "utf-8" }).trim();
66
74
  return result ? result.split("\n").filter(Boolean) : [];
67
75
  }
68
76
  catch (e) {
@@ -23,6 +23,7 @@ const DEFAULTS = {
23
23
  checkpoints: true,
24
24
  auto_rollback: false,
25
25
  timeout_scale_cap: 6,
26
+ file_change_allowlist: [],
26
27
  };
27
28
  // ─── Public API ─────────────────────────────────────────────────────────────
28
29
  /**
@@ -42,6 +43,9 @@ export function resolveSafetyHarnessConfig(raw) {
42
43
  checkpoints: typeof raw.checkpoints === "boolean" ? raw.checkpoints : DEFAULTS.checkpoints,
43
44
  auto_rollback: typeof raw.auto_rollback === "boolean" ? raw.auto_rollback : DEFAULTS.auto_rollback,
44
45
  timeout_scale_cap: typeof raw.timeout_scale_cap === "number" ? raw.timeout_scale_cap : DEFAULTS.timeout_scale_cap,
46
+ file_change_allowlist: Array.isArray(raw.file_change_allowlist)
47
+ ? raw.file_change_allowlist.filter((p) => typeof p === "string")
48
+ : DEFAULTS.file_change_allowlist,
45
49
  };
46
50
  }
47
51
  /**
@@ -56,7 +60,7 @@ export function isHarnessEnabled(raw) {
56
60
  return DEFAULTS.enabled;
57
61
  }
58
62
  // ─── Re-exports ─────────────────────────────────────────────────────────────
59
- export { resetEvidence, getEvidence, getBashEvidence, getFilePaths, recordToolCall, recordToolResult, } from "./evidence-collector.js";
63
+ export { resetEvidence, getEvidence, getBashEvidence, getFilePaths, recordToolCall, recordToolResult, saveEvidenceToDisk, loadEvidenceFromDisk, clearEvidenceFromDisk, } from "./evidence-collector.js";
60
64
  export { classifyCommand } from "./destructive-guard.js";
61
65
  export { validateFileChanges } from "./file-change-validator.js";
62
66
  export { crossReferenceEvidence } from "./evidence-cross-ref.js";
@@ -501,7 +501,7 @@ async function handleAllSlicesDone(basePath, activeMilestone, registry, requirem
501
501
  const validationContent = validationFile ? await loadFile(validationFile) : null;
502
502
  const validationTerminal = validationContent ? isValidationTerminal(validationContent) : false;
503
503
  const verdict = validationContent ? extractVerdict(validationContent) : undefined;
504
- if (!validationTerminal || verdict === 'needs-remediation') {
504
+ if (!validationTerminal) {
505
505
  return {
506
506
  activeMilestone, activeSlice: null, activeTask: null,
507
507
  phase: 'validating-milestone',
@@ -511,6 +511,23 @@ async function handleAllSlicesDone(basePath, activeMilestone, registry, requirem
511
511
  progress: { milestones: milestoneProgress, slices: sliceProgress },
512
512
  };
513
513
  }
514
+ // All roadmap slices are done (enforced by caller) and verdict is
515
+ // needs-remediation — remediation cannot progress without new slices.
516
+ // Return blocked instead of re-dispatching validate-milestone (#4506).
517
+ if (verdict === 'needs-remediation') {
518
+ return {
519
+ activeMilestone, activeSlice: null, activeTask: null,
520
+ phase: 'blocked',
521
+ recentDecisions: [],
522
+ blockers: [
523
+ `Milestone ${activeMilestone.id} validation verdict is needs-remediation but all slices are complete. ` +
524
+ `Add remediation slices via gsd_reassess_roadmap or override the verdict manually.`,
525
+ ],
526
+ nextAction: `Resolve ${activeMilestone.id} remediation before proceeding.`,
527
+ registry, requirements,
528
+ progress: { milestones: milestoneProgress, slices: sliceProgress },
529
+ };
530
+ }
514
531
  return {
515
532
  activeMilestone, activeSlice: null, activeTask: null,
516
533
  phase: 'completing-milestone',
@@ -1278,9 +1295,11 @@ export async function _deriveStateImpl(basePath) {
1278
1295
  done: activeRoadmap.slices.length,
1279
1296
  total: activeRoadmap.slices.length,
1280
1297
  };
1281
- // Force re-validation when verdict is needs-remediation remediation slices
1282
- // may have completed since the stale validation was written (#3596).
1283
- if (!validationTerminal || verdict === 'needs-remediation') {
1298
+ // Force re-validation when VALIDATION.md is absent or non-terminal
1299
+ // remediation slices may have completed since the stale validation was
1300
+ // written (#3596). But needs-remediation with all slices done is a dead
1301
+ // end — return blocked to avoid an infinite dispatch loop (#4506).
1302
+ if (!validationTerminal) {
1284
1303
  return {
1285
1304
  activeMilestone,
1286
1305
  activeSlice: null,
@@ -1297,6 +1316,26 @@ export async function _deriveStateImpl(basePath) {
1297
1316
  },
1298
1317
  };
1299
1318
  }
1319
+ if (verdict === 'needs-remediation') {
1320
+ return {
1321
+ activeMilestone,
1322
+ activeSlice: null,
1323
+ activeTask: null,
1324
+ phase: 'blocked',
1325
+ recentDecisions: [],
1326
+ blockers: [
1327
+ `Milestone ${activeMilestone.id} validation verdict is needs-remediation but all slices are complete. ` +
1328
+ `Add remediation slices via gsd_reassess_roadmap or override the verdict manually.`,
1329
+ ],
1330
+ nextAction: `Resolve ${activeMilestone.id} remediation before proceeding.`,
1331
+ registry,
1332
+ requirements,
1333
+ progress: {
1334
+ milestones: milestoneProgress,
1335
+ slices: sliceProgress,
1336
+ },
1337
+ };
1338
+ }
1300
1339
  return {
1301
1340
  activeMilestone,
1302
1341
  activeSlice: null,
@@ -16,7 +16,11 @@ async function getEncoder() {
16
16
  try {
17
17
  // @ts-ignore — tiktoken may not have type declarations in extensions tsconfig
18
18
  const tiktoken = await import("tiktoken");
19
- encoder = tiktoken.encoding_for_model("gpt-4o");
19
+ // Use cl100k_base — the most conservative and broadly compatible BPE encoding.
20
+ // It is shared by GPT-3.5/GPT-4 and gives a safer (larger) estimate than
21
+ // gpt-4o's o200k_base encoding, which produces fewer tokens for the same text
22
+ // and would cause context windows for non-OpenAI providers to be under-counted.
23
+ encoder = tiktoken.get_encoding("cl100k_base");
20
24
  return encoder;
21
25
  }
22
26
  catch {
@@ -24,19 +28,32 @@ async function getEncoder() {
24
28
  return null;
25
29
  }
26
30
  }
27
- export async function countTokens(text) {
31
+ /**
32
+ * Count tokens in `text` using tiktoken (cl100k_base) when available.
33
+ *
34
+ * When tiktoken is not loaded, falls back to a provider-aware character-ratio
35
+ * estimate via `estimateTokensForProvider`. Passing `provider` is recommended
36
+ * so the heuristic fallback is as accurate as possible.
37
+ */
38
+ export async function countTokens(text, provider) {
28
39
  const enc = await getEncoder();
29
40
  if (enc) {
30
41
  const tokens = enc.encode(text);
31
42
  return tokens.length;
32
43
  }
33
- return Math.ceil(text.length / 4);
44
+ return estimateTokensForProvider(text, provider ?? "unknown");
34
45
  }
35
- export function countTokensSync(text) {
46
+ /**
47
+ * Synchronous token count — only accurate after `initTokenCounter()` resolves.
48
+ *
49
+ * Before init, or when tiktoken is unavailable, falls back to a provider-aware
50
+ * character-ratio estimate. Passing `provider` is recommended.
51
+ */
52
+ export function countTokensSync(text, provider) {
36
53
  if (encoder) {
37
54
  return encoder.encode(text).length;
38
55
  }
39
- return Math.ceil(text.length / 4);
56
+ return estimateTokensForProvider(text, provider ?? "unknown");
40
57
  }
41
58
  export async function initTokenCounter() {
42
59
  const enc = await getEncoder();