gsd-pi 2.76.0-dev.fe143342a → 2.77.0-dev.1594b263e

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 (925) hide show
  1. package/README.md +18 -36
  2. package/dist/claude-cli-check.js +36 -3
  3. package/dist/cli-web-branch.d.ts +1 -0
  4. package/dist/cli-web-branch.js +3 -0
  5. package/dist/cli.js +38 -2
  6. package/dist/extension-discovery.d.ts +6 -0
  7. package/dist/extension-discovery.js +37 -0
  8. package/dist/extension-registry.d.ts +3 -0
  9. package/dist/extension-sort.d.ts +18 -0
  10. package/dist/extension-sort.js +114 -0
  11. package/dist/extension-validator.d.ts +47 -0
  12. package/dist/extension-validator.js +127 -0
  13. package/dist/headless.js +49 -4
  14. package/dist/loader.js +35 -7
  15. package/dist/onboarding.js +45 -0
  16. package/dist/provider-migrations.d.ts +18 -0
  17. package/dist/provider-migrations.js +14 -0
  18. package/dist/resource-loader.d.ts +40 -0
  19. package/dist/resource-loader.js +32 -13
  20. package/dist/resources/extensions/browser-tools/capture.js +9 -0
  21. package/dist/resources/extensions/browser-tools/tests/browser-tools-integration.test.mjs +8 -59
  22. package/dist/resources/extensions/browser-tools/tests/browser-tools-unit.test.cjs +36 -24
  23. package/dist/resources/extensions/browser-tools/tests/capture-sharp-optional.test.cjs +69 -71
  24. package/dist/resources/extensions/browser-tools/tools/forms.js +5 -1
  25. package/dist/resources/extensions/browser-tools/tools/intent.js +5 -1
  26. package/dist/resources/extensions/claude-code-cli/readiness.js +9 -4
  27. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +559 -76
  28. package/dist/resources/extensions/cmux/index.js +20 -0
  29. package/dist/resources/extensions/github-sync/templates.js +103 -0
  30. package/dist/resources/extensions/google-search/extension-manifest.json +5 -4
  31. package/dist/resources/extensions/google-search/index.js +3 -375
  32. package/dist/resources/extensions/gsd/abandon-detect.js +44 -0
  33. package/dist/resources/extensions/gsd/auto/loop.js +133 -2
  34. package/dist/resources/extensions/gsd/auto/phases.js +110 -42
  35. package/dist/resources/extensions/gsd/auto/resolve.js +24 -0
  36. package/dist/resources/extensions/gsd/auto/run-unit.js +48 -4
  37. package/dist/resources/extensions/gsd/auto/session.js +24 -3
  38. package/dist/resources/extensions/gsd/auto/turn-epoch.js +95 -0
  39. package/dist/resources/extensions/gsd/auto-dispatch.js +216 -40
  40. package/dist/resources/extensions/gsd/auto-loop.js +1 -1
  41. package/dist/resources/extensions/gsd/auto-model-selection.js +125 -5
  42. package/dist/resources/extensions/gsd/auto-post-unit.js +240 -66
  43. package/dist/resources/extensions/gsd/auto-prompts.js +386 -104
  44. package/dist/resources/extensions/gsd/auto-recovery.js +124 -4
  45. package/dist/resources/extensions/gsd/auto-start.js +141 -66
  46. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +11 -5
  47. package/dist/resources/extensions/gsd/auto-tool-tracking.js +47 -7
  48. package/dist/resources/extensions/gsd/auto-unit-closeout.js +11 -2
  49. package/dist/resources/extensions/gsd/auto-worktree.js +230 -86
  50. package/dist/resources/extensions/gsd/auto.js +159 -48
  51. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +36 -2
  52. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +209 -0
  53. package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +5 -6
  54. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +11 -0
  55. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +24 -9
  56. package/dist/resources/extensions/gsd/bootstrap/system-context.js +11 -6
  57. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +161 -11
  58. package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
  59. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +31 -4
  60. package/dist/resources/extensions/gsd/commands-cmux.js +9 -6
  61. package/dist/resources/extensions/gsd/commands-extensions.js +634 -43
  62. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
  63. package/dist/resources/extensions/gsd/component-loader.js +447 -0
  64. package/dist/resources/extensions/gsd/component-types.js +69 -0
  65. package/dist/resources/extensions/gsd/context-store.js +23 -7
  66. package/dist/resources/extensions/gsd/detection.js +49 -1
  67. package/dist/resources/extensions/gsd/dispatch-guard.js +29 -3
  68. package/dist/resources/extensions/gsd/docs/preferences-reference.md +1 -1
  69. package/dist/resources/extensions/gsd/file-lock.js +49 -9
  70. package/dist/resources/extensions/gsd/forensics.js +106 -0
  71. package/dist/resources/extensions/gsd/gate-registry.js +2 -2
  72. package/dist/resources/extensions/gsd/git-constants.js +28 -1
  73. package/dist/resources/extensions/gsd/git-self-heal.js +27 -0
  74. package/dist/resources/extensions/gsd/git-service.js +127 -2
  75. package/dist/resources/extensions/gsd/gitignore.js +2 -0
  76. package/dist/resources/extensions/gsd/gsd-db.js +95 -32
  77. package/dist/resources/extensions/gsd/guided-flow-queue.js +4 -1
  78. package/dist/resources/extensions/gsd/guided-flow.js +214 -13
  79. package/dist/resources/extensions/gsd/health-widget.js +4 -1
  80. package/dist/resources/extensions/gsd/journal.js +17 -2
  81. package/dist/resources/extensions/gsd/key-manager.js +22 -0
  82. package/dist/resources/extensions/gsd/memory-extractor.js +7 -1
  83. package/dist/resources/extensions/gsd/milestone-actions.js +15 -0
  84. package/dist/resources/extensions/gsd/milestone-scope-classifier.js +299 -0
  85. package/dist/resources/extensions/gsd/milestone-summary-classifier.js +37 -0
  86. package/dist/resources/extensions/gsd/model-cost-table.js +3 -0
  87. package/dist/resources/extensions/gsd/model-router.js +42 -3
  88. package/dist/resources/extensions/gsd/native-git-bridge.js +34 -4
  89. package/dist/resources/extensions/gsd/notifications.js +30 -16
  90. package/dist/resources/extensions/gsd/pre-execution-checks.js +31 -6
  91. package/dist/resources/extensions/gsd/preferences-validation.js +23 -0
  92. package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +4 -0
  93. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +5 -1
  94. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  95. package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
  96. package/dist/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  97. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  98. package/dist/resources/extensions/gsd/prompts/plan-slice.md +15 -2
  99. package/dist/resources/extensions/gsd/prompts/system.md +1 -0
  100. package/dist/resources/extensions/gsd/reports.js +5 -4
  101. package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
  102. package/dist/resources/extensions/gsd/safety/file-change-validator.js +12 -4
  103. package/dist/resources/extensions/gsd/safety/git-checkpoint.js +11 -0
  104. package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
  105. package/dist/resources/extensions/gsd/service-tier.js +5 -2
  106. package/dist/resources/extensions/gsd/session-lock.js +19 -10
  107. package/dist/resources/extensions/gsd/skill-manifest.js +168 -0
  108. package/dist/resources/extensions/gsd/slice-cadence.js +238 -0
  109. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +278 -8
  110. package/dist/resources/extensions/gsd/state-transition-matrix.js +118 -0
  111. package/dist/resources/extensions/gsd/state.js +69 -58
  112. package/dist/resources/extensions/gsd/sync-lock.js +98 -42
  113. package/dist/resources/extensions/gsd/token-counter.js +22 -5
  114. package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
  115. package/dist/resources/extensions/gsd/tools/complete-slice.js +21 -0
  116. package/dist/resources/extensions/gsd/tools/complete-task.js +31 -0
  117. package/dist/resources/extensions/gsd/tools/validate-milestone.js +7 -2
  118. package/dist/resources/extensions/gsd/unit-context-composer.js +147 -0
  119. package/dist/resources/extensions/gsd/unit-context-manifest.js +370 -0
  120. package/dist/resources/extensions/gsd/uok/audit.js +18 -2
  121. package/dist/resources/extensions/gsd/uok/dispatch-envelope.js +33 -0
  122. package/dist/resources/extensions/gsd/uok/execution-graph.js +10 -0
  123. package/dist/resources/extensions/gsd/uok/gate-runner.js +53 -5
  124. package/dist/resources/extensions/gsd/uok/gitops.js +2 -1
  125. package/dist/resources/extensions/gsd/uok/loop-adapter.js +37 -10
  126. package/dist/resources/extensions/gsd/uok/parity-report.js +58 -0
  127. package/dist/resources/extensions/gsd/uok/plan-v2.js +30 -7
  128. package/dist/resources/extensions/gsd/uok/writer.js +82 -0
  129. package/dist/resources/extensions/gsd/workflow-logger.js +10 -2
  130. package/dist/resources/extensions/gsd/workflow-mcp.js +6 -0
  131. package/dist/resources/extensions/gsd/worktree-manager.js +86 -8
  132. package/dist/resources/extensions/gsd/worktree-resolver.js +136 -17
  133. package/dist/resources/extensions/gsd/worktree-telemetry.js +198 -0
  134. package/dist/resources/extensions/mcp-client/auth.js +10 -1
  135. package/dist/resources/extensions/mcp-client/index.js +121 -10
  136. package/dist/resources/extensions/ollama/index.js +5 -1
  137. package/dist/resources/extensions/remote-questions/manager.js +11 -5
  138. package/dist/resources/extensions/shared/cmux-events.js +12 -0
  139. package/dist/resources/extensions/shared/rtk-session-stats.js +1 -2
  140. package/dist/resources/skills/create-skill/SKILL.md +2 -2
  141. package/dist/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  142. package/dist/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  143. package/dist/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  144. package/dist/resources/skills/verify-before-complete/SKILL.md +2 -1
  145. package/dist/resources/skills/write-docs/SKILL.md +2 -1
  146. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  147. package/dist/web/standalone/.next/BUILD_ID +1 -1
  148. package/dist/web/standalone/.next/app-path-routes-manifest.json +10 -10
  149. package/dist/web/standalone/.next/build-manifest.json +3 -3
  150. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  151. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  152. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  153. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  154. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  155. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  156. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  157. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  158. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  159. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  160. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  161. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  162. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  163. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  164. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  165. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  166. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  167. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  168. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  169. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  170. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  171. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  172. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  173. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  174. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +1 -1
  175. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  176. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  177. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  178. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  179. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  180. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  181. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  182. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  183. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  184. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  185. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  186. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  187. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  188. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  189. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  190. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  191. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  192. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  193. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  194. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  195. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  196. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  197. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  198. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  199. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  200. package/dist/web/standalone/.next/server/app/api/notifications/route.js +1 -1
  201. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  202. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  203. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  204. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  205. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  206. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  207. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  208. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  209. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  210. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  211. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  212. package/dist/web/standalone/.next/server/app/api/session/events/route.js +1 -1
  213. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  214. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  216. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  217. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  218. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  219. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  220. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  221. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  222. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  223. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  224. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
  225. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  226. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  228. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  229. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  230. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  232. package/dist/web/standalone/.next/server/app/index.html +1 -1
  233. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  234. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  235. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  236. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  237. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  238. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  239. package/dist/web/standalone/.next/server/app-paths-manifest.json +10 -10
  240. package/dist/web/standalone/.next/server/chunks/1926.js +1 -0
  241. package/dist/web/standalone/.next/server/chunks/6897.js +2 -2
  242. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  243. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  244. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  245. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  246. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  247. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  248. package/dist/web/standalone/.next/static/chunks/2826.e9f5195e91f9cad2.js +11 -0
  249. package/dist/web/standalone/.next/static/chunks/{webpack-5fc74f13a25fa1bb.js → webpack-2e68521d7c82f7c2.js} +1 -1
  250. package/dist/welcome-screen.js +6 -1
  251. package/dist/wizard.js +2 -0
  252. package/package.json +17 -16
  253. package/packages/daemon/package.json +2 -2
  254. package/packages/daemon/src/logger.ts +4 -3
  255. package/packages/mcp-server/README.md +3 -3
  256. package/packages/mcp-server/dist/env-writer.d.ts +1 -0
  257. package/packages/mcp-server/dist/env-writer.d.ts.map +1 -1
  258. package/packages/mcp-server/dist/env-writer.js +74 -6
  259. package/packages/mcp-server/dist/env-writer.js.map +1 -1
  260. package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
  261. package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
  262. package/packages/mcp-server/dist/remote-questions.js +732 -0
  263. package/packages/mcp-server/dist/remote-questions.js.map +1 -0
  264. package/packages/mcp-server/dist/server.d.ts +31 -0
  265. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  266. package/packages/mcp-server/dist/server.js +179 -93
  267. package/packages/mcp-server/dist/server.js.map +1 -1
  268. package/packages/mcp-server/dist/session-manager.d.ts +14 -0
  269. package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
  270. package/packages/mcp-server/dist/session-manager.js +49 -1
  271. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  272. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  273. package/packages/mcp-server/dist/workflow-tools.js +15 -6
  274. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  275. package/packages/mcp-server/package.json +9 -3
  276. package/packages/mcp-server/src/env-writer.test.ts +79 -1
  277. package/packages/mcp-server/src/env-writer.ts +76 -6
  278. package/packages/mcp-server/src/mcp-server.test.ts +89 -0
  279. package/packages/mcp-server/src/readers/graph.test.ts +87 -15
  280. package/packages/mcp-server/src/readers/readers.test.ts +5 -1
  281. package/packages/mcp-server/src/remote-questions.test.ts +294 -0
  282. package/packages/mcp-server/src/remote-questions.ts +916 -0
  283. package/packages/mcp-server/src/secure-env-collect.test.ts +232 -237
  284. package/packages/mcp-server/src/server.ts +236 -108
  285. package/packages/mcp-server/src/session-manager.ts +43 -1
  286. package/packages/mcp-server/src/workflow-tools.test.ts +85 -0
  287. package/packages/mcp-server/src/workflow-tools.ts +19 -6
  288. package/packages/mcp-server/tsconfig.test.json +19 -0
  289. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  290. package/packages/native/package.json +7 -2
  291. package/packages/native/src/__tests__/_test-coverage-guard.test.mjs +98 -0
  292. package/packages/native/src/__tests__/clipboard.test.mjs +69 -23
  293. package/packages/native/src/__tests__/module-compat.test.mjs +59 -27
  294. package/packages/native/src/__tests__/ps.test.mjs +14 -8
  295. package/packages/native/src/__tests__/stream-process.test.mjs +23 -2
  296. package/packages/native/src/__tests__/truncate.test.mjs +17 -2
  297. package/packages/native/tsconfig.tsbuildinfo +1 -1
  298. package/packages/pi-agent-core/package.json +6 -1
  299. package/packages/pi-agent-core/src/agent-loop.test.ts +226 -31
  300. package/packages/pi-agent-core/src/agent.test.ts +96 -102
  301. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  302. package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -1
  303. package/packages/pi-ai/dist/models/capability-patches.js +9 -2
  304. package/packages/pi-ai/dist/models/capability-patches.js.map +1 -1
  305. package/packages/pi-ai/dist/models/custom.d.ts +38 -0
  306. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
  307. package/packages/pi-ai/dist/models/custom.js +41 -0
  308. package/packages/pi-ai/dist/models/custom.js.map +1 -1
  309. package/packages/pi-ai/dist/models/generated/index.d.ts +34 -0
  310. package/packages/pi-ai/dist/models/generated/index.d.ts.map +1 -1
  311. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +17 -0
  312. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -1
  313. package/packages/pi-ai/dist/models/generated/openai-codex.js +17 -0
  314. package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -1
  315. package/packages/pi-ai/dist/models/generated/openai.d.ts +17 -0
  316. package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -1
  317. package/packages/pi-ai/dist/models/generated/openai.js +17 -0
  318. package/packages/pi-ai/dist/models/generated/openai.js.map +1 -1
  319. package/packages/pi-ai/dist/models.generated.test.js +43 -70
  320. package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
  321. package/packages/pi-ai/dist/models.test.js +36 -11
  322. package/packages/pi-ai/dist/models.test.js.map +1 -1
  323. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
  324. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  325. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  326. package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
  327. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  328. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  329. package/packages/pi-ai/dist/providers/anthropic.js +8 -3
  330. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  331. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
  332. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
  333. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
  334. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
  335. package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
  336. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  337. package/packages/pi-ai/dist/providers/simple-options.js +16 -1
  338. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  339. package/packages/pi-ai/package.json +6 -1
  340. package/packages/pi-ai/scripts/generate-models.ts +44 -0
  341. package/packages/pi-ai/src/models/capability-patches.ts +10 -2
  342. package/packages/pi-ai/src/models/custom.ts +42 -0
  343. package/packages/pi-ai/src/models/generated/openai-codex.ts +17 -0
  344. package/packages/pi-ai/src/models/generated/openai.ts +17 -0
  345. package/packages/pi-ai/src/models.generated.test.ts +46 -73
  346. package/packages/pi-ai/src/models.test.ts +48 -11
  347. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
  348. package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
  349. package/packages/pi-ai/src/providers/anthropic.ts +9 -3
  350. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
  351. package/packages/pi-ai/src/providers/simple-options.ts +17 -1
  352. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  353. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +96 -31
  354. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  355. package/packages/pi-coding-agent/dist/core/agent-session-model-switch.test.js +75 -12
  356. package/packages/pi-coding-agent/dist/core/agent-session-model-switch.test.js.map +1 -1
  357. package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js +99 -31
  358. package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js.map +1 -1
  359. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  360. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  361. package/packages/pi-coding-agent/dist/core/agent-session.js +7 -0
  362. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  363. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +25 -0
  364. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  365. package/packages/pi-coding-agent/dist/core/compaction/compaction.js +105 -6
  366. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  367. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js +230 -28
  368. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js.map +1 -1
  369. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts +30 -2
  370. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts.map +1 -1
  371. package/packages/pi-coding-agent/dist/core/compaction/utils.js +113 -12
  372. package/packages/pi-coding-agent/dist/core/compaction/utils.js.map +1 -1
  373. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts +1 -0
  374. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts.map +1 -1
  375. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +29 -18
  376. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
  377. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts +2 -0
  378. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts.map +1 -0
  379. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js +130 -0
  380. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js.map +1 -0
  381. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js +56 -1
  382. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js.map +1 -1
  383. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js +8 -15
  384. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js.map +1 -1
  385. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts +25 -0
  386. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts.map +1 -0
  387. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js +109 -0
  388. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js.map +1 -0
  389. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts +67 -0
  390. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts.map +1 -0
  391. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js +167 -0
  392. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js.map +1 -0
  393. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +8 -2
  394. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  395. package/packages/pi-coding-agent/dist/core/extensions/loader.js +85 -8
  396. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  397. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +2 -0
  398. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  399. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  400. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +14 -0
  401. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  402. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  403. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js +41 -4
  404. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js.map +1 -1
  405. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +19 -2
  406. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
  407. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
  408. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
  409. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
  410. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
  411. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  412. package/packages/pi-coding-agent/dist/core/model-registry.js +14 -0
  413. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  414. package/packages/pi-coding-agent/dist/core/resource-loader-cache-reset.test.js +76 -18
  415. package/packages/pi-coding-agent/dist/core/resource-loader-cache-reset.test.js.map +1 -1
  416. package/packages/pi-coding-agent/dist/core/resource-loader.js +1 -1
  417. package/packages/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
  418. package/packages/pi-coding-agent/dist/core/retry-handler.d.ts.map +1 -1
  419. package/packages/pi-coding-agent/dist/core/retry-handler.js +2 -6
  420. package/packages/pi-coding-agent/dist/core/retry-handler.js.map +1 -1
  421. package/packages/pi-coding-agent/dist/core/retry-handler.test.js +5 -1
  422. package/packages/pi-coding-agent/dist/core/retry-handler.test.js.map +1 -1
  423. package/packages/pi-coding-agent/dist/core/retryable-error-regex.d.ts +18 -0
  424. package/packages/pi-coding-agent/dist/core/retryable-error-regex.d.ts.map +1 -0
  425. package/packages/pi-coding-agent/dist/core/retryable-error-regex.js +18 -0
  426. package/packages/pi-coding-agent/dist/core/retryable-error-regex.js.map +1 -0
  427. package/packages/pi-coding-agent/dist/core/sdk.d.ts +1 -0
  428. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  429. package/packages/pi-coding-agent/dist/core/sdk.js +4 -1
  430. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  431. package/packages/pi-coding-agent/dist/core/sdk.test.js +19 -1
  432. package/packages/pi-coding-agent/dist/core/sdk.test.js.map +1 -1
  433. package/packages/pi-coding-agent/dist/core/session-manager.js +1 -1
  434. package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  435. package/packages/pi-coding-agent/dist/core/session-manager.test.js +21 -1
  436. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  437. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts +20 -0
  438. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
  439. package/packages/pi-coding-agent/dist/core/system-prompt.js +19 -5
  440. package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  441. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js +2 -1
  442. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js.map +1 -1
  443. package/packages/pi-coding-agent/dist/index.d.ts +1 -0
  444. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  445. package/packages/pi-coding-agent/dist/index.js +1 -0
  446. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  447. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js +15 -6
  448. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js.map +1 -1
  449. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +36 -5
  450. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  451. package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.js +20 -13
  452. package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.js.map +1 -1
  453. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  454. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +14 -5
  455. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  456. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts +7 -1
  457. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
  458. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js +31 -9
  459. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js.map +1 -1
  460. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  461. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +30 -12
  462. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  463. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
  464. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.js +18 -3
  465. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.js.map +1 -1
  466. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +139 -0
  467. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
  468. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.d.ts +2 -0
  469. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.d.ts.map +1 -1
  470. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.js.map +1 -1
  471. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +4 -0
  472. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  473. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +118 -14
  474. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  475. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.d.ts +2 -0
  476. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.d.ts.map +1 -0
  477. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.js +130 -0
  478. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.js.map +1 -0
  479. package/packages/pi-coding-agent/package.json +6 -1
  480. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +113 -36
  481. package/packages/pi-coding-agent/src/core/agent-session-model-switch.test.ts +89 -17
  482. package/packages/pi-coding-agent/src/core/agent-session-tool-refresh.test.ts +112 -43
  483. package/packages/pi-coding-agent/src/core/agent-session.ts +11 -0
  484. package/packages/pi-coding-agent/src/core/compaction/compaction.test.ts +368 -28
  485. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +122 -6
  486. package/packages/pi-coding-agent/src/core/compaction/utils.ts +111 -13
  487. package/packages/pi-coding-agent/src/core/compaction-orchestrator.test.ts +154 -0
  488. package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +32 -18
  489. package/packages/pi-coding-agent/src/core/compaction-utils.test.ts +68 -1
  490. package/packages/pi-coding-agent/src/core/discovery-cache.test.ts +9 -18
  491. package/packages/pi-coding-agent/src/core/extensions/extension-discovery.ts +119 -0
  492. package/packages/pi-coding-agent/src/core/extensions/extension-registry.ts +222 -0
  493. package/packages/pi-coding-agent/src/core/extensions/loader.ts +82 -11
  494. package/packages/pi-coding-agent/src/core/extensions/runner.ts +2 -0
  495. package/packages/pi-coding-agent/src/core/extensions/types.ts +15 -0
  496. package/packages/pi-coding-agent/src/core/lsp/lsp-integration.test.ts +48 -4
  497. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +22 -2
  498. package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
  499. package/packages/pi-coding-agent/src/core/model-registry.ts +16 -0
  500. package/packages/pi-coding-agent/src/core/resource-loader-cache-reset.test.ts +93 -28
  501. package/packages/pi-coding-agent/src/core/resource-loader.ts +1 -1
  502. package/packages/pi-coding-agent/src/core/retry-handler.test.ts +5 -1
  503. package/packages/pi-coding-agent/src/core/retry-handler.ts +2 -8
  504. package/packages/pi-coding-agent/src/core/retryable-error-regex.ts +18 -0
  505. package/packages/pi-coding-agent/src/core/sdk.test.ts +25 -1
  506. package/packages/pi-coding-agent/src/core/sdk.ts +10 -3
  507. package/packages/pi-coding-agent/src/core/session-manager.test.ts +30 -1
  508. package/packages/pi-coding-agent/src/core/session-manager.ts +1 -1
  509. package/packages/pi-coding-agent/src/core/system-prompt.ts +38 -4
  510. package/packages/pi-coding-agent/src/core/tools/path-utils.test.ts +2 -1
  511. package/packages/pi-coding-agent/src/index.ts +1 -0
  512. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/provider-display-name.test.ts +17 -7
  513. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +49 -3
  514. package/packages/pi-coding-agent/src/modes/interactive/components/dynamic-border.test.ts +26 -20
  515. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +14 -5
  516. package/packages/pi-coding-agent/src/modes/interactive/components/model-selector.ts +45 -11
  517. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +48 -9
  518. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +160 -1
  519. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.ts +20 -3
  520. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-state.ts +2 -0
  521. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +132 -14
  522. package/packages/pi-coding-agent/src/tests/system-prompt-skill-filter.test.ts +157 -0
  523. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  524. package/packages/pi-tui/dist/__tests__/autocomplete.test.js +31 -14
  525. package/packages/pi-tui/dist/__tests__/autocomplete.test.js.map +1 -1
  526. package/packages/pi-tui/dist/__tests__/overlay-layout.test.js +128 -17
  527. package/packages/pi-tui/dist/__tests__/overlay-layout.test.js.map +1 -1
  528. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js +51 -6
  529. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js.map +1 -1
  530. package/packages/pi-tui/dist/__tests__/tui.test.js +18 -30
  531. package/packages/pi-tui/dist/__tests__/tui.test.js.map +1 -1
  532. package/packages/pi-tui/dist/components/__tests__/input.test.js +10 -3
  533. package/packages/pi-tui/dist/components/__tests__/input.test.js.map +1 -1
  534. package/packages/pi-tui/dist/components/__tests__/loader.test.js +53 -9
  535. package/packages/pi-tui/dist/components/__tests__/loader.test.js.map +1 -1
  536. package/packages/pi-tui/dist/components/__tests__/markdown-maxlines.test.js +6 -2
  537. package/packages/pi-tui/dist/components/__tests__/markdown-maxlines.test.js.map +1 -1
  538. package/packages/pi-tui/dist/components/editor.d.ts +14 -0
  539. package/packages/pi-tui/dist/components/editor.d.ts.map +1 -1
  540. package/packages/pi-tui/dist/components/editor.js +19 -0
  541. package/packages/pi-tui/dist/components/editor.js.map +1 -1
  542. package/packages/pi-tui/dist/components/image.test.js +6 -5
  543. package/packages/pi-tui/dist/components/image.test.js.map +1 -1
  544. package/packages/pi-tui/dist/editor-component.d.ts +2 -0
  545. package/packages/pi-tui/dist/editor-component.d.ts.map +1 -1
  546. package/packages/pi-tui/dist/editor-component.js.map +1 -1
  547. package/packages/pi-tui/dist/stdin-buffer.d.ts +7 -0
  548. package/packages/pi-tui/dist/stdin-buffer.d.ts.map +1 -1
  549. package/packages/pi-tui/dist/stdin-buffer.js +20 -0
  550. package/packages/pi-tui/dist/stdin-buffer.js.map +1 -1
  551. package/packages/pi-tui/package.json +6 -1
  552. package/packages/pi-tui/src/__tests__/autocomplete.test.ts +46 -15
  553. package/packages/pi-tui/src/__tests__/overlay-layout.test.ts +140 -17
  554. package/packages/pi-tui/src/__tests__/stdin-buffer.test.ts +62 -6
  555. package/packages/pi-tui/src/__tests__/tui.test.ts +18 -37
  556. package/packages/pi-tui/src/components/__tests__/input.test.ts +19 -3
  557. package/packages/pi-tui/src/components/__tests__/loader.test.ts +112 -35
  558. package/packages/pi-tui/src/components/__tests__/markdown-maxlines.test.ts +9 -2
  559. package/packages/pi-tui/src/components/editor.ts +22 -0
  560. package/packages/pi-tui/src/components/image.test.ts +10 -5
  561. package/packages/pi-tui/src/editor-component.ts +3 -0
  562. package/packages/pi-tui/src/stdin-buffer.ts +26 -0
  563. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  564. package/packages/rpc-client/dist/rpc-client.test.js +101 -51
  565. package/packages/rpc-client/dist/rpc-client.test.js.map +1 -1
  566. package/packages/rpc-client/package.json +6 -1
  567. package/packages/rpc-client/src/rpc-client.test.ts +109 -52
  568. package/packages/rpc-client/tsconfig.tsbuildinfo +1 -1
  569. package/pkg/package.json +1 -1
  570. package/scripts/install.js +526 -0
  571. package/scripts/lib/workspace-manifest.cjs +86 -0
  572. package/scripts/link-workspace-packages.cjs +5 -17
  573. package/scripts/postinstall.js +9 -178
  574. package/src/resources/extensions/browser-tools/capture.ts +12 -0
  575. package/src/resources/extensions/browser-tools/tests/browser-tools-integration.test.mjs +8 -59
  576. package/src/resources/extensions/browser-tools/tests/browser-tools-unit.test.cjs +36 -24
  577. package/src/resources/extensions/browser-tools/tests/capture-sharp-optional.test.cjs +69 -71
  578. package/src/resources/extensions/browser-tools/tools/forms.ts +5 -1
  579. package/src/resources/extensions/browser-tools/tools/intent.ts +5 -1
  580. package/src/resources/extensions/claude-code-cli/readiness.ts +9 -4
  581. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +609 -82
  582. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +1033 -87
  583. package/src/resources/extensions/cmux/index.ts +35 -10
  584. package/src/resources/extensions/github-sync/templates.ts +151 -0
  585. package/src/resources/extensions/github-sync/tests/cli.test.ts +76 -7
  586. package/src/resources/extensions/github-sync/tests/templates.test.ts +92 -1
  587. package/src/resources/extensions/google-search/extension-manifest.json +5 -4
  588. package/src/resources/extensions/google-search/index.ts +9 -470
  589. package/src/resources/extensions/gsd/abandon-detect.ts +62 -0
  590. package/src/resources/extensions/gsd/auto/loop-deps.ts +14 -1
  591. package/src/resources/extensions/gsd/auto/loop.ts +151 -2
  592. package/src/resources/extensions/gsd/auto/phases.ts +139 -41
  593. package/src/resources/extensions/gsd/auto/resolve.ts +29 -0
  594. package/src/resources/extensions/gsd/auto/run-unit.ts +56 -4
  595. package/src/resources/extensions/gsd/auto/session.ts +35 -3
  596. package/src/resources/extensions/gsd/auto/turn-epoch.ts +108 -0
  597. package/src/resources/extensions/gsd/auto/types.ts +1 -1
  598. package/src/resources/extensions/gsd/auto-dispatch.ts +229 -39
  599. package/src/resources/extensions/gsd/auto-loop.ts +1 -1
  600. package/src/resources/extensions/gsd/auto-model-selection.ts +132 -5
  601. package/src/resources/extensions/gsd/auto-post-unit.ts +255 -76
  602. package/src/resources/extensions/gsd/auto-prompts.ts +413 -94
  603. package/src/resources/extensions/gsd/auto-recovery.ts +125 -2
  604. package/src/resources/extensions/gsd/auto-start.ts +166 -60
  605. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +12 -5
  606. package/src/resources/extensions/gsd/auto-tool-tracking.ts +51 -7
  607. package/src/resources/extensions/gsd/auto-unit-closeout.ts +14 -3
  608. package/src/resources/extensions/gsd/auto-worktree.ts +251 -93
  609. package/src/resources/extensions/gsd/auto.ts +182 -54
  610. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +43 -2
  611. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +221 -0
  612. package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +6 -6
  613. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +11 -0
  614. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +25 -9
  615. package/src/resources/extensions/gsd/bootstrap/system-context.ts +13 -9
  616. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +193 -11
  617. package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
  618. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +27 -8
  619. package/src/resources/extensions/gsd/commands-cmux.ts +10 -6
  620. package/src/resources/extensions/gsd/commands-extensions.ts +747 -41
  621. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
  622. package/src/resources/extensions/gsd/component-loader.ts +598 -0
  623. package/src/resources/extensions/gsd/component-types.ts +362 -0
  624. package/src/resources/extensions/gsd/context-store.ts +25 -8
  625. package/src/resources/extensions/gsd/detection.ts +58 -1
  626. package/src/resources/extensions/gsd/dispatch-guard.ts +26 -2
  627. package/src/resources/extensions/gsd/docs/preferences-reference.md +1 -1
  628. package/src/resources/extensions/gsd/file-lock.ts +84 -11
  629. package/src/resources/extensions/gsd/forensics.ts +118 -1
  630. package/src/resources/extensions/gsd/gate-registry.ts +2 -2
  631. package/src/resources/extensions/gsd/git-constants.ts +30 -1
  632. package/src/resources/extensions/gsd/git-self-heal.ts +31 -0
  633. package/src/resources/extensions/gsd/git-service.ts +150 -2
  634. package/src/resources/extensions/gsd/gitignore.ts +2 -1
  635. package/src/resources/extensions/gsd/gsd-db.ts +97 -34
  636. package/src/resources/extensions/gsd/guided-flow-queue.ts +4 -1
  637. package/src/resources/extensions/gsd/guided-flow.ts +261 -14
  638. package/src/resources/extensions/gsd/health-widget.ts +3 -1
  639. package/src/resources/extensions/gsd/journal.ts +39 -3
  640. package/src/resources/extensions/gsd/key-manager.ts +22 -0
  641. package/src/resources/extensions/gsd/memory-extractor.ts +11 -3
  642. package/src/resources/extensions/gsd/milestone-actions.ts +18 -0
  643. package/src/resources/extensions/gsd/milestone-scope-classifier.ts +366 -0
  644. package/src/resources/extensions/gsd/milestone-summary-classifier.ts +42 -0
  645. package/src/resources/extensions/gsd/model-cost-table.ts +3 -0
  646. package/src/resources/extensions/gsd/model-router.ts +48 -1
  647. package/src/resources/extensions/gsd/native-git-bridge.ts +34 -4
  648. package/src/resources/extensions/gsd/notifications.ts +27 -15
  649. package/src/resources/extensions/gsd/pre-execution-checks.ts +33 -7
  650. package/src/resources/extensions/gsd/preferences-types.ts +8 -0
  651. package/src/resources/extensions/gsd/preferences-validation.ts +21 -0
  652. package/src/resources/extensions/gsd/prompt-cache-optimizer.ts +4 -0
  653. package/src/resources/extensions/gsd/prompts/complete-milestone.md +5 -1
  654. package/src/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  655. package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
  656. package/src/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  657. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  658. package/src/resources/extensions/gsd/prompts/plan-slice.md +15 -2
  659. package/src/resources/extensions/gsd/prompts/system.md +1 -0
  660. package/src/resources/extensions/gsd/reports.ts +5 -4
  661. package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
  662. package/src/resources/extensions/gsd/safety/file-change-validator.ts +16 -3
  663. package/src/resources/extensions/gsd/safety/git-checkpoint.ts +15 -0
  664. package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
  665. package/src/resources/extensions/gsd/service-tier.ts +5 -2
  666. package/src/resources/extensions/gsd/session-lock.ts +20 -10
  667. package/src/resources/extensions/gsd/skill-manifest.ts +175 -0
  668. package/src/resources/extensions/gsd/slice-cadence.ts +299 -0
  669. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +309 -8
  670. package/src/resources/extensions/gsd/state-transition-matrix.ts +152 -0
  671. package/src/resources/extensions/gsd/state.ts +76 -66
  672. package/src/resources/extensions/gsd/sync-lock.ts +97 -39
  673. package/src/resources/extensions/gsd/tests/artifact-retry-cap.test.ts +270 -0
  674. package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +2 -1
  675. package/src/resources/extensions/gsd/tests/auto-deterministic-error-classification-4973.test.ts +341 -0
  676. package/src/resources/extensions/gsd/tests/auto-discuss-milestone-deadlock-4973.test.ts +264 -0
  677. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +322 -286
  678. package/src/resources/extensions/gsd/tests/auto-mode-guards.test.ts +79 -0
  679. package/src/resources/extensions/gsd/tests/auto-model-selection-tool-poisoning.test.ts +742 -0
  680. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +78 -0
  681. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
  682. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +61 -0
  683. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +122 -0
  684. package/src/resources/extensions/gsd/tests/auto-remediate-slice-status.test.ts +4 -1
  685. package/src/resources/extensions/gsd/tests/auto-retry-mcp-churn-fixes.test.ts +8 -194
  686. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
  687. package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +64 -0
  688. package/src/resources/extensions/gsd/tests/auto-start-cold-db-bootstrap.test.ts +2 -2
  689. package/src/resources/extensions/gsd/tests/auto-start-needs-discussion.test.ts +15 -58
  690. package/src/resources/extensions/gsd/tests/auto-start-worktree-db-path.test.ts +2 -2
  691. package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +3 -2
  692. package/src/resources/extensions/gsd/tests/auto-warning-noise-regression.test.ts +3 -2
  693. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
  694. package/src/resources/extensions/gsd/tests/bootstrap-derive-state-db-open.test.ts +2 -1
  695. package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +17 -21
  696. package/src/resources/extensions/gsd/tests/canonical-milestone-root.test.ts +108 -0
  697. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
  698. package/src/resources/extensions/gsd/tests/cmux.test.ts +5 -9
  699. package/src/resources/extensions/gsd/tests/complete-milestone-excerpt.test.ts +263 -0
  700. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
  701. package/src/resources/extensions/gsd/tests/complete-slice-composer.test.ts +192 -0
  702. package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +2 -1
  703. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  704. package/src/resources/extensions/gsd/tests/complete-task.test.ts +16 -8
  705. package/src/resources/extensions/gsd/tests/component-loader.test.ts +589 -0
  706. package/src/resources/extensions/gsd/tests/component-types.test.ts +127 -0
  707. package/src/resources/extensions/gsd/tests/context-store.test.ts +79 -0
  708. package/src/resources/extensions/gsd/tests/copy-planning-artifacts-samepath.test.ts +2 -1
  709. package/src/resources/extensions/gsd/tests/crash-recovery.test.ts +50 -1
  710. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +161 -0
  711. package/src/resources/extensions/gsd/tests/db-access-guardrails.test.ts +1 -0
  712. package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +3 -3
  713. package/src/resources/extensions/gsd/tests/derive-state-db-disk-reconcile.test.ts +40 -0
  714. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +91 -3
  715. package/src/resources/extensions/gsd/tests/derive-state.test.ts +4 -4
  716. package/src/resources/extensions/gsd/tests/discuss-slice-structured-questions.test.ts +2 -1
  717. package/src/resources/extensions/gsd/tests/discuss-tool-scope-leak.test.ts +2 -1
  718. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +14 -9
  719. package/src/resources/extensions/gsd/tests/dispatch-guard-summary-db-mismatch.test.ts +77 -0
  720. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +25 -0
  721. package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +14 -0
  722. package/src/resources/extensions/gsd/tests/dispatcher-stuck-planning.test.ts +3 -2
  723. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +31 -0
  724. package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +4 -3
  725. package/src/resources/extensions/gsd/tests/empty-content-abort-loop.test.ts +4 -3
  726. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +1 -1
  727. package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
  728. package/src/resources/extensions/gsd/tests/exec-history.test.ts +113 -0
  729. package/src/resources/extensions/gsd/tests/execution-entry-missing-context-4671.test.ts +173 -0
  730. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +139 -129
  731. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +38 -0
  732. package/src/resources/extensions/gsd/tests/file-lock.test.ts +86 -12
  733. package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +8 -104
  734. package/src/resources/extensions/gsd/tests/gate-state-canonicalization.test.ts +102 -0
  735. package/src/resources/extensions/gsd/tests/gate-storage.test.ts +1 -1
  736. package/src/resources/extensions/gsd/tests/google-search-stub.test.ts +131 -0
  737. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +296 -1
  738. package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +117 -0
  739. package/src/resources/extensions/gsd/tests/hook-key-parsing.test.ts +4 -55
  740. package/src/resources/extensions/gsd/tests/integration/all-milestones-complete-merge.test.ts +7 -56
  741. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +30 -0
  742. package/src/resources/extensions/gsd/tests/integration/doctor-proactive.test.ts +18 -2
  743. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +4 -2
  744. package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
  745. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
  746. package/src/resources/extensions/gsd/tests/integration/queue-completed-milestone-perf.test.ts +10 -4
  747. package/src/resources/extensions/gsd/tests/integration/state-machine-edge-cases.test.ts +144 -7
  748. package/src/resources/extensions/gsd/tests/integration/state-machine-live-validation.test.ts +4 -0
  749. package/src/resources/extensions/gsd/tests/integration/state-machine-runtime-failures.test.ts +2 -16
  750. package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +11 -0
  751. package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +9 -3
  752. package/src/resources/extensions/gsd/tests/interrupted-session-ui.test.ts +6 -9
  753. package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
  754. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +66 -0
  755. package/src/resources/extensions/gsd/tests/key-manager.test.ts +2 -0
  756. package/src/resources/extensions/gsd/tests/knowledge.test.ts +93 -1
  757. package/src/resources/extensions/gsd/tests/mcp-client-security.test.ts +47 -0
  758. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  759. package/src/resources/extensions/gsd/tests/memory-extractor.test.ts +5 -15
  760. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
  761. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  762. package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +227 -55
  763. package/src/resources/extensions/gsd/tests/milestone-scope-classifier.test.ts +187 -0
  764. package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +3 -3
  765. package/src/resources/extensions/gsd/tests/milestone-summary-classifier.test.ts +30 -0
  766. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +4 -2
  767. package/src/resources/extensions/gsd/tests/model-cost-table.test.ts +9 -1
  768. package/src/resources/extensions/gsd/tests/model-router.test.ts +1 -1
  769. package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +6 -48
  770. package/src/resources/extensions/gsd/tests/notification-widget.test.ts +6 -3
  771. package/src/resources/extensions/gsd/tests/orphaned-worktree-audit.test.ts +59 -2
  772. package/src/resources/extensions/gsd/tests/parallel-commit-scope.test.ts +5 -0
  773. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +274 -112
  774. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +150 -0
  775. package/src/resources/extensions/gsd/tests/pipeline-variant-dispatch.test.ts +301 -0
  776. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
  777. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
  778. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +337 -0
  779. package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +32 -1
  780. package/src/resources/extensions/gsd/tests/preferences-worktree-sync.test.ts +2 -1
  781. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
  782. package/src/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +12 -0
  783. package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +15 -4
  784. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +54 -41
  785. package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +213 -0
  786. package/src/resources/extensions/gsd/tests/queue-draft-detection.test.ts +3 -2
  787. package/src/resources/extensions/gsd/tests/queued-discuss-fast-path.test.ts +4 -5
  788. package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +13 -7
  789. package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
  790. package/src/resources/extensions/gsd/tests/reassess-default-optin.test.ts +132 -0
  791. package/src/resources/extensions/gsd/tests/recovery-attempts-reset.test.ts +8 -40
  792. package/src/resources/extensions/gsd/tests/regex-hardening.test.ts +136 -256
  793. package/src/resources/extensions/gsd/tests/require-slice-discussion-dispatch.test.ts +170 -0
  794. package/src/resources/extensions/gsd/tests/research-milestone-composer.test.ts +114 -0
  795. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +15 -6
  796. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
  797. package/src/resources/extensions/gsd/tests/rewrite-docs-abandon-detect.test.ts +195 -0
  798. package/src/resources/extensions/gsd/tests/run-uat-composer.test.ts +148 -0
  799. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
  800. package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
  801. package/src/resources/extensions/gsd/tests/service-tier.test.ts +4 -0
  802. package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +29 -0
  803. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
  804. package/src/resources/extensions/gsd/tests/sidecar-queue.test.ts +3 -2
  805. package/src/resources/extensions/gsd/tests/silent-catch-diagnostics.test.ts +55 -95
  806. package/src/resources/extensions/gsd/tests/single-writer-v3-tool-surface.test.ts +158 -0
  807. package/src/resources/extensions/gsd/tests/skill-activation.test.ts +120 -1
  808. package/src/resources/extensions/gsd/tests/skill-manifest.test.ts +112 -0
  809. package/src/resources/extensions/gsd/tests/slice-cadence.test.ts +242 -0
  810. package/src/resources/extensions/gsd/tests/slice-context-injection.test.ts +3 -2
  811. package/src/resources/extensions/gsd/tests/slice-parallel-orchestrator.test.ts +164 -1
  812. package/src/resources/extensions/gsd/tests/smart-entry-draft.test.ts +2 -1
  813. package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +112 -0
  814. package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
  815. package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +29 -5
  816. package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +44 -0
  817. package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +3 -3
  818. package/src/resources/extensions/gsd/tests/structured-data-formatter.test.ts +11 -92
  819. package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +2 -2
  820. package/src/resources/extensions/gsd/tests/subagent-model-dispatch.test.ts +7 -6
  821. package/src/resources/extensions/gsd/tests/survivor-branch-complete.test.ts +102 -101
  822. package/src/resources/extensions/gsd/tests/sync-lock.test.ts +31 -0
  823. package/src/resources/extensions/gsd/tests/sync-worktree-skip-current.test.ts +4 -3
  824. package/src/resources/extensions/gsd/tests/test-helpers.test.ts +98 -0
  825. package/src/resources/extensions/gsd/tests/test-helpers.ts +153 -0
  826. package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
  827. package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -1
  828. package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
  829. package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +61 -1
  830. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +8 -1
  831. package/src/resources/extensions/gsd/tests/triage-resolution.test.ts +50 -2
  832. package/src/resources/extensions/gsd/tests/turn-epoch.test.ts +162 -0
  833. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +355 -0
  834. package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +258 -0
  835. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +51 -0
  836. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +16 -0
  837. package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +75 -0
  838. package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +49 -26
  839. package/src/resources/extensions/gsd/tests/uok-loop-adapter-writer.test.ts +65 -0
  840. package/src/resources/extensions/gsd/tests/uok-parity-report.test.ts +42 -0
  841. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +42 -2
  842. package/src/resources/extensions/gsd/tests/uok-writer.test.ts +75 -0
  843. package/src/resources/extensions/gsd/tests/validate-extension-package.test.ts +168 -0
  844. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +139 -5
  845. package/src/resources/extensions/gsd/tests/verify-artifact-tightened.test.ts +144 -80
  846. package/src/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +20 -54
  847. package/src/resources/extensions/gsd/tests/visualizer-overlay.test.ts +342 -277
  848. package/src/resources/extensions/gsd/tests/worker-model-override.test.ts +37 -29
  849. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +25 -2
  850. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
  851. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +242 -247
  852. package/src/resources/extensions/gsd/tests/worktree-health-monorepo.test.ts +103 -67
  853. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
  854. package/src/resources/extensions/gsd/tests/worktree-nested-git-safety.test.ts +92 -90
  855. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
  856. package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +238 -59
  857. package/src/resources/extensions/gsd/tests/worktree-sync-overwrite-loop.test.ts +113 -161
  858. package/src/resources/extensions/gsd/tests/worktree-telemetry.test.ts +210 -0
  859. package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +262 -0
  860. package/src/resources/extensions/gsd/tests/write-gate-predicates.test.ts +186 -0
  861. package/src/resources/extensions/gsd/tests/write-gate.test.ts +71 -5
  862. package/src/resources/extensions/gsd/tests/zombie-gsd-state.test.ts +80 -96
  863. package/src/resources/extensions/gsd/token-counter.ts +22 -5
  864. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  865. package/src/resources/extensions/gsd/tools/complete-slice.ts +38 -0
  866. package/src/resources/extensions/gsd/tools/complete-task.ts +49 -0
  867. package/src/resources/extensions/gsd/tools/validate-milestone.ts +8 -2
  868. package/src/resources/extensions/gsd/types.ts +3 -3
  869. package/src/resources/extensions/gsd/unit-context-composer.ts +218 -0
  870. package/src/resources/extensions/gsd/unit-context-manifest.ts +574 -0
  871. package/src/resources/extensions/gsd/uok/audit.ts +20 -2
  872. package/src/resources/extensions/gsd/uok/contracts.ts +65 -0
  873. package/src/resources/extensions/gsd/uok/dispatch-envelope.ts +56 -0
  874. package/src/resources/extensions/gsd/uok/execution-graph.ts +22 -0
  875. package/src/resources/extensions/gsd/uok/gate-runner.ts +65 -5
  876. package/src/resources/extensions/gsd/uok/gitops.ts +6 -1
  877. package/src/resources/extensions/gsd/uok/loop-adapter.ts +45 -10
  878. package/src/resources/extensions/gsd/uok/parity-report.ts +84 -0
  879. package/src/resources/extensions/gsd/uok/plan-v2.ts +39 -8
  880. package/src/resources/extensions/gsd/uok/writer.ts +113 -0
  881. package/src/resources/extensions/gsd/workflow-logger.ts +23 -3
  882. package/src/resources/extensions/gsd/workflow-mcp.ts +6 -0
  883. package/src/resources/extensions/gsd/worktree-manager.ts +109 -7
  884. package/src/resources/extensions/gsd/worktree-resolver.ts +150 -18
  885. package/src/resources/extensions/gsd/worktree-telemetry.ts +322 -0
  886. package/src/resources/extensions/mcp-client/auth.ts +12 -1
  887. package/src/resources/extensions/mcp-client/index.ts +132 -11
  888. package/src/resources/extensions/mcp-client/tests/server-name-spaces.test.ts +70 -36
  889. package/src/resources/extensions/ollama/index.ts +5 -1
  890. package/src/resources/extensions/ollama/ollama-auth-mode.test.ts +123 -15
  891. package/src/resources/extensions/ollama/ollama-status-indicator.test.ts +206 -19
  892. package/src/resources/extensions/remote-questions/manager.ts +36 -4
  893. package/src/resources/extensions/remote-questions/tests/command-polling.test.ts +200 -190
  894. package/src/resources/extensions/shared/cmux-events.ts +59 -0
  895. package/src/resources/extensions/shared/rtk-session-stats.ts +1 -2
  896. package/src/resources/extensions/shared/tests/interview-preview.test.ts +11 -3
  897. package/src/resources/extensions/voice/tests/linux-ready.test.ts +129 -113
  898. package/src/resources/skills/create-skill/SKILL.md +2 -2
  899. package/src/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  900. package/src/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  901. package/src/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  902. package/src/resources/skills/verify-before-complete/SKILL.md +2 -1
  903. package/src/resources/skills/write-docs/SKILL.md +2 -1
  904. package/dist/web/standalone/.next/server/chunks/7461.js +0 -1
  905. package/dist/web/standalone/.next/static/chunks/2826.e59e8578e2e28639.js +0 -9
  906. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts +0 -2
  907. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts.map +0 -1
  908. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js +0 -289
  909. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js.map +0 -1
  910. package/packages/pi-ai/src/utils/oauth/oauth-providers.test.ts +0 -363
  911. package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +0 -143
  912. package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +0 -142
  913. package/src/resources/extensions/gsd/tests/dashboard-model-label-ordering.test.ts +0 -107
  914. package/src/resources/extensions/gsd/tests/find-missing-summaries-closed.test.ts +0 -48
  915. package/src/resources/extensions/gsd/tests/forensics-context-persist.test.ts +0 -159
  916. package/src/resources/extensions/gsd/tests/forensics-db-completion.test.ts +0 -96
  917. package/src/resources/extensions/gsd/tests/forensics-dedup.test.ts +0 -79
  918. package/src/resources/extensions/gsd/tests/forensics-hook-key-parse.test.ts +0 -74
  919. package/src/resources/extensions/gsd/tests/forensics-journal.test.ts +0 -162
  920. package/src/resources/extensions/gsd/tests/gitignore-bg-shell.test.ts +0 -38
  921. package/src/resources/extensions/gsd/tests/gsd-no-project-error.test.ts +0 -73
  922. package/src/resources/extensions/gsd/tests/idle-watchdog-stall-override.test.ts +0 -125
  923. package/src/resources/extensions/gsd/tests/import-done-milestones.test.ts +0 -42
  924. /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → MdwvuQQLlBY6wwiSO1Tgv}/_buildManifest.js +0 -0
  925. /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → MdwvuQQLlBY6wwiSO1Tgv}/_ssgManifest.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"anthropic.js","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"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","sourcesContent":["// Lazy-loaded: Anthropic SDK (~500ms) is imported on first use, not at startup.\n// This avoids penalizing users who don't use Anthropic models.\nimport type Anthropic from \"@anthropic-ai/sdk\";\nimport { getEnvApiKey } from \"../env-api-keys.js\";\nimport type {\n\tContext,\n\tModel,\n\tSimpleStreamOptions,\n\tStreamFunction,\n} from \"../types.js\";\nimport { AssistantMessageEventStream } from \"../utils/event-stream.js\";\n\nimport { buildCopilotDynamicHeaders, hasCopilotVisionInput } from \"./github-copilot-headers.js\";\nimport { adjustMaxTokensForThinking, buildBaseOptions } from \"./simple-options.js\";\nimport {\n\ttype AnthropicEffort,\n\ttype AnthropicOptions,\n\textractRetryAfterMs,\n\tmapThinkingLevelToEffort,\n\tprocessAnthropicStream,\n\tsupportsAdaptiveThinking,\n} from \"./anthropic-shared.js\";\n\n// Re-export types used by other modules\nexport type { AnthropicEffort, AnthropicOptions };\nexport { extractRetryAfterMs };\n\n/**\n * Resolve the base URL for Anthropic API requests.\n *\n * Resolution order:\n * 1. ANTHROPIC_BASE_URL environment variable (if set and non-empty after trim)\n * 2. model.baseUrl (from the model definition)\n *\n * This allows routing traffic through custom proxy endpoints (e.g. OpusMax,\n * local mirrors, corporate gateways) without modifying model definitions.\n */\nexport function resolveAnthropicBaseUrl(model: Model<\"anthropic-messages\">): string {\n\tconst envBaseUrl = process.env.ANTHROPIC_BASE_URL?.trim();\n\tif (envBaseUrl) {\n\t\treturn envBaseUrl;\n\t}\n\treturn model.baseUrl;\n}\n\nlet _AnthropicClass: typeof Anthropic | undefined;\nasync function getAnthropicClass(): Promise<typeof Anthropic> {\n\tif (!_AnthropicClass) {\n\t\tconst mod = await import(\"@anthropic-ai/sdk\");\n\t\t_AnthropicClass = mod.default;\n\t}\n\treturn _AnthropicClass;\n}\n\nfunction mergeHeaders(...headerSources: (Record<string, string> | undefined)[]): Record<string, string> {\n\tconst merged: Record<string, string> = {};\n\tfor (const headers of headerSources) {\n\t\tif (headers) {\n\t\t\tObject.assign(merged, headers);\n\t\t}\n\t}\n\treturn merged;\n}\n\nexport function usesAnthropicBearerAuth(provider: Model<\"anthropic-messages\">[\"provider\"]): boolean {\n\treturn provider === \"alibaba-coding-plan\" || provider === \"minimax\" || provider === \"minimax-cn\";\n}\n\nfunction hasBearerAuthorizationHeader(model: Model<\"anthropic-messages\">): boolean {\n\tconst authHeader = model.headers?.Authorization ?? model.headers?.authorization;\n\treturn typeof authHeader === \"string\" && authHeader.trim().toLowerCase().startsWith(\"bearer \");\n}\n\nasync function createClient(\n\tmodel: Model<\"anthropic-messages\">,\n\tapiKey: string,\n\tinterleavedThinking: boolean,\n\toptionsHeaders?: Record<string, string>,\n\tdynamicHeaders?: Record<string, string>,\n): Promise<{ client: Anthropic; isOAuthToken: boolean }> {\n\tconst AnthropicClass = await getAnthropicClass();\n\t// Adaptive thinking models (Opus 4.6, Sonnet 4.6) have interleaved thinking built-in.\n\t// The beta header is deprecated on Opus 4.6 and redundant on Sonnet 4.6, so skip it.\n\tconst needsInterleavedBeta = interleavedThinking && !supportsAdaptiveThinking(model.id);\n\n\t// Copilot: Bearer auth, selective betas (no fine-grained-tool-streaming)\n\tif (model.provider === \"github-copilot\") {\n\t\tconst betaFeatures: string[] = [];\n\t\tif (needsInterleavedBeta) {\n\t\t\tbetaFeatures.push(\"interleaved-thinking-2025-05-14\");\n\t\t}\n\n\t\tconst client = new AnthropicClass({\n\t\t\tapiKey: null,\n\t\t\tauthToken: apiKey,\n\t\t\tbaseURL: resolveAnthropicBaseUrl(model),\n\t\t\tdangerouslyAllowBrowser: true,\n\t\t\tdefaultHeaders: mergeHeaders(\n\t\t\t\t{\n\t\t\t\t\taccept: \"application/json\",\n\t\t\t\t\t\"anthropic-dangerous-direct-browser-access\": \"true\",\n\t\t\t\t\t...(betaFeatures.length > 0 ? { \"anthropic-beta\": betaFeatures.join(\",\") } : {}),\n\t\t\t\t},\n\t\t\t\tmodel.headers,\n\t\t\t\tdynamicHeaders,\n\t\t\t\toptionsHeaders,\n\t\t\t),\n\t\t});\n\n\t\treturn { client, isOAuthToken: false };\n\t}\n\n\t// Skip beta headers for providers that don't support them (e.g., Alibaba Coding Plan)\n\tconst skipBetaHeaders = model.provider === \"alibaba-coding-plan\";\n\tconst betaFeatures = skipBetaHeaders ? [] : [\"fine-grained-tool-streaming-2025-05-14\"];\n\tif (needsInterleavedBeta && !skipBetaHeaders) {\n\t\tbetaFeatures.push(\"interleaved-thinking-2025-05-14\");\n\t}\n\n\t// API key auth (Anthropic OAuth removed per TOS compliance — use API keys or Claude CLI)\n\t// Some Anthropic-compatible providers require Bearer auth instead of x-api-key.\n\tconst usesBearerAuth = usesAnthropicBearerAuth(model.provider) || hasBearerAuthorizationHeader(model);\n\tconst client = new AnthropicClass({\n\t\tapiKey: usesBearerAuth ? null : apiKey,\n\t\tauthToken: usesBearerAuth ? apiKey : undefined,\n\t\tbaseURL: model.baseUrl,\n\t\tdangerouslyAllowBrowser: true,\n\t\tdefaultHeaders: mergeHeaders(\n\t\t\t{\n\t\t\t\taccept: \"application/json\",\n\t\t\t\t\"anthropic-dangerous-direct-browser-access\": \"true\",\n\t\t\t\t...(betaFeatures.length > 0 ? { \"anthropic-beta\": betaFeatures.join(\",\") } : {}),\n\t\t\t},\n\t\t\tmodel.headers,\n\t\t\toptionsHeaders,\n\t\t),\n\t});\n\n\treturn { client, isOAuthToken: false };\n}\n\nexport const streamAnthropic: StreamFunction<\"anthropic-messages\", AnthropicOptions> = (\n\tmodel: Model<\"anthropic-messages\">,\n\tcontext: Context,\n\toptions?: AnthropicOptions,\n): AssistantMessageEventStream => {\n\tconst stream = new AssistantMessageEventStream();\n\n\t(async () => {\n\t\tconst apiKey = options?.apiKey ?? getEnvApiKey(model.provider) ?? \"\";\n\n\t\tlet copilotDynamicHeaders: Record<string, string> | undefined;\n\t\tif (model.provider === \"github-copilot\") {\n\t\t\tconst hasImages = hasCopilotVisionInput(context.messages);\n\t\t\tcopilotDynamicHeaders = buildCopilotDynamicHeaders({\n\t\t\t\tmessages: context.messages,\n\t\t\t\thasImages,\n\t\t\t});\n\t\t}\n\n\t\tconst { client, isOAuthToken: isOAuth } = await createClient(\n\t\t\tmodel,\n\t\t\tapiKey,\n\t\t\toptions?.interleavedThinking ?? true,\n\t\t\toptions?.headers,\n\t\t\tcopilotDynamicHeaders,\n\t\t);\n\n\t\tprocessAnthropicStream(stream, {\n\t\t\tclient,\n\t\t\tmodel,\n\t\t\tcontext,\n\t\t\tisOAuthToken: isOAuth,\n\t\t\toptions,\n\t\t\tAnthropicSdkClass: _AnthropicClass,\n\t\t});\n\t})();\n\n\treturn stream;\n};\n\nexport const streamSimpleAnthropic: StreamFunction<\"anthropic-messages\", SimpleStreamOptions> = (\n\tmodel: Model<\"anthropic-messages\">,\n\tcontext: Context,\n\toptions?: SimpleStreamOptions,\n): AssistantMessageEventStream => {\n\tconst apiKey = options?.apiKey || getEnvApiKey(model.provider);\n\tif (!apiKey) {\n\t\tthrow new Error(`No API key for provider: ${model.provider}`);\n\t}\n\n\tconst base = buildBaseOptions(model, options, apiKey);\n\tif (!options?.reasoning) {\n\t\treturn streamAnthropic(model, context, { ...base, thinkingEnabled: false } satisfies AnthropicOptions);\n\t}\n\n\t// For Opus 4.6 and Sonnet 4.6: use adaptive thinking with effort level\n\t// For older models: use budget-based thinking\n\tif (supportsAdaptiveThinking(model.id)) {\n\t\tconst effort = mapThinkingLevelToEffort(options.reasoning, model.id);\n\t\treturn streamAnthropic(model, context, {\n\t\t\t...base,\n\t\t\tthinkingEnabled: true,\n\t\t\teffort,\n\t\t} satisfies AnthropicOptions);\n\t}\n\n\tconst adjusted = adjustMaxTokensForThinking(\n\t\tbase.maxTokens || 0,\n\t\tmodel.maxTokens,\n\t\toptions.reasoning,\n\t\toptions.thinkingBudgets,\n\t);\n\n\treturn streamAnthropic(model, context, {\n\t\t...base,\n\t\tmaxTokens: adjusted.maxTokens,\n\t\tthinkingEnabled: true,\n\t\tthinkingBudgetTokens: adjusted.thinkingBudget,\n\t} satisfies AnthropicOptions);\n};\n"]}
1
+ {"version":3,"file":"anthropic.js","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"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","sourcesContent":["// Lazy-loaded: Anthropic SDK (~500ms) is imported on first use, not at startup.\n// This avoids penalizing users who don't use Anthropic models.\nimport type Anthropic from \"@anthropic-ai/sdk\";\nimport { getEnvApiKey } from \"../env-api-keys.js\";\nimport type {\n\tContext,\n\tModel,\n\tSimpleStreamOptions,\n\tStreamFunction,\n} from \"../types.js\";\nimport { AssistantMessageEventStream } from \"../utils/event-stream.js\";\n\nimport { buildCopilotDynamicHeaders, hasCopilotVisionInput } from \"./github-copilot-headers.js\";\nimport { adjustMaxTokensForThinking, buildBaseOptions } from \"./simple-options.js\";\nimport {\n\ttype AnthropicEffort,\n\ttype AnthropicOptions,\n\textractRetryAfterMs,\n\tmapThinkingLevelToEffort,\n\tprocessAnthropicStream,\n\tsupportsAdaptiveThinking,\n} from \"./anthropic-shared.js\";\n\n// Re-export types used by other modules\nexport type { AnthropicEffort, AnthropicOptions };\nexport { extractRetryAfterMs };\n\n/**\n * Resolve the base URL for Anthropic API requests.\n *\n * Resolution order:\n * 1. ANTHROPIC_BASE_URL environment variable (if set and non-empty after trim)\n * 2. model.baseUrl (from the model definition)\n *\n * This allows routing traffic through custom proxy endpoints (e.g. OpusMax,\n * local mirrors, corporate gateways) without modifying model definitions.\n */\nexport function resolveAnthropicBaseUrl(model: Model<\"anthropic-messages\">): string {\n\tconst envBaseUrl = process.env.ANTHROPIC_BASE_URL?.trim();\n\tif (envBaseUrl) {\n\t\treturn envBaseUrl;\n\t}\n\treturn model.baseUrl;\n}\n\nlet _AnthropicClass: typeof Anthropic | undefined;\nasync function getAnthropicClass(): Promise<typeof Anthropic> {\n\tif (!_AnthropicClass) {\n\t\tconst mod = await import(\"@anthropic-ai/sdk\");\n\t\t_AnthropicClass = mod.default;\n\t}\n\treturn _AnthropicClass;\n}\n\nfunction mergeHeaders(...headerSources: (Record<string, string> | undefined)[]): Record<string, string> {\n\tconst merged: Record<string, string> = {};\n\tfor (const headers of headerSources) {\n\t\tif (headers) {\n\t\t\tObject.assign(merged, headers);\n\t\t}\n\t}\n\treturn merged;\n}\n\nexport function usesAnthropicBearerAuth(provider: Model<\"anthropic-messages\">[\"provider\"]): boolean {\n\treturn provider === \"alibaba-coding-plan\" || provider === \"minimax\" || provider === \"minimax-cn\";\n}\n\nfunction hasBearerAuthorizationHeader(model: Model<\"anthropic-messages\">): boolean {\n\tconst authHeader = model.headers?.Authorization ?? model.headers?.authorization;\n\treturn typeof authHeader === \"string\" && authHeader.trim().toLowerCase().startsWith(\"bearer \");\n}\n\nasync function createClient(\n\tmodel: Model<\"anthropic-messages\">,\n\tapiKey: string,\n\tinterleavedThinking: boolean,\n\toptionsHeaders?: Record<string, string>,\n\tdynamicHeaders?: Record<string, string>,\n): Promise<{ client: Anthropic; isOAuthToken: boolean }> {\n\tconst AnthropicClass = await getAnthropicClass();\n\t// Adaptive thinking models (Opus 4.6, Sonnet 4.6) have interleaved thinking built-in.\n\t// The beta header is deprecated on Opus 4.6 and redundant on Sonnet 4.6, so skip it.\n\tconst needsInterleavedBeta = interleavedThinking && !supportsAdaptiveThinking(model.id);\n\n\t// Copilot: Bearer auth, selective betas (no fine-grained-tool-streaming)\n\tif (model.provider === \"github-copilot\") {\n\t\tconst betaFeatures: string[] = [];\n\t\tif (needsInterleavedBeta) {\n\t\t\tbetaFeatures.push(\"interleaved-thinking-2025-05-14\");\n\t\t}\n\n\t\tconst client = new AnthropicClass({\n\t\t\tapiKey: null,\n\t\t\tauthToken: apiKey,\n\t\t\tbaseURL: resolveAnthropicBaseUrl(model),\n\t\t\tdangerouslyAllowBrowser: true,\n\t\t\tdefaultHeaders: mergeHeaders(\n\t\t\t\t{\n\t\t\t\t\taccept: \"application/json\",\n\t\t\t\t\t\"anthropic-dangerous-direct-browser-access\": \"true\",\n\t\t\t\t\t...(betaFeatures.length > 0 ? { \"anthropic-beta\": betaFeatures.join(\",\") } : {}),\n\t\t\t\t},\n\t\t\t\tmodel.headers,\n\t\t\t\tdynamicHeaders,\n\t\t\t\toptionsHeaders,\n\t\t\t),\n\t\t});\n\n\t\treturn { client, isOAuthToken: false };\n\t}\n\n\t// Skip beta headers for providers that don't support fine-grained-tool-streaming.\n\t// MiniMax and minimax-cn implement the beta by emitting empty tool names in\n\t// content_block_start (name arrives as a delta instead), which corrupts conversation\n\t// history and triggers MiniMax error 2013 on the next request (#4538).\n\tconst skipBetaHeaders =\n\t\tmodel.provider === \"alibaba-coding-plan\" ||\n\t\tmodel.provider === \"minimax\" ||\n\t\tmodel.provider === \"minimax-cn\";\n\tconst betaFeatures = skipBetaHeaders ? [] : [\"fine-grained-tool-streaming-2025-05-14\"];\n\tif (needsInterleavedBeta && !skipBetaHeaders) {\n\t\tbetaFeatures.push(\"interleaved-thinking-2025-05-14\");\n\t}\n\n\t// API key auth (Anthropic OAuth removed per TOS compliance — use API keys or Claude CLI)\n\t// Some Anthropic-compatible providers require Bearer auth instead of x-api-key.\n\tconst usesBearerAuth = usesAnthropicBearerAuth(model.provider) || hasBearerAuthorizationHeader(model);\n\tconst client = new AnthropicClass({\n\t\tapiKey: usesBearerAuth ? null : apiKey,\n\t\tauthToken: usesBearerAuth ? apiKey : undefined,\n\t\tbaseURL: resolveAnthropicBaseUrl(model),\n\t\tdangerouslyAllowBrowser: true,\n\t\tdefaultHeaders: mergeHeaders(\n\t\t\t{\n\t\t\t\taccept: \"application/json\",\n\t\t\t\t\"anthropic-dangerous-direct-browser-access\": \"true\",\n\t\t\t\t...(betaFeatures.length > 0 ? { \"anthropic-beta\": betaFeatures.join(\",\") } : {}),\n\t\t\t},\n\t\t\tmodel.headers,\n\t\t\toptionsHeaders,\n\t\t),\n\t});\n\n\treturn { client, isOAuthToken: false };\n}\n\nexport const streamAnthropic: StreamFunction<\"anthropic-messages\", AnthropicOptions> = (\n\tmodel: Model<\"anthropic-messages\">,\n\tcontext: Context,\n\toptions?: AnthropicOptions,\n): AssistantMessageEventStream => {\n\tconst stream = new AssistantMessageEventStream();\n\n\t(async () => {\n\t\tconst apiKey = options?.apiKey ?? getEnvApiKey(model.provider) ?? \"\";\n\n\t\tlet copilotDynamicHeaders: Record<string, string> | undefined;\n\t\tif (model.provider === \"github-copilot\") {\n\t\t\tconst hasImages = hasCopilotVisionInput(context.messages);\n\t\t\tcopilotDynamicHeaders = buildCopilotDynamicHeaders({\n\t\t\t\tmessages: context.messages,\n\t\t\t\thasImages,\n\t\t\t});\n\t\t}\n\n\t\tconst { client, isOAuthToken: isOAuth } = await createClient(\n\t\t\tmodel,\n\t\t\tapiKey,\n\t\t\toptions?.interleavedThinking ?? true,\n\t\t\toptions?.headers,\n\t\t\tcopilotDynamicHeaders,\n\t\t);\n\n\t\tprocessAnthropicStream(stream, {\n\t\t\tclient,\n\t\t\tmodel,\n\t\t\tcontext,\n\t\t\tisOAuthToken: isOAuth,\n\t\t\toptions,\n\t\t\tAnthropicSdkClass: _AnthropicClass,\n\t\t});\n\t})();\n\n\treturn stream;\n};\n\nexport const streamSimpleAnthropic: StreamFunction<\"anthropic-messages\", SimpleStreamOptions> = (\n\tmodel: Model<\"anthropic-messages\">,\n\tcontext: Context,\n\toptions?: SimpleStreamOptions,\n): AssistantMessageEventStream => {\n\tconst apiKey = options?.apiKey || getEnvApiKey(model.provider);\n\tif (!apiKey) {\n\t\tthrow new Error(`No API key for provider: ${model.provider}`);\n\t}\n\n\tconst base = buildBaseOptions(model, options, apiKey);\n\tif (!options?.reasoning) {\n\t\treturn streamAnthropic(model, context, { ...base, thinkingEnabled: false } satisfies AnthropicOptions);\n\t}\n\n\t// For Opus 4.6 and Sonnet 4.6: use adaptive thinking with effort level\n\t// For older models: use budget-based thinking\n\tif (supportsAdaptiveThinking(model.id)) {\n\t\tconst effort = mapThinkingLevelToEffort(options.reasoning, model.id);\n\t\treturn streamAnthropic(model, context, {\n\t\t\t...base,\n\t\t\tthinkingEnabled: true,\n\t\t\teffort,\n\t\t} satisfies AnthropicOptions);\n\t}\n\n\tconst adjusted = adjustMaxTokensForThinking(\n\t\tbase.maxTokens || 0,\n\t\tmodel.maxTokens,\n\t\toptions.reasoning,\n\t\toptions.thinkingBudgets,\n\t);\n\n\treturn streamAnthropic(model, context, {\n\t\t...base,\n\t\tmaxTokens: adjusted.maxTokens,\n\t\tthinkingEnabled: true,\n\t\tthinkingBudgetTokens: adjusted.thinkingBudget,\n\t} satisfies AnthropicOptions);\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=minimax-tool-name.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"minimax-tool-name.test.d.ts","sourceRoot":"","sources":["../../src/providers/minimax-tool-name.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,80 @@
1
+ /**
2
+ * Regression tests for MiniMax error 2013 "function name or parameters is empty" (#4538).
3
+ *
4
+ * Root cause: the `fine-grained-tool-streaming-2025-05-14` beta header is sent to
5
+ * MiniMax. MiniMax's Anthropic-compatible API implements this beta by streaming the
6
+ * tool name as a delta (empty string in `content_block_start`). The empty name gets
7
+ * stored in conversation history and sent back on the next request, causing MiniMax
8
+ * to return error 2013.
9
+ *
10
+ * Fix: exclude MiniMax (and minimax-cn) from the fine-grained-tool-streaming beta,
11
+ * same as alibaba-coding-plan. Also guard against storing empty tool names.
12
+ */
13
+ import test, { describe } from "node:test";
14
+ import assert from "node:assert/strict";
15
+ import { readFileSync } from "node:fs";
16
+ import { dirname, join } from "node:path";
17
+ import { fileURLToPath } from "node:url";
18
+ import { convertMessages } from "./anthropic-shared.js";
19
+ const __dirname = dirname(fileURLToPath(import.meta.url));
20
+ const source = readFileSync(join(__dirname, "anthropic.ts"), "utf-8");
21
+ describe("MiniMax fine-grained-tool-streaming exclusion (#4538)", () => {
22
+ test("minimax is excluded from fine-grained-tool-streaming-2025-05-14 beta", () => {
23
+ // The skipBetaHeaders flag must include minimax so it never receives the
24
+ // fine-grained-tool-streaming beta that causes empty tool names.
25
+ assert.match(source, /skipBetaHeaders.*minimax/s, "minimax must be included in skipBetaHeaders to suppress fine-grained-tool-streaming");
26
+ });
27
+ test("minimax-cn is excluded from fine-grained-tool-streaming-2025-05-14 beta", () => {
28
+ assert.match(source, /skipBetaHeaders.*minimax-cn/s, "minimax-cn must be included in skipBetaHeaders to suppress fine-grained-tool-streaming");
29
+ });
30
+ });
31
+ describe("empty tool name guard in convertMessages (#4538)", () => {
32
+ // When fine-grained-tool-streaming causes a tool name to arrive as empty in
33
+ // content_block_start, we must not store '' in conversation history.
34
+ // convertMessages must skip tool_use blocks with empty/missing names.
35
+ const minimaxModel = {
36
+ id: "MiniMax-M2",
37
+ api: "anthropic-messages",
38
+ provider: "minimax",
39
+ baseUrl: "https://api.minimax.io/anthropic",
40
+ reasoning: true,
41
+ input: ["text"],
42
+ name: "MiniMax-M2",
43
+ cost: { input: 0.3, output: 1.2, cacheRead: 0, cacheWrite: 0 },
44
+ contextWindow: 196608,
45
+ maxTokens: 128000,
46
+ };
47
+ test("tool_use blocks with empty name are dropped from converted messages", () => {
48
+ const assistantMsg = {
49
+ role: "assistant",
50
+ content: [
51
+ {
52
+ type: "toolCall",
53
+ id: "toolu_01",
54
+ name: "", // empty — the bug: fine-grained streaming left name as ""
55
+ arguments: { path: "/foo" },
56
+ },
57
+ ],
58
+ api: "anthropic-messages",
59
+ provider: "minimax",
60
+ model: "MiniMax-M2",
61
+ usage: { input: 1, output: 1, cacheRead: 0, cacheWrite: 0, totalTokens: 2, cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 } },
62
+ stopReason: "toolUse",
63
+ timestamp: Date.now(),
64
+ };
65
+ const messages = [assistantMsg];
66
+ const result = convertMessages(messages, minimaxModel, false, undefined);
67
+ // The assistant block with the empty-name toolCall must not appear in the output.
68
+ // If it does appear, its tool_use name must not be empty.
69
+ for (const param of result) {
70
+ if (param.role === "assistant" && Array.isArray(param.content)) {
71
+ for (const block of param.content) {
72
+ if (block.type === "tool_use") {
73
+ assert.ok(block.name && block.name.length > 0, `tool_use block must never have an empty name; got: "${block.name}"`);
74
+ }
75
+ }
76
+ }
77
+ }
78
+ });
79
+ });
80
+ //# sourceMappingURL=minimax-tool-name.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"minimax-tool-name.test.js","sourceRoot":"","sources":["../../src/providers/minimax-tool-name.test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Regression tests for MiniMax error 2013 \"function name or parameters is empty\" (#4538).\n *\n * Root cause: the `fine-grained-tool-streaming-2025-05-14` beta header is sent to\n * MiniMax. MiniMax's Anthropic-compatible API implements this beta by streaming the\n * tool name as a delta (empty string in `content_block_start`). The empty name gets\n * stored in conversation history and sent back on the next request, causing MiniMax\n * to return error 2013.\n *\n * Fix: exclude MiniMax (and minimax-cn) from the fine-grained-tool-streaming beta,\n * same as alibaba-coding-plan. Also guard against storing empty tool names.\n */\nimport test, { describe } from \"node:test\";\nimport assert from \"node:assert/strict\";\nimport { readFileSync } from \"node:fs\";\nimport { dirname, join } from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport { convertMessages } from \"./anthropic-shared.js\";\nimport type { AssistantMessage } from \"../types.js\";\n\nconst __dirname = dirname(fileURLToPath(import.meta.url));\nconst source = readFileSync(join(__dirname, \"anthropic.ts\"), \"utf-8\");\n\ndescribe(\"MiniMax fine-grained-tool-streaming exclusion (#4538)\", () => {\n\ttest(\"minimax is excluded from fine-grained-tool-streaming-2025-05-14 beta\", () => {\n\t\t// The skipBetaHeaders flag must include minimax so it never receives the\n\t\t// fine-grained-tool-streaming beta that causes empty tool names.\n\t\tassert.match(\n\t\t\tsource,\n\t\t\t/skipBetaHeaders.*minimax/s,\n\t\t\t\"minimax must be included in skipBetaHeaders to suppress fine-grained-tool-streaming\",\n\t\t);\n\t});\n\n\ttest(\"minimax-cn is excluded from fine-grained-tool-streaming-2025-05-14 beta\", () => {\n\t\tassert.match(\n\t\t\tsource,\n\t\t\t/skipBetaHeaders.*minimax-cn/s,\n\t\t\t\"minimax-cn must be included in skipBetaHeaders to suppress fine-grained-tool-streaming\",\n\t\t);\n\t});\n});\n\ndescribe(\"empty tool name guard in convertMessages (#4538)\", () => {\n\t// When fine-grained-tool-streaming causes a tool name to arrive as empty in\n\t// content_block_start, we must not store '' in conversation history.\n\t// convertMessages must skip tool_use blocks with empty/missing names.\n\tconst minimaxModel = {\n\t\tid: \"MiniMax-M2\",\n\t\tapi: \"anthropic-messages\" as const,\n\t\tprovider: \"minimax\" as const,\n\t\tbaseUrl: \"https://api.minimax.io/anthropic\",\n\t\treasoning: true,\n\t\tinput: [\"text\"] as [\"text\"],\n\t\tname: \"MiniMax-M2\",\n\t\tcost: { input: 0.3, output: 1.2, cacheRead: 0, cacheWrite: 0 },\n\t\tcontextWindow: 196608,\n\t\tmaxTokens: 128000,\n\t};\n\n\ttest(\"tool_use blocks with empty name are dropped from converted messages\", () => {\n\t\tconst assistantMsg: AssistantMessage = {\n\t\t\trole: \"assistant\",\n\t\t\tcontent: [\n\t\t\t\t{\n\t\t\t\t\ttype: \"toolCall\",\n\t\t\t\t\tid: \"toolu_01\",\n\t\t\t\t\tname: \"\", // empty — the bug: fine-grained streaming left name as \"\"\n\t\t\t\t\targuments: { path: \"/foo\" },\n\t\t\t\t},\n\t\t\t],\n\t\t\tapi: \"anthropic-messages\",\n\t\t\tprovider: \"minimax\",\n\t\t\tmodel: \"MiniMax-M2\",\n\t\t\tusage: { input: 1, output: 1, cacheRead: 0, cacheWrite: 0, totalTokens: 2, cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 } },\n\t\t\tstopReason: \"toolUse\",\n\t\t\ttimestamp: Date.now(),\n\t\t};\n\n\t\tconst messages = [assistantMsg];\n\t\tconst result = convertMessages(messages, minimaxModel, false, undefined);\n\n\t\t// The assistant block with the empty-name toolCall must not appear in the output.\n\t\t// If it does appear, its tool_use name must not be empty.\n\t\tfor (const param of result) {\n\t\t\tif (param.role === \"assistant\" && Array.isArray(param.content)) {\n\t\t\t\tfor (const block of param.content) {\n\t\t\t\t\tif ((block as any).type === \"tool_use\") {\n\t\t\t\t\t\tassert.ok(\n\t\t\t\t\t\t\t(block as any).name && (block as any).name.length > 0,\n\t\t\t\t\t\t\t`tool_use block must never have an empty name; got: \"${(block as any).name}\"`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n});\n"]}
@@ -1,4 +1,14 @@
1
1
  import type { Api, Model, SimpleStreamOptions, StreamOptions, ThinkingBudgets, ThinkingLevel } from "../types.js";
2
+ /**
3
+ * Compute the default maxTokens for a model when no explicit value is provided.
4
+ *
5
+ * The 32 k cap is retained only for native Anthropic models (api === "anthropic-messages")
6
+ * where the Anthropic API historically rejected higher values. Custom and
7
+ * Anthropic-compatible models (e.g. OpenAI-completions, Vertex, etc.) use their
8
+ * declared model.maxTokens directly so that providers with larger output windows
9
+ * (131 072 tokens, etc.) are not silently capped.
10
+ */
11
+ export declare function defaultMaxTokens(model: Model<Api>): number;
2
12
  export declare function buildBaseOptions(model: Model<Api>, options?: SimpleStreamOptions, apiKey?: string): StreamOptions;
3
13
  export declare function clampReasoning(effort: ThinkingLevel | undefined): Exclude<ThinkingLevel, "xhigh"> | undefined;
4
14
  export declare function adjustMaxTokensForThinking(baseMaxTokens: number, modelMaxTokens: number, reasoningLevel: ThinkingLevel, customBudgets?: ThinkingBudgets): {
@@ -1 +1 @@
1
- {"version":3,"file":"simple-options.d.ts","sourceRoot":"","sources":["../../src/providers/simple-options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAElH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,EAAE,mBAAmB,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,aAAa,CAajH;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,aAAa,GAAG,SAAS,GAAG,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,GAAG,SAAS,CAE7G;AAED,wBAAgB,0BAA0B,CACzC,aAAa,EAAE,MAAM,EACrB,cAAc,EAAE,MAAM,EACtB,cAAc,EAAE,aAAa,EAC7B,aAAa,CAAC,EAAE,eAAe,GAC7B;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,cAAc,EAAE,MAAM,CAAA;CAAE,CAmB/C"}
1
+ {"version":3,"file":"simple-options.d.ts","sourceRoot":"","sources":["../../src/providers/simple-options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAElH;;;;;;;;GAQG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,MAAM,CAK1D;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,EAAE,mBAAmB,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,aAAa,CAajH;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,aAAa,GAAG,SAAS,GAAG,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,GAAG,SAAS,CAE7G;AAED,wBAAgB,0BAA0B,CACzC,aAAa,EAAE,MAAM,EACrB,cAAc,EAAE,MAAM,EACtB,cAAc,EAAE,aAAa,EAC7B,aAAa,CAAC,EAAE,eAAe,GAC7B;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,cAAc,EAAE,MAAM,CAAA;CAAE,CAmB/C"}
@@ -1,7 +1,22 @@
1
+ /**
2
+ * Compute the default maxTokens for a model when no explicit value is provided.
3
+ *
4
+ * The 32 k cap is retained only for native Anthropic models (api === "anthropic-messages")
5
+ * where the Anthropic API historically rejected higher values. Custom and
6
+ * Anthropic-compatible models (e.g. OpenAI-completions, Vertex, etc.) use their
7
+ * declared model.maxTokens directly so that providers with larger output windows
8
+ * (131 072 tokens, etc.) are not silently capped.
9
+ */
10
+ export function defaultMaxTokens(model) {
11
+ if (model.api === "anthropic-messages") {
12
+ return Math.min(model.maxTokens, 32000);
13
+ }
14
+ return model.maxTokens;
15
+ }
1
16
  export function buildBaseOptions(model, options, apiKey) {
2
17
  return {
3
18
  temperature: options?.temperature,
4
- maxTokens: options?.maxTokens || Math.min(model.maxTokens, 32000),
19
+ maxTokens: options?.maxTokens || defaultMaxTokens(model),
5
20
  signal: options?.signal,
6
21
  apiKey: apiKey || options?.apiKey,
7
22
  cacheRetention: options?.cacheRetention,
@@ -1 +1 @@
1
- {"version":3,"file":"simple-options.js","sourceRoot":"","sources":["../../src/providers/simple-options.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,gBAAgB,CAAC,KAAiB,EAAE,OAA6B,EAAE,MAAe;IACjG,OAAO;QACN,WAAW,EAAE,OAAO,EAAE,WAAW;QACjC,SAAS,EAAE,OAAO,EAAE,SAAS,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC;QACjE,MAAM,EAAE,OAAO,EAAE,MAAM;QACvB,MAAM,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM;QACjC,cAAc,EAAE,OAAO,EAAE,cAAc;QACvC,SAAS,EAAE,OAAO,EAAE,SAAS;QAC7B,OAAO,EAAE,OAAO,EAAE,OAAO;QACzB,SAAS,EAAE,OAAO,EAAE,SAAS;QAC7B,eAAe,EAAE,OAAO,EAAE,eAAe;QACzC,QAAQ,EAAE,OAAO,EAAE,QAAQ;KAC3B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,MAAiC;IAC/D,OAAO,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,0BAA0B,CACzC,aAAqB,EACrB,cAAsB,EACtB,cAA6B,EAC7B,aAA+B;IAE/B,MAAM,cAAc,GAAoB;QACvC,OAAO,EAAE,IAAI;QACb,GAAG,EAAE,IAAI;QACT,MAAM,EAAE,IAAI;QACZ,IAAI,EAAE,KAAK;KACX,CAAC;IACF,MAAM,OAAO,GAAG,EAAE,GAAG,cAAc,EAAE,GAAG,aAAa,EAAE,CAAC;IAExD,MAAM,eAAe,GAAG,IAAI,CAAC;IAC7B,MAAM,KAAK,GAAG,cAAc,CAAC,cAAc,CAAE,CAAC;IAC9C,IAAI,cAAc,GAAG,OAAO,CAAC,KAAK,CAAE,CAAC;IACrC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,GAAG,cAAc,EAAE,cAAc,CAAC,CAAC;IAE3E,IAAI,SAAS,IAAI,cAAc,EAAE,CAAC;QACjC,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,GAAG,eAAe,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC;AACtC,CAAC","sourcesContent":["import type { Api, Model, SimpleStreamOptions, StreamOptions, ThinkingBudgets, ThinkingLevel } from \"../types.js\";\n\nexport function buildBaseOptions(model: Model<Api>, options?: SimpleStreamOptions, apiKey?: string): StreamOptions {\n\treturn {\n\t\ttemperature: options?.temperature,\n\t\tmaxTokens: options?.maxTokens || Math.min(model.maxTokens, 32000),\n\t\tsignal: options?.signal,\n\t\tapiKey: apiKey || options?.apiKey,\n\t\tcacheRetention: options?.cacheRetention,\n\t\tsessionId: options?.sessionId,\n\t\theaders: options?.headers,\n\t\tonPayload: options?.onPayload,\n\t\tmaxRetryDelayMs: options?.maxRetryDelayMs,\n\t\tmetadata: options?.metadata,\n\t};\n}\n\nexport function clampReasoning(effort: ThinkingLevel | undefined): Exclude<ThinkingLevel, \"xhigh\"> | undefined {\n\treturn effort === \"xhigh\" ? \"high\" : effort;\n}\n\nexport function adjustMaxTokensForThinking(\n\tbaseMaxTokens: number,\n\tmodelMaxTokens: number,\n\treasoningLevel: ThinkingLevel,\n\tcustomBudgets?: ThinkingBudgets,\n): { maxTokens: number; thinkingBudget: number } {\n\tconst defaultBudgets: ThinkingBudgets = {\n\t\tminimal: 1024,\n\t\tlow: 2048,\n\t\tmedium: 8192,\n\t\thigh: 16384,\n\t};\n\tconst budgets = { ...defaultBudgets, ...customBudgets };\n\n\tconst minOutputTokens = 1024;\n\tconst level = clampReasoning(reasoningLevel)!;\n\tlet thinkingBudget = budgets[level]!;\n\tconst maxTokens = Math.min(baseMaxTokens + thinkingBudget, modelMaxTokens);\n\n\tif (maxTokens <= thinkingBudget) {\n\t\tthinkingBudget = Math.max(0, maxTokens - minOutputTokens);\n\t}\n\n\treturn { maxTokens, thinkingBudget };\n}\n"]}
1
+ {"version":3,"file":"simple-options.js","sourceRoot":"","sources":["../../src/providers/simple-options.ts"],"names":[],"mappings":"AAEA;;;;;;;;GAQG;AACH,MAAM,UAAU,gBAAgB,CAAC,KAAiB;IACjD,IAAI,KAAK,CAAC,GAAG,KAAK,oBAAoB,EAAE,CAAC;QACxC,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IACzC,CAAC;IACD,OAAO,KAAK,CAAC,SAAS,CAAC;AACxB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAiB,EAAE,OAA6B,EAAE,MAAe;IACjG,OAAO;QACN,WAAW,EAAE,OAAO,EAAE,WAAW;QACjC,SAAS,EAAE,OAAO,EAAE,SAAS,IAAI,gBAAgB,CAAC,KAAK,CAAC;QACxD,MAAM,EAAE,OAAO,EAAE,MAAM;QACvB,MAAM,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM;QACjC,cAAc,EAAE,OAAO,EAAE,cAAc;QACvC,SAAS,EAAE,OAAO,EAAE,SAAS;QAC7B,OAAO,EAAE,OAAO,EAAE,OAAO;QACzB,SAAS,EAAE,OAAO,EAAE,SAAS;QAC7B,eAAe,EAAE,OAAO,EAAE,eAAe;QACzC,QAAQ,EAAE,OAAO,EAAE,QAAQ;KAC3B,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,MAAiC;IAC/D,OAAO,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,0BAA0B,CACzC,aAAqB,EACrB,cAAsB,EACtB,cAA6B,EAC7B,aAA+B;IAE/B,MAAM,cAAc,GAAoB;QACvC,OAAO,EAAE,IAAI;QACb,GAAG,EAAE,IAAI;QACT,MAAM,EAAE,IAAI;QACZ,IAAI,EAAE,KAAK;KACX,CAAC;IACF,MAAM,OAAO,GAAG,EAAE,GAAG,cAAc,EAAE,GAAG,aAAa,EAAE,CAAC;IAExD,MAAM,eAAe,GAAG,IAAI,CAAC;IAC7B,MAAM,KAAK,GAAG,cAAc,CAAC,cAAc,CAAE,CAAC;IAC9C,IAAI,cAAc,GAAG,OAAO,CAAC,KAAK,CAAE,CAAC;IACrC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,GAAG,cAAc,EAAE,cAAc,CAAC,CAAC;IAE3E,IAAI,SAAS,IAAI,cAAc,EAAE,CAAC;QACjC,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,GAAG,eAAe,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC;AACtC,CAAC","sourcesContent":["import type { Api, Model, SimpleStreamOptions, StreamOptions, ThinkingBudgets, ThinkingLevel } from \"../types.js\";\n\n/**\n * Compute the default maxTokens for a model when no explicit value is provided.\n *\n * The 32 k cap is retained only for native Anthropic models (api === \"anthropic-messages\")\n * where the Anthropic API historically rejected higher values. Custom and\n * Anthropic-compatible models (e.g. OpenAI-completions, Vertex, etc.) use their\n * declared model.maxTokens directly so that providers with larger output windows\n * (131 072 tokens, etc.) are not silently capped.\n */\nexport function defaultMaxTokens(model: Model<Api>): number {\n\tif (model.api === \"anthropic-messages\") {\n\t\treturn Math.min(model.maxTokens, 32000);\n\t}\n\treturn model.maxTokens;\n}\n\nexport function buildBaseOptions(model: Model<Api>, options?: SimpleStreamOptions, apiKey?: string): StreamOptions {\n\treturn {\n\t\ttemperature: options?.temperature,\n\t\tmaxTokens: options?.maxTokens || defaultMaxTokens(model),\n\t\tsignal: options?.signal,\n\t\tapiKey: apiKey || options?.apiKey,\n\t\tcacheRetention: options?.cacheRetention,\n\t\tsessionId: options?.sessionId,\n\t\theaders: options?.headers,\n\t\tonPayload: options?.onPayload,\n\t\tmaxRetryDelayMs: options?.maxRetryDelayMs,\n\t\tmetadata: options?.metadata,\n\t};\n}\n\nexport function clampReasoning(effort: ThinkingLevel | undefined): Exclude<ThinkingLevel, \"xhigh\"> | undefined {\n\treturn effort === \"xhigh\" ? \"high\" : effort;\n}\n\nexport function adjustMaxTokensForThinking(\n\tbaseMaxTokens: number,\n\tmodelMaxTokens: number,\n\treasoningLevel: ThinkingLevel,\n\tcustomBudgets?: ThinkingBudgets,\n): { maxTokens: number; thinkingBudget: number } {\n\tconst defaultBudgets: ThinkingBudgets = {\n\t\tminimal: 1024,\n\t\tlow: 2048,\n\t\tmedium: 8192,\n\t\thigh: 16384,\n\t};\n\tconst budgets = { ...defaultBudgets, ...customBudgets };\n\n\tconst minOutputTokens = 1024;\n\tconst level = clampReasoning(reasoningLevel)!;\n\tlet thinkingBudget = budgets[level]!;\n\tconst maxTokens = Math.min(baseMaxTokens + thinkingBudget, modelMaxTokens);\n\n\tif (maxTokens <= thinkingBudget) {\n\t\tthinkingBudget = Math.max(0, maxTokens - minOutputTokens);\n\t}\n\n\treturn { maxTokens, thinkingBudget };\n}\n"]}
@@ -1,8 +1,13 @@
1
1
  {
2
2
  "name": "@gsd/pi-ai",
3
- "version": "2.76.0",
3
+ "version": "2.77.0",
4
4
  "description": "Unified LLM API (vendored from pi-mono)",
5
5
  "type": "module",
6
+ "gsd": {
7
+ "linkable": true,
8
+ "scope": "@gsd",
9
+ "name": "pi-ai"
10
+ },
6
11
  "main": "./dist/index.js",
7
12
  "types": "./dist/index.d.ts",
8
13
  "exports": {
@@ -707,6 +707,13 @@ async function generateModels() {
707
707
  candidate.contextWindow = 272000;
708
708
  candidate.maxTokens = 128000;
709
709
  }
710
+ if (candidate.provider === "openai" && candidate.id === "gpt-5.5") {
711
+ // GPT-5.5 has a 1M context window.
712
+ // Keep max output aligned with existing GPT-5.x local constraints.
713
+ // Source: https://openai.com/index/introducing-gpt-5-5/
714
+ candidate.contextWindow = 1000000;
715
+ candidate.maxTokens = 128000;
716
+ }
710
717
  // Keep selected OpenRouter model metadata stable until upstream settles.
711
718
  if (candidate.provider === "openrouter" && candidate.id === "moonshotai/kimi-k2.5") {
712
719
  candidate.cost.input = 0.41;
@@ -942,6 +949,27 @@ async function generateModels() {
942
949
  });
943
950
  }
944
951
 
952
+ if (!allModels.some((m) => m.provider === "openai" && m.id === "gpt-5.5")) {
953
+ allModels.push({
954
+ id: "gpt-5.5",
955
+ name: "GPT-5.5",
956
+ api: "openai-responses",
957
+ baseUrl: "https://api.openai.com/v1",
958
+ provider: "openai",
959
+ reasoning: true,
960
+ input: ["text", "image"],
961
+ cost: {
962
+ // Source: https://openai.com/api/pricing/
963
+ input: 5,
964
+ output: 30,
965
+ cacheRead: 0.5,
966
+ cacheWrite: 0,
967
+ },
968
+ contextWindow: 1000000,
969
+ maxTokens: 128000,
970
+ });
971
+ }
972
+
945
973
  // OpenAI Codex (ChatGPT OAuth) models
946
974
  // NOTE: These are not fetched from models.dev; we keep a small, explicit list to avoid aliases.
947
975
  // Context window is based on observed server limits (400s above ~272k), not marketing numbers.
@@ -1033,6 +1061,22 @@ async function generateModels() {
1033
1061
  contextWindow: CODEX_CONTEXT,
1034
1062
  maxTokens: CODEX_MAX_TOKENS,
1035
1063
  },
1064
+ {
1065
+ id: "gpt-5.5",
1066
+ name: "GPT-5.5",
1067
+ api: "openai-codex-responses",
1068
+ provider: "openai-codex",
1069
+ baseUrl: CODEX_BASE_URL,
1070
+ reasoning: true,
1071
+ input: ["text", "image"],
1072
+ // Official GPT-5.5 list price; Codex availability and 400K window are live.
1073
+ // Sources:
1074
+ // - https://openai.com/index/introducing-gpt-5-5/
1075
+ // - https://openai.com/api/pricing/
1076
+ cost: { input: 5, output: 30, cacheRead: 0.5, cacheWrite: 0 },
1077
+ contextWindow: 400000,
1078
+ maxTokens: CODEX_MAX_TOKENS,
1079
+ },
1036
1080
  {
1037
1081
  id: "gpt-5.4-mini",
1038
1082
  name: "GPT-5.4 Mini",
@@ -3,11 +3,19 @@ import type { Api, Model, ModelCapabilities } from "../types.js";
3
3
  type CapabilityPatch = { match: (m: Model<Api>) => boolean; caps: ModelCapabilities };
4
4
 
5
5
  export const CAPABILITY_PATCHES: CapabilityPatch[] = [
6
- // GPT-5.x supports xhigh thinking and OpenAI service tiers
6
+ // GPT-5.2-5.4 support xhigh thinking and OpenAI service tiers
7
7
  {
8
- match: (m) => m.id.includes("gpt-5.2") || m.id.includes("gpt-5.3") || m.id.includes("gpt-5.4"),
8
+ match: (m) =>
9
+ m.id.includes("gpt-5.2") ||
10
+ m.id.includes("gpt-5.3") ||
11
+ m.id.includes("gpt-5.4"),
9
12
  caps: { supportsXhigh: true, supportsServiceTier: true },
10
13
  },
14
+ // GPT-5.5 supports xhigh thinking; service-tier support is gated separately.
15
+ {
16
+ match: (m) => m.id.includes("gpt-5.5"),
17
+ caps: { supportsXhigh: true },
18
+ },
11
19
  // Anthropic Opus 4.6+ supports xhigh thinking
12
20
  {
13
21
  match: (m) => m.api === "anthropic-messages" && (
@@ -292,4 +292,46 @@ export const CUSTOM_MODELS = {
292
292
  compat: { thinkingFormat: "zai", supportsDeveloperRole: false },
293
293
  } satisfies Model<"openai-completions">,
294
294
  },
295
+
296
+ // ─── MiniMax additive hotfixes ───────────────────────────────────────
297
+ // models.dev currently omits MiniMax-M2.1-highspeed in some snapshots.
298
+ // Keep this additive (no overrides) so generated models still win when present.
299
+ "minimax": {
300
+ "MiniMax-M2.1-highspeed": {
301
+ id: "MiniMax-M2.1-highspeed",
302
+ name: "MiniMax-M2.1-highspeed",
303
+ api: "anthropic-messages",
304
+ provider: "minimax",
305
+ baseUrl: "https://api.minimax.io/anthropic",
306
+ reasoning: true,
307
+ input: ["text"],
308
+ cost: {
309
+ input: 0.6,
310
+ output: 2.4,
311
+ cacheRead: 0,
312
+ cacheWrite: 0,
313
+ },
314
+ contextWindow: 204800,
315
+ maxTokens: 131072,
316
+ } satisfies Model<"anthropic-messages">,
317
+ },
318
+ "minimax-cn": {
319
+ "MiniMax-M2.1-highspeed": {
320
+ id: "MiniMax-M2.1-highspeed",
321
+ name: "MiniMax-M2.1-highspeed",
322
+ api: "anthropic-messages",
323
+ provider: "minimax-cn",
324
+ baseUrl: "https://api.minimaxi.com/anthropic",
325
+ reasoning: true,
326
+ input: ["text"],
327
+ cost: {
328
+ input: 0.6,
329
+ output: 2.4,
330
+ cacheRead: 0,
331
+ cacheWrite: 0,
332
+ },
333
+ contextWindow: 204800,
334
+ maxTokens: 131072,
335
+ } satisfies Model<"anthropic-messages">,
336
+ },
295
337
  } as const;
@@ -140,6 +140,23 @@ export const OPENAI_CODEX_MODELS = {
140
140
  contextWindow: 272000,
141
141
  maxTokens: 128000,
142
142
  } satisfies Model<"openai-codex-responses">,
143
+ "gpt-5.5": {
144
+ id: "gpt-5.5",
145
+ name: "GPT-5.5",
146
+ api: "openai-codex-responses",
147
+ provider: "openai-codex",
148
+ baseUrl: "https://chatgpt.com/backend-api",
149
+ reasoning: true,
150
+ input: ["text", "image"],
151
+ cost: {
152
+ input: 5,
153
+ output: 30,
154
+ cacheRead: 0.5,
155
+ cacheWrite: 0,
156
+ },
157
+ contextWindow: 400000,
158
+ maxTokens: 128000,
159
+ } satisfies Model<"openai-codex-responses">,
143
160
  "gpt-5.4-mini": {
144
161
  id: "gpt-5.4-mini",
145
162
  name: "GPT-5.4 Mini",
@@ -514,6 +514,23 @@ export const OPENAI_MODELS = {
514
514
  contextWindow: 272000,
515
515
  maxTokens: 128000,
516
516
  } satisfies Model<"openai-responses">,
517
+ "gpt-5.5": {
518
+ id: "gpt-5.5",
519
+ name: "GPT-5.5",
520
+ api: "openai-responses",
521
+ provider: "openai",
522
+ baseUrl: "https://api.openai.com/v1",
523
+ reasoning: true,
524
+ input: ["text", "image"],
525
+ cost: {
526
+ input: 5,
527
+ output: 30,
528
+ cacheRead: 0.5,
529
+ cacheWrite: 0,
530
+ },
531
+ contextWindow: 1000000,
532
+ maxTokens: 128000,
533
+ } satisfies Model<"openai-responses">,
517
534
  "gpt-5.4-mini": {
518
535
  id: "gpt-5.4-mini",
519
536
  name: "GPT-5.4 mini",
@@ -256,9 +256,15 @@ describe("MODELS structural invariants", () => {
256
256
  // ═══════════════════════════════════════════════════════════════════════════
257
257
 
258
258
  describe("MODELS registry shape", () => {
259
- it("has exactly 23 providers", () => {
259
+ // "exactly 23 providers" and "all 23 expected providers" tests
260
+ // removed (#4804): each hardcoded a snapshot count/list that breaks
261
+ // on every benign provider addition without indicating any real
262
+ // problem. The structural invariants below (non-empty, sanity
263
+ // threshold, getProviders consistency) are the useful guarantees.
264
+
265
+ it("registry is non-empty", () => {
260
266
  const count = Object.keys(MODELS).length;
261
- assert.equal(count, 23, `Expected 23 providers, got ${count}: ${Object.keys(MODELS).join(", ")}`);
267
+ assert.ok(count > 0, "MODELS must have at least one provider");
262
268
  });
263
269
 
264
270
  it("has at least 200 models in total (sanity check)", () => {
@@ -269,37 +275,11 @@ describe("MODELS registry shape", () => {
269
275
  assert.ok(total >= 200, `Registry has only ${total} models — unexpectedly small`);
270
276
  });
271
277
 
272
- it("all 23 expected providers are present", () => {
273
- const expected = [
274
- "amazon-bedrock",
275
- "anthropic",
276
- "azure-openai-responses",
277
- "cerebras",
278
- "github-copilot",
279
- "google",
280
- "google-antigravity",
281
- "google-gemini-cli",
282
- "google-vertex",
283
- "groq",
284
- "huggingface",
285
- "kimi-coding",
286
- "minimax",
287
- "minimax-cn",
288
- "mistral",
289
- "openai",
290
- "openai-codex",
291
- "opencode",
292
- "opencode-go",
293
- "openrouter",
294
- "vercel-ai-gateway",
295
- "xai",
296
- "zai",
297
- ];
298
- const actual = Object.keys(MODELS).sort();
299
- assert.deepEqual(actual, expected.sort());
300
- });
301
-
302
- it("getProviders() returns all generated providers", () => {
278
+ it("getProviders() returns every generated provider", () => {
279
+ // `getProviders()` may also include providers defined in
280
+ // `models/custom.ts` (manually-patched entries). We assert only
281
+ // that every GENERATED provider is present — which is the
282
+ // invariant the generator controls.
303
283
  const providers = getProviders();
304
284
  for (const p of Object.keys(MODELS)) {
305
285
  assert.ok(providers.includes(p as any), `getProviders() missing generated provider: ${p}`);
@@ -346,44 +326,37 @@ describe("removed models are absent from the registry", () => {
346
326
  }
347
327
  });
348
328
 
349
- // ═══════════════════════════════════════════════════════════════════════════
350
- // Spot-checks for notable models added in this regeneration
351
- // ═══════════════════════════════════════════════════════════════════════════
352
-
353
- describe("spot-checks for models added in this regeneration", () => {
354
- const newModels: Array<{ provider: string; id: string; reasoning?: boolean }> = [
355
- { provider: "openrouter", id: "z-ai/glm-5.1" },
356
- { provider: "openrouter", id: "z-ai/glm-5v-turbo" },
357
- { provider: "openrouter", id: "google/gemma-4-31b-it" },
358
- { provider: "openrouter", id: "google/gemma-4-26b-a4b-it" },
359
- { provider: "openrouter", id: "arcee-ai/trinity-large-thinking", reasoning: true },
360
- { provider: "openrouter", id: "openai/gpt-audio" },
361
- { provider: "openrouter", id: "anthropic/claude-opus-4.6-fast" },
362
- { provider: "openrouter", id: "anthropic/claude-opus-4.7" },
363
- { provider: "amazon-bedrock", id: "anthropic.claude-opus-4-7" },
364
- { provider: "amazon-bedrock", id: "us.anthropic.claude-opus-4-7" },
365
- { provider: "amazon-bedrock", id: "eu.anthropic.claude-opus-4-7" },
366
- { provider: "amazon-bedrock", id: "global.anthropic.claude-opus-4-7" },
367
- { provider: "google-antigravity", id: "claude-opus-4-7-thinking", reasoning: true },
368
- { provider: "openrouter", id: "qwen/qwen3.6-plus" },
369
- { provider: "groq", id: "groq/compound" },
370
- { provider: "groq", id: "groq/compound-mini" },
371
- { provider: "huggingface", id: "zai-org/GLM-5.1" },
372
- { provider: "openai", id: "gpt-5.3-chat-latest" },
373
- { provider: "openai-codex", id: "gpt-5.4-mini", reasoning: true },
374
- { provider: "mistral", id: "mistral-small-2603" },
375
- { provider: "zai", id: "glm-5.1" },
376
- ];
377
-
378
- for (const { provider, id, reasoning } of newModels) {
379
- it(`${provider}/${id} is present in the registry`, () => {
380
- const model = getModel(provider as any, id as any);
381
- assert.ok(model, `Expected ${provider}/${id} to be present after regeneration`);
382
- assert.equal(model.id, id);
383
- assert.equal(model.provider, provider);
384
- if (reasoning !== undefined) {
385
- assert.equal(model.reasoning, reasoning, `${id} reasoning should be ${reasoning}`);
386
- }
387
- });
388
- }
329
+ // "Spot-checks for models added in this regeneration" removed (#4804).
330
+ //
331
+ // The block asserted that a hardcoded list of 21 model IDs was present
332
+ // in the registry. Each assertion read a value the generator had just
333
+ // written, so the test could not detect a broken generator — it only
334
+ // tripped when someone hand-edited the snapshot. Worse, the list went
335
+ // stale on every regeneration (adding a fresh list is the reviewer's
336
+ // tax) without providing any invariant the structural tests above
337
+ // didn't already cover:
338
+ // - every id matches its key
339
+ // - every model has a positive contextWindow
340
+ // - no duplicate model IDs
341
+ //
342
+ // If a specific model capability is load-bearing for a feature, the
343
+ // guard for that capability belongs in the feature's own test — not
344
+ // in a "did the generator output what it output" snapshot. The
345
+ // GPT-5.5 availability test below is an example: it asserts concrete
346
+ // pricing/context-window values the feature depends on.
347
+
348
+ describe("GPT-5.5 availability", () => {
349
+ it("exposes GPT-5.5 through OpenAI API and OpenAI Codex providers", () => {
350
+ const apiModel = getModel("openai", "gpt-5.5" as any);
351
+ assert.ok(apiModel, "openai/gpt-5.5 should be present");
352
+ assert.equal(apiModel.contextWindow, 1000000);
353
+ assert.equal(apiModel.cost.input, 5);
354
+ assert.equal(apiModel.cost.output, 30);
355
+
356
+ const codexModel = getModel("openai-codex", "gpt-5.5" as any);
357
+ assert.ok(codexModel, "openai-codex/gpt-5.5 should be present");
358
+ assert.equal(codexModel.contextWindow, 400000);
359
+ assert.equal(codexModel.cost.input, 5);
360
+ assert.equal(codexModel.cost.output, 30);
361
+ });
389
362
  });