@opengsd/gsd-pi 1.2.0-dev.844675c9 → 1.2.0-dev.84c56d87

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 (657) hide show
  1. package/dist/cli-style.d.ts +17 -0
  2. package/dist/cli-style.js +28 -0
  3. package/dist/cli-web-branch.d.ts +2 -0
  4. package/dist/cli-web-branch.js +9 -2
  5. package/dist/cli.js +1 -1
  6. package/dist/headless-events.d.ts +4 -2
  7. package/dist/headless-events.js +7 -29
  8. package/dist/help-text.js +5 -0
  9. package/dist/models-resolver.d.ts +3 -13
  10. package/dist/models-resolver.js +3 -22
  11. package/dist/resource-loader.js +2 -14
  12. package/dist/resources/.managed-resources-content-hash +1 -1
  13. package/dist/resources/extensions/ask-user-questions.js +78 -23
  14. package/dist/resources/extensions/bg-shell/utilities.js +5 -2
  15. package/dist/resources/extensions/browser-tools/engine/managed-gsd-browser.js +209 -88
  16. package/dist/resources/extensions/browser-tools/engine/selection.js +73 -5
  17. package/dist/resources/extensions/browser-tools/index.js +69 -12
  18. package/dist/resources/extensions/claude-code-cli/models.js +9 -0
  19. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +122 -234
  20. package/dist/resources/extensions/claude-code-cli/turn-assembler.js +224 -0
  21. package/dist/resources/extensions/github-sync/templates.js +3 -3
  22. package/dist/resources/extensions/gsd/artifact-projection.js +14 -0
  23. package/dist/resources/extensions/gsd/auto/loop.js +74 -56
  24. package/dist/resources/extensions/gsd/auto/orchestrator.js +142 -15
  25. package/dist/resources/extensions/gsd/auto/phases.js +34 -4
  26. package/dist/resources/extensions/gsd/auto/run-unit.js +2 -1
  27. package/dist/resources/extensions/gsd/auto/session.js +3 -0
  28. package/dist/resources/extensions/gsd/auto-dashboard.js +16 -4
  29. package/dist/resources/extensions/gsd/auto-dispatch.js +6 -5
  30. package/dist/resources/extensions/gsd/auto-model-selection.js +8 -0
  31. package/dist/resources/extensions/gsd/auto-post-unit.js +23 -11
  32. package/dist/resources/extensions/gsd/auto-prompts.js +84 -8
  33. package/dist/resources/extensions/gsd/auto-recovery.js +48 -49
  34. package/dist/resources/extensions/gsd/auto-runtime-state.js +14 -0
  35. package/dist/resources/extensions/gsd/auto-start.js +24 -37
  36. package/dist/resources/extensions/gsd/auto-timers.js +16 -2
  37. package/dist/resources/extensions/gsd/auto-tool-tracking.js +50 -0
  38. package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +11 -45
  39. package/dist/resources/extensions/gsd/auto-verification.js +7 -7
  40. package/dist/resources/extensions/gsd/auto-worktree-repair.js +10 -2
  41. package/dist/resources/extensions/gsd/auto-worktree.js +53 -368
  42. package/dist/resources/extensions/gsd/auto.js +19 -27
  43. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +3 -2
  44. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +28 -37
  45. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +20 -43
  46. package/dist/resources/extensions/gsd/bootstrap/query-tools.js +2 -2
  47. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
  48. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +209 -149
  49. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +93 -8
  50. package/dist/resources/extensions/gsd/branch-patterns.js +2 -0
  51. package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
  52. package/dist/resources/extensions/gsd/captures.js +5 -15
  53. package/dist/resources/extensions/gsd/closeout-consistency-gate.js +21 -4
  54. package/dist/resources/extensions/gsd/closeout-recovery.js +3 -2
  55. package/dist/resources/extensions/gsd/codebase-generator.js +8 -4
  56. package/dist/resources/extensions/gsd/commands/catalog.js +6 -62
  57. package/dist/resources/extensions/gsd/commands/handlers/auto.js +3 -0
  58. package/dist/resources/extensions/gsd/commands-handlers.js +20 -0
  59. package/dist/resources/extensions/gsd/commands-inspect.js +4 -8
  60. package/dist/resources/extensions/gsd/commands-maintenance.js +61 -41
  61. package/dist/resources/extensions/gsd/commands-ship.js +2 -2
  62. package/dist/resources/extensions/gsd/commands-verdict.js +12 -2
  63. package/dist/resources/extensions/gsd/crash-recovery.js +4 -12
  64. package/dist/resources/extensions/gsd/db/engine.js +755 -0
  65. package/dist/resources/extensions/gsd/db/queries.js +372 -0
  66. package/dist/resources/extensions/gsd/db/sql-constants.js +11 -0
  67. package/dist/resources/extensions/gsd/db/writers/cascades.js +194 -0
  68. package/dist/resources/extensions/gsd/db/writers/import-restore.js +182 -0
  69. package/dist/resources/extensions/gsd/db/writers/memory.js +149 -0
  70. package/dist/resources/extensions/gsd/db/writers/reconcile.js +458 -0
  71. package/dist/resources/extensions/gsd/db/writers/status.js +70 -0
  72. package/dist/resources/extensions/gsd/db-workspace.js +103 -0
  73. package/dist/resources/extensions/gsd/delegation-policy.js +2 -10
  74. package/dist/resources/extensions/gsd/discussion-handoff.js +218 -0
  75. package/dist/resources/extensions/gsd/docs/preferences-reference.md +9 -0
  76. package/dist/resources/extensions/gsd/doctor-environment.js +5 -11
  77. package/dist/resources/extensions/gsd/doctor-format.js +9 -6
  78. package/dist/resources/extensions/gsd/doctor-git-checks.js +4 -3
  79. package/dist/resources/extensions/gsd/doctor-runtime-checks.js +21 -16
  80. package/dist/resources/extensions/gsd/doctor.js +16 -9
  81. package/dist/resources/extensions/gsd/error-classifier.js +10 -1
  82. package/dist/resources/extensions/gsd/git-conflict-state.js +16 -1
  83. package/dist/resources/extensions/gsd/git-service.js +1 -0
  84. package/dist/resources/extensions/gsd/gitignore.js +3 -0
  85. package/dist/resources/extensions/gsd/gsd-db.js +183 -2048
  86. package/dist/resources/extensions/gsd/guidance.js +98 -0
  87. package/dist/resources/extensions/gsd/guided-flow.js +83 -471
  88. package/dist/resources/extensions/gsd/guided-unit-completion.js +225 -0
  89. package/dist/resources/extensions/gsd/markdown-renderer.js +2 -1
  90. package/dist/resources/extensions/gsd/mcp-filter.js +4 -20
  91. package/dist/resources/extensions/gsd/mcp-tool-name.js +18 -0
  92. package/dist/resources/extensions/gsd/md-importer.js +4 -3
  93. package/dist/resources/extensions/gsd/memory-consolidation-scanner.js +1 -1
  94. package/dist/resources/extensions/gsd/migrate/safety.js +22 -11
  95. package/dist/resources/extensions/gsd/migration-auto-check.js +27 -5
  96. package/dist/resources/extensions/gsd/milestone-closeout-proof.js +72 -0
  97. package/dist/resources/extensions/gsd/milestone-closeout.js +12 -4
  98. package/dist/resources/extensions/gsd/milestone-merge-transaction.js +10 -0
  99. package/dist/resources/extensions/gsd/milestone-planning-persistence.js +156 -0
  100. package/dist/resources/extensions/gsd/milestone-readiness.js +77 -0
  101. package/dist/resources/extensions/gsd/milestone-settlement.js +50 -0
  102. package/dist/resources/extensions/gsd/milestone-validation-evidence.js +73 -0
  103. package/dist/resources/extensions/gsd/milestone-validation-verdict.js +57 -0
  104. package/dist/resources/extensions/gsd/model-cost-table.js +1 -0
  105. package/dist/resources/extensions/gsd/model-router.js +3 -0
  106. package/dist/resources/extensions/gsd/notification-store.js +11 -4
  107. package/dist/resources/extensions/gsd/parallel-eligibility.js +3 -6
  108. package/dist/resources/extensions/gsd/parallel-merge.js +14 -11
  109. package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +11 -7
  110. package/dist/resources/extensions/gsd/parallel-orchestrator.js +3 -2
  111. package/dist/resources/extensions/gsd/paths.js +37 -24
  112. package/dist/resources/extensions/gsd/pre-execution-checks.js +91 -3
  113. package/dist/resources/extensions/gsd/preferences-diagnostics.js +67 -0
  114. package/dist/resources/extensions/gsd/preferences-models.js +12 -46
  115. package/dist/resources/extensions/gsd/preferences.js +161 -29
  116. package/dist/resources/extensions/gsd/prompts/complete-slice.md +1 -0
  117. package/dist/resources/extensions/gsd/prompts/execute-task.md +2 -0
  118. package/dist/resources/extensions/gsd/prompts/guided-discuss-project.md +3 -1
  119. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +2 -0
  120. package/dist/resources/extensions/gsd/prompts/plan-slice.md +2 -1
  121. package/dist/resources/extensions/gsd/prompts/refine-slice.md +2 -1
  122. package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  123. package/dist/resources/extensions/gsd/prompts/system.md +1 -1
  124. package/dist/resources/extensions/gsd/provider-error-guidance.js +1 -5
  125. package/dist/resources/extensions/gsd/provider-payload-policy.js +83 -0
  126. package/dist/resources/extensions/gsd/provider-switch-observer.js +1 -1
  127. package/dist/resources/extensions/gsd/publication.js +87 -0
  128. package/dist/resources/extensions/gsd/pull-request-process.js +13 -0
  129. package/dist/resources/extensions/gsd/quality-gate-closure.js +109 -0
  130. package/dist/resources/extensions/gsd/question-transport.js +86 -0
  131. package/dist/resources/extensions/gsd/recovery-classification.js +41 -87
  132. package/dist/resources/extensions/gsd/roadmap-slices.js +8 -2
  133. package/dist/resources/extensions/gsd/safety/evidence-collector.js +37 -4
  134. package/dist/resources/extensions/gsd/safety/evidence-cross-ref.js +7 -2
  135. package/dist/resources/extensions/gsd/safety/file-change-validator.js +10 -0
  136. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +3 -2
  137. package/dist/resources/extensions/gsd/state-transition-matrix.js +38 -0
  138. package/dist/resources/extensions/gsd/state.js +14 -25
  139. package/dist/resources/extensions/gsd/status-guards.js +56 -8
  140. package/dist/resources/extensions/gsd/stop-notice.js +57 -0
  141. package/dist/resources/extensions/gsd/templates/plan.md +7 -0
  142. package/dist/resources/extensions/gsd/templates/project.md +1 -0
  143. package/dist/resources/extensions/gsd/templates/roadmap.md +1 -1
  144. package/dist/resources/extensions/gsd/templates/uat.md +5 -1
  145. package/dist/resources/extensions/gsd/tool-contract.js +52 -8
  146. package/dist/resources/extensions/gsd/tool-presentation-plan.js +15 -34
  147. package/dist/resources/extensions/gsd/tool-surface-readiness.js +56 -0
  148. package/dist/resources/extensions/gsd/tool-surface-snapshot.js +17 -0
  149. package/dist/resources/extensions/gsd/tools/complete-slice.js +24 -43
  150. package/dist/resources/extensions/gsd/tools/exec-tool.js +5 -8
  151. package/dist/resources/extensions/gsd/tools/plan-milestone.js +15 -143
  152. package/dist/resources/extensions/gsd/tools/plan-slice.js +12 -6
  153. package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +39 -0
  154. package/dist/resources/extensions/gsd/tools/reopen-milestone.js +11 -29
  155. package/dist/resources/extensions/gsd/tools/reopen-slice.js +14 -33
  156. package/dist/resources/extensions/gsd/tools/skip-slice.js +18 -36
  157. package/dist/resources/extensions/gsd/tools/validate-milestone.js +15 -78
  158. package/dist/resources/extensions/gsd/uat-policy.js +17 -10
  159. package/dist/resources/extensions/gsd/uat-run.js +9 -14
  160. package/dist/resources/extensions/gsd/undo.js +8 -7
  161. package/dist/resources/extensions/gsd/unit-closeout.js +138 -0
  162. package/dist/resources/extensions/gsd/unit-context-composer.js +49 -21
  163. package/dist/resources/extensions/gsd/unit-context-manifest.js +4 -27
  164. package/dist/resources/extensions/gsd/unit-registry.js +337 -0
  165. package/dist/resources/extensions/gsd/unit-runtime.js +3 -2
  166. package/dist/resources/extensions/gsd/unit-tool-contracts.js +9 -181
  167. package/dist/resources/extensions/gsd/user-input-boundary.js +23 -0
  168. package/dist/resources/extensions/gsd/validation-block-guard.js +2 -0
  169. package/dist/resources/extensions/gsd/web-app-uat.js +117 -0
  170. package/dist/resources/extensions/gsd/workflow-mcp.js +15 -102
  171. package/dist/resources/extensions/gsd/workflow-reconcile.js +4 -3
  172. package/dist/resources/extensions/gsd/workflow-tool-surface.js +46 -0
  173. package/dist/resources/extensions/gsd/workspace-git-guard.js +2 -0
  174. package/dist/resources/extensions/gsd/worktree-git-recovery.js +293 -0
  175. package/dist/resources/extensions/gsd/worktree-lifecycle.js +9 -1
  176. package/dist/resources/extensions/gsd/worktree-manager.js +45 -28
  177. package/dist/resources/extensions/gsd/worktree-placement.js +59 -0
  178. package/dist/resources/extensions/gsd/worktree-reentry.js +12 -8
  179. package/dist/resources/extensions/gsd/worktree-root.js +28 -6
  180. package/dist/resources/extensions/gsd/worktree-safety.js +8 -5
  181. package/dist/resources/extensions/gsd/worktree-session-state.js +12 -11
  182. package/dist/resources/extensions/gsd/worktree-state-projection.js +33 -4
  183. package/dist/resources/extensions/gsd/worktree-telemetry.js +12 -0
  184. package/dist/resources/extensions/search-the-web/native-search.js +5 -3
  185. package/dist/resources/extensions/shared/browser-contract.js +59 -0
  186. package/dist/resources/extensions/shared/gsd-browser-cli.js +72 -4
  187. package/dist/resources/extensions/shared/interview-ui.js +2 -2
  188. package/dist/resources/shared/claude-runtime-floor.js +182 -0
  189. package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
  190. package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
  191. package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
  192. package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
  193. package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
  194. package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
  195. package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
  196. package/dist/resources/skills/gsd-browser/SKILL.md +1 -1
  197. package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
  198. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  199. package/dist/update-cmd.js +20 -0
  200. package/dist/web/standalone/.next/BUILD_ID +1 -1
  201. package/dist/web/standalone/.next/app-path-routes-manifest.json +6 -6
  202. package/dist/web/standalone/.next/build-manifest.json +3 -3
  203. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  204. package/dist/web/standalone/.next/react-loadable-manifest.json +8 -8
  205. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  206. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  207. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  208. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  209. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  210. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  211. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  212. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  213. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  214. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  215. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  216. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  217. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  218. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  219. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  220. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  221. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  222. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  223. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  224. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  225. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  226. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  227. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  228. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  229. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  230. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  231. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  232. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  233. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  234. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  235. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  236. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  237. package/dist/web/standalone/.next/server/app/api/mcp-connections/route.js.nft.json +1 -1
  238. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  239. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  240. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  241. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  242. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  243. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  244. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  245. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  246. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  247. package/dist/web/standalone/.next/server/app/api/shutdown/route.js.nft.json +1 -1
  248. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  249. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  250. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  251. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  252. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  253. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  254. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  255. package/dist/web/standalone/.next/server/app/index.html +1 -1
  256. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  257. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  258. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  259. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  260. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  261. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  262. package/dist/web/standalone/.next/server/app-paths-manifest.json +6 -6
  263. package/dist/web/standalone/.next/server/chunks/5124.js +1 -1
  264. package/dist/web/standalone/.next/server/chunks/{5047.js → 5942.js} +2 -2
  265. package/dist/web/standalone/.next/server/chunks/8357.js +1 -1
  266. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  267. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  268. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  269. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  270. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  271. package/dist/web/standalone/.next/static/chunks/2659.b7b129ee6a769448.js +1 -0
  272. package/dist/web/standalone/.next/static/chunks/2772.bfa657f49f955239.js +1 -0
  273. package/dist/web/standalone/.next/static/chunks/{3616.4113d484a994e411.js → 3616.3c60753b8ffcbd2e.js} +1 -1
  274. package/dist/web/standalone/.next/static/chunks/4283.e4873b058df143a1.js +2 -0
  275. package/dist/web/standalone/.next/static/chunks/5826.a46ecdd1cfe8dabc.js +1 -0
  276. package/dist/web/standalone/.next/static/chunks/796.cf859a427a2cb2ac.js +10 -0
  277. package/dist/web/standalone/.next/static/chunks/8785.2e5a118797fb2dd2.js +1 -0
  278. package/dist/web/standalone/.next/static/chunks/{webpack-dda80a1ef5587410.js → webpack-fbea77b5f9953368.js} +1 -1
  279. package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
  280. package/dist/web/standalone/node_modules/postcss/lib/container.js +18 -26
  281. package/dist/web/standalone/node_modules/postcss/lib/css-syntax-error.js +14 -47
  282. package/dist/web/standalone/node_modules/postcss/lib/declaration.js +4 -4
  283. package/dist/web/standalone/node_modules/postcss/lib/fromJSON.js +3 -3
  284. package/dist/web/standalone/node_modules/postcss/lib/input.js +29 -54
  285. package/dist/web/standalone/node_modules/postcss/lib/lazy-result.js +37 -47
  286. package/dist/web/standalone/node_modules/postcss/lib/map-generator.js +9 -26
  287. package/dist/web/standalone/node_modules/postcss/lib/no-work-result.js +55 -57
  288. package/dist/web/standalone/node_modules/postcss/lib/node.js +31 -99
  289. package/dist/web/standalone/node_modules/postcss/lib/parse.js +1 -1
  290. package/dist/web/standalone/node_modules/postcss/lib/parser.js +9 -10
  291. package/dist/web/standalone/node_modules/postcss/lib/postcss.js +12 -12
  292. package/dist/web/standalone/node_modules/postcss/lib/previous-map.js +11 -30
  293. package/dist/web/standalone/node_modules/postcss/lib/processor.js +7 -7
  294. package/dist/web/standalone/node_modules/postcss/lib/result.js +5 -5
  295. package/dist/web/standalone/node_modules/postcss/lib/rule.js +6 -6
  296. package/dist/web/standalone/node_modules/postcss/lib/stringifier.js +28 -69
  297. package/dist/web/standalone/node_modules/postcss/lib/tokenize.js +2 -6
  298. package/dist/web/standalone/node_modules/postcss/package.json +48 -48
  299. package/dist/web/standalone/package.json +1 -1
  300. package/dist/web-mode.d.ts +2 -0
  301. package/dist/web-mode.js +20 -8
  302. package/dist/worktree-cli.js +3 -6
  303. package/dist/worktree-status-banner.js +7 -11
  304. package/package.json +2 -1
  305. package/packages/cloud-mcp-gateway/package.json +2 -2
  306. package/packages/contracts/dist/workflow.d.ts +4 -0
  307. package/packages/contracts/dist/workflow.d.ts.map +1 -1
  308. package/packages/contracts/dist/workflow.js.map +1 -1
  309. package/packages/contracts/package.json +1 -1
  310. package/packages/daemon/package.json +4 -4
  311. package/packages/gsd-agent-core/dist/session/agent-session-extensions.d.ts +2 -0
  312. package/packages/gsd-agent-core/dist/session/agent-session-extensions.d.ts.map +1 -1
  313. package/packages/gsd-agent-core/dist/session/agent-session-extensions.js +14 -0
  314. package/packages/gsd-agent-core/dist/session/agent-session-extensions.js.map +1 -1
  315. package/packages/gsd-agent-core/package.json +5 -5
  316. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  317. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +3 -0
  318. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
  319. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  320. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +106 -40
  321. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  322. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.d.ts.map +1 -1
  323. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.js +6 -0
  324. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.js.map +1 -1
  325. package/packages/gsd-agent-modes/package.json +7 -7
  326. package/packages/mcp-server/dist/cli.js +6 -3
  327. package/packages/mcp-server/dist/cli.js.map +1 -1
  328. package/packages/mcp-server/dist/server.d.ts +10 -0
  329. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  330. package/packages/mcp-server/dist/server.js +8 -0
  331. package/packages/mcp-server/dist/server.js.map +1 -1
  332. package/packages/mcp-server/dist/workflow-tools.d.ts +49 -0
  333. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  334. package/packages/mcp-server/dist/workflow-tools.js +48 -22
  335. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  336. package/packages/mcp-server/package.json +3 -3
  337. package/packages/native/package.json +1 -1
  338. package/packages/pi-agent-core/package.json +1 -1
  339. package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
  340. package/packages/pi-ai/dist/image-models.generated.js +6 -6
  341. package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
  342. package/packages/pi-ai/dist/models.generated.d.ts +455 -546
  343. package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
  344. package/packages/pi-ai/dist/models.generated.js +481 -599
  345. package/packages/pi-ai/dist/models.generated.js.map +1 -1
  346. package/packages/pi-ai/package.json +1 -1
  347. package/packages/pi-coding-agent/dist/core/capability-patches.d.ts.map +1 -1
  348. package/packages/pi-coding-agent/dist/core/capability-patches.js +3 -1
  349. package/packages/pi-coding-agent/dist/core/capability-patches.js.map +1 -1
  350. package/packages/pi-coding-agent/package.json +7 -7
  351. package/packages/pi-tui/dist/components/input.js +1 -1
  352. package/packages/pi-tui/dist/components/input.js.map +1 -1
  353. package/packages/pi-tui/dist/keys.d.ts.map +1 -1
  354. package/packages/pi-tui/dist/keys.js +39 -30
  355. package/packages/pi-tui/dist/keys.js.map +1 -1
  356. package/packages/pi-tui/dist/stdin-buffer.d.ts.map +1 -1
  357. package/packages/pi-tui/dist/stdin-buffer.js +22 -0
  358. package/packages/pi-tui/dist/stdin-buffer.js.map +1 -1
  359. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  360. package/packages/pi-tui/dist/tui.js +9 -0
  361. package/packages/pi-tui/dist/tui.js.map +1 -1
  362. package/packages/pi-tui/package.json +2 -2
  363. package/packages/rpc-client/package.json +2 -2
  364. package/pkg/package.json +1 -1
  365. package/src/resources/extensions/ask-user-questions.ts +87 -24
  366. package/src/resources/extensions/bg-shell/utilities.ts +5 -2
  367. package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
  368. package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
  369. package/src/resources/extensions/browser-tools/index.ts +71 -13
  370. package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
  371. package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
  372. package/src/resources/extensions/claude-code-cli/models.ts +9 -0
  373. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +148 -285
  374. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +268 -0
  375. package/src/resources/extensions/claude-code-cli/turn-assembler.ts +287 -0
  376. package/src/resources/extensions/github-sync/templates.ts +3 -3
  377. package/src/resources/extensions/github-sync/tests/templates.test.ts +2 -2
  378. package/src/resources/extensions/gsd/artifact-projection.ts +31 -0
  379. package/src/resources/extensions/gsd/auto/contracts.ts +32 -2
  380. package/src/resources/extensions/gsd/auto/loop-deps.ts +3 -1
  381. package/src/resources/extensions/gsd/auto/loop.ts +83 -61
  382. package/src/resources/extensions/gsd/auto/orchestrator.ts +164 -17
  383. package/src/resources/extensions/gsd/auto/phases.ts +45 -4
  384. package/src/resources/extensions/gsd/auto/run-unit.ts +2 -1
  385. package/src/resources/extensions/gsd/auto/session.ts +4 -0
  386. package/src/resources/extensions/gsd/auto-dashboard.ts +18 -4
  387. package/src/resources/extensions/gsd/auto-dispatch.ts +20 -7
  388. package/src/resources/extensions/gsd/auto-model-selection.ts +8 -0
  389. package/src/resources/extensions/gsd/auto-post-unit.ts +29 -10
  390. package/src/resources/extensions/gsd/auto-prompts.ts +110 -9
  391. package/src/resources/extensions/gsd/auto-recovery.ts +50 -50
  392. package/src/resources/extensions/gsd/auto-runtime-state.ts +26 -0
  393. package/src/resources/extensions/gsd/auto-start.ts +29 -35
  394. package/src/resources/extensions/gsd/auto-timers.ts +16 -2
  395. package/src/resources/extensions/gsd/auto-tool-tracking.ts +54 -0
  396. package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +19 -47
  397. package/src/resources/extensions/gsd/auto-verification.ts +7 -8
  398. package/src/resources/extensions/gsd/auto-worktree-repair.ts +13 -2
  399. package/src/resources/extensions/gsd/auto-worktree.ts +68 -384
  400. package/src/resources/extensions/gsd/auto.ts +35 -32
  401. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +3 -5
  402. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +29 -37
  403. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +20 -43
  404. package/src/resources/extensions/gsd/bootstrap/query-tools.ts +2 -2
  405. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
  406. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +251 -161
  407. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +136 -6
  408. package/src/resources/extensions/gsd/branch-patterns.ts +3 -0
  409. package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
  410. package/src/resources/extensions/gsd/captures.ts +5 -16
  411. package/src/resources/extensions/gsd/closeout-consistency-gate.ts +27 -5
  412. package/src/resources/extensions/gsd/closeout-recovery.ts +2 -1
  413. package/src/resources/extensions/gsd/codebase-generator.ts +9 -5
  414. package/src/resources/extensions/gsd/commands/catalog.ts +6 -68
  415. package/src/resources/extensions/gsd/commands/handlers/auto.ts +3 -0
  416. package/src/resources/extensions/gsd/commands-handlers.ts +18 -0
  417. package/src/resources/extensions/gsd/commands-inspect.ts +7 -8
  418. package/src/resources/extensions/gsd/commands-maintenance.ts +74 -40
  419. package/src/resources/extensions/gsd/commands-ship.ts +2 -2
  420. package/src/resources/extensions/gsd/commands-verdict.ts +19 -2
  421. package/src/resources/extensions/gsd/crash-recovery.ts +3 -9
  422. package/src/resources/extensions/gsd/db/engine.ts +809 -0
  423. package/src/resources/extensions/gsd/db/queries.ts +453 -0
  424. package/src/resources/extensions/gsd/db/sql-constants.ts +12 -0
  425. package/src/resources/extensions/gsd/db/writers/cascades.ts +237 -0
  426. package/src/resources/extensions/gsd/db/writers/import-restore.ts +310 -0
  427. package/src/resources/extensions/gsd/db/writers/memory.ts +220 -0
  428. package/src/resources/extensions/gsd/db/writers/reconcile.ts +500 -0
  429. package/src/resources/extensions/gsd/db/writers/status.ts +88 -0
  430. package/src/resources/extensions/gsd/db-workspace.ts +170 -0
  431. package/src/resources/extensions/gsd/delegation-policy.ts +3 -11
  432. package/src/resources/extensions/gsd/discussion-handoff.ts +276 -0
  433. package/src/resources/extensions/gsd/docs/preferences-reference.md +9 -0
  434. package/src/resources/extensions/gsd/doctor-environment.ts +5 -13
  435. package/src/resources/extensions/gsd/doctor-format.ts +12 -7
  436. package/src/resources/extensions/gsd/doctor-git-checks.ts +3 -3
  437. package/src/resources/extensions/gsd/doctor-runtime-checks.ts +22 -17
  438. package/src/resources/extensions/gsd/doctor.ts +15 -5
  439. package/src/resources/extensions/gsd/error-classifier.ts +12 -1
  440. package/src/resources/extensions/gsd/git-conflict-state.ts +17 -1
  441. package/src/resources/extensions/gsd/git-service.ts +1 -0
  442. package/src/resources/extensions/gsd/gitignore.ts +3 -0
  443. package/src/resources/extensions/gsd/gsd-db.ts +185 -2373
  444. package/src/resources/extensions/gsd/guidance.ts +139 -0
  445. package/src/resources/extensions/gsd/guided-flow.ts +95 -561
  446. package/src/resources/extensions/gsd/guided-unit-completion.ts +275 -0
  447. package/src/resources/extensions/gsd/markdown-renderer.ts +2 -1
  448. package/src/resources/extensions/gsd/mcp-filter.ts +4 -24
  449. package/src/resources/extensions/gsd/mcp-tool-name.ts +30 -0
  450. package/src/resources/extensions/gsd/md-importer.ts +3 -3
  451. package/src/resources/extensions/gsd/memory-consolidation-scanner.ts +1 -1
  452. package/src/resources/extensions/gsd/migrate/safety.ts +20 -9
  453. package/src/resources/extensions/gsd/migration-auto-check.ts +30 -5
  454. package/src/resources/extensions/gsd/milestone-closeout-proof.ts +131 -0
  455. package/src/resources/extensions/gsd/milestone-closeout.ts +12 -4
  456. package/src/resources/extensions/gsd/milestone-merge-transaction.ts +47 -0
  457. package/src/resources/extensions/gsd/milestone-planning-persistence.ts +224 -0
  458. package/src/resources/extensions/gsd/milestone-readiness.ts +125 -0
  459. package/src/resources/extensions/gsd/milestone-settlement.ts +81 -0
  460. package/src/resources/extensions/gsd/milestone-validation-evidence.ts +95 -0
  461. package/src/resources/extensions/gsd/milestone-validation-verdict.ts +80 -0
  462. package/src/resources/extensions/gsd/model-cost-table.ts +1 -0
  463. package/src/resources/extensions/gsd/model-router.ts +3 -0
  464. package/src/resources/extensions/gsd/notification-store.ts +26 -3
  465. package/src/resources/extensions/gsd/parallel-eligibility.ts +4 -5
  466. package/src/resources/extensions/gsd/parallel-merge.ts +12 -9
  467. package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +10 -7
  468. package/src/resources/extensions/gsd/parallel-orchestrator.ts +6 -2
  469. package/src/resources/extensions/gsd/paths.ts +42 -22
  470. package/src/resources/extensions/gsd/pre-execution-checks.ts +109 -3
  471. package/src/resources/extensions/gsd/preferences-diagnostics.ts +98 -0
  472. package/src/resources/extensions/gsd/preferences-models.ts +10 -46
  473. package/src/resources/extensions/gsd/preferences-types.ts +16 -0
  474. package/src/resources/extensions/gsd/preferences.ts +191 -28
  475. package/src/resources/extensions/gsd/prompts/complete-slice.md +1 -0
  476. package/src/resources/extensions/gsd/prompts/execute-task.md +2 -0
  477. package/src/resources/extensions/gsd/prompts/guided-discuss-project.md +3 -1
  478. package/src/resources/extensions/gsd/prompts/plan-milestone.md +2 -0
  479. package/src/resources/extensions/gsd/prompts/plan-slice.md +2 -1
  480. package/src/resources/extensions/gsd/prompts/refine-slice.md +2 -1
  481. package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  482. package/src/resources/extensions/gsd/prompts/system.md +1 -1
  483. package/src/resources/extensions/gsd/provider-error-guidance.ts +4 -9
  484. package/src/resources/extensions/gsd/provider-payload-policy.ts +140 -0
  485. package/src/resources/extensions/gsd/provider-switch-observer.ts +1 -1
  486. package/src/resources/extensions/gsd/publication.ts +122 -0
  487. package/src/resources/extensions/gsd/pull-request-process.ts +41 -0
  488. package/src/resources/extensions/gsd/quality-gate-closure.ts +140 -0
  489. package/src/resources/extensions/gsd/question-transport.ts +138 -0
  490. package/src/resources/extensions/gsd/recovery-classification.ts +47 -88
  491. package/src/resources/extensions/gsd/roadmap-slices.ts +8 -2
  492. package/src/resources/extensions/gsd/safety/evidence-collector.ts +36 -4
  493. package/src/resources/extensions/gsd/safety/evidence-cross-ref.ts +7 -2
  494. package/src/resources/extensions/gsd/safety/file-change-validator.ts +14 -0
  495. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +6 -2
  496. package/src/resources/extensions/gsd/state-transition-matrix.ts +42 -0
  497. package/src/resources/extensions/gsd/state.ts +19 -26
  498. package/src/resources/extensions/gsd/status-guards.ts +59 -8
  499. package/src/resources/extensions/gsd/stop-notice.ts +75 -0
  500. package/src/resources/extensions/gsd/templates/plan.md +7 -0
  501. package/src/resources/extensions/gsd/templates/project.md +1 -0
  502. package/src/resources/extensions/gsd/templates/roadmap.md +1 -1
  503. package/src/resources/extensions/gsd/templates/uat.md +5 -1
  504. package/src/resources/extensions/gsd/tests/ask-user-questions-render.test.ts +92 -0
  505. package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +29 -1
  506. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +444 -5
  507. package/src/resources/extensions/gsd/tests/auto-milestone-target.test.ts +23 -0
  508. package/src/resources/extensions/gsd/tests/auto-model-selection-tool-poisoning.test.ts +18 -0
  509. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +133 -4
  510. package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +3 -1
  511. package/src/resources/extensions/gsd/tests/auto-post-unit-evidence-crossref-4909.test.ts +46 -0
  512. package/src/resources/extensions/gsd/tests/auto-runtime-state.test.ts +34 -0
  513. package/src/resources/extensions/gsd/tests/auto-worktree-registry.test.ts +2 -2
  514. package/src/resources/extensions/gsd/tests/auto-worktree-repair.test.ts +4 -2
  515. package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
  516. package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
  517. package/src/resources/extensions/gsd/tests/canonical-milestone-root.test.ts +20 -0
  518. package/src/resources/extensions/gsd/tests/checkout-branch-stash-guard.test.ts +66 -1
  519. package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +44 -0
  520. package/src/resources/extensions/gsd/tests/codebase-generator.test.ts +22 -0
  521. package/src/resources/extensions/gsd/tests/commands-dispatcher-workspace-git.test.ts +11 -0
  522. package/src/resources/extensions/gsd/tests/commands-verdict.test.ts +46 -8
  523. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +34 -3
  524. package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +89 -0
  525. package/src/resources/extensions/gsd/tests/doctor-scope-db-unavailable.test.ts +18 -0
  526. package/src/resources/extensions/gsd/tests/evidence-xref-gsd-exec.test.ts +157 -0
  527. package/src/resources/extensions/gsd/tests/execute-task-rendering.test.ts +1 -0
  528. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
  529. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +33 -1
  530. package/src/resources/extensions/gsd/tests/fixtures/pr-body/swarm-lane-no-blockers.md +1 -5
  531. package/src/resources/extensions/gsd/tests/fixtures/pr-body/swarm-lane-with-blockers.md +1 -5
  532. package/src/resources/extensions/gsd/tests/gate-state-canonicalization.test.ts +48 -1
  533. package/src/resources/extensions/gsd/tests/guidance.test.ts +125 -0
  534. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +58 -15
  535. package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +74 -59
  536. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +3 -2
  537. package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
  538. package/src/resources/extensions/gsd/tests/mcp-tool-name.test.ts +34 -0
  539. package/src/resources/extensions/gsd/tests/migration-auto-check.test.ts +143 -1
  540. package/src/resources/extensions/gsd/tests/milestone-closeout-proof.test.ts +99 -0
  541. package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +25 -0
  542. package/src/resources/extensions/gsd/tests/milestone-merge-transaction.test.ts +46 -0
  543. package/src/resources/extensions/gsd/tests/milestone-readiness.test.ts +65 -0
  544. package/src/resources/extensions/gsd/tests/milestone-validation-evidence.test.ts +41 -0
  545. package/src/resources/extensions/gsd/tests/milestone-validation-verdict.test.ts +55 -0
  546. package/src/resources/extensions/gsd/tests/notification-store.test.ts +32 -0
  547. package/src/resources/extensions/gsd/tests/plan-milestone.test.ts +45 -0
  548. package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +2 -0
  549. package/src/resources/extensions/gsd/tests/planning-crossval.test.ts +45 -0
  550. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +193 -1
  551. package/src/resources/extensions/gsd/tests/preferences-diagnostics.test.ts +67 -0
  552. package/src/resources/extensions/gsd/tests/preferences.test.ts +183 -0
  553. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +46 -0
  554. package/src/resources/extensions/gsd/tests/provider-error-guidance.test.ts +3 -3
  555. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +9 -0
  556. package/src/resources/extensions/gsd/tests/provider-payload-policy.test.ts +165 -0
  557. package/src/resources/extensions/gsd/tests/publication.test.ts +120 -0
  558. package/src/resources/extensions/gsd/tests/pull-request-process.test.ts +47 -0
  559. package/src/resources/extensions/gsd/tests/recovery-classification-illegal-transition.test.ts +30 -0
  560. package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +342 -1
  561. package/src/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +40 -0
  562. package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +26 -1
  563. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +38 -0
  564. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +80 -0
  565. package/src/resources/extensions/gsd/tests/session-switch-clears-pending-autostart.test.ts +108 -0
  566. package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +144 -7
  567. package/src/resources/extensions/gsd/tests/stale-queued-milestone.test.ts +27 -0
  568. package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +2 -1
  569. package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +36 -0
  570. package/src/resources/extensions/gsd/tests/status-guards.test.ts +38 -0
  571. package/src/resources/extensions/gsd/tests/stop-notice.test.ts +70 -0
  572. package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +35 -0
  573. package/src/resources/extensions/gsd/tests/tool-availability-audit.test.ts +35 -0
  574. package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +8 -0
  575. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +35 -42
  576. package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +155 -0
  577. package/src/resources/extensions/gsd/tests/uat-policy.test.ts +24 -6
  578. package/src/resources/extensions/gsd/tests/unit-closeout.test.ts +209 -0
  579. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +70 -2
  580. package/src/resources/extensions/gsd/tests/unit-registry.test.ts +163 -0
  581. package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +86 -1
  582. package/src/resources/extensions/gsd/tests/validate-milestone-stuck-guard.test.ts +39 -0
  583. package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +193 -0
  584. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +128 -11
  585. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +2 -2
  586. package/src/resources/extensions/gsd/tests/workspace-git-preflight.test.ts +15 -0
  587. package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +41 -4
  588. package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +43 -1
  589. package/src/resources/extensions/gsd/tests/worktree-placement.test.ts +113 -0
  590. package/src/resources/extensions/gsd/tests/worktree-projection-writers.test.ts +1 -1
  591. package/src/resources/extensions/gsd/tests/worktree-reentry.test.ts +1 -1
  592. package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +3 -1
  593. package/src/resources/extensions/gsd/tests/worktree-symlink-removal.test.ts +12 -6
  594. package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +2 -2
  595. package/src/resources/extensions/gsd/tests/worktree-telemetry.test.ts +22 -0
  596. package/src/resources/extensions/gsd/tests/write-gate.test.ts +121 -0
  597. package/src/resources/extensions/gsd/tool-contract.ts +86 -8
  598. package/src/resources/extensions/gsd/tool-presentation-plan.ts +16 -33
  599. package/src/resources/extensions/gsd/tool-surface-readiness.ts +76 -0
  600. package/src/resources/extensions/gsd/tool-surface-snapshot.ts +47 -0
  601. package/src/resources/extensions/gsd/tools/complete-slice.ts +23 -58
  602. package/src/resources/extensions/gsd/tools/exec-tool.ts +5 -8
  603. package/src/resources/extensions/gsd/tools/plan-milestone.ts +19 -160
  604. package/src/resources/extensions/gsd/tools/plan-slice.ts +12 -6
  605. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +43 -0
  606. package/src/resources/extensions/gsd/tools/reopen-milestone.ts +11 -38
  607. package/src/resources/extensions/gsd/tools/reopen-slice.ts +14 -42
  608. package/src/resources/extensions/gsd/tools/skip-slice.ts +18 -44
  609. package/src/resources/extensions/gsd/tools/validate-milestone.ts +25 -84
  610. package/src/resources/extensions/gsd/uat-policy.ts +20 -10
  611. package/src/resources/extensions/gsd/uat-run.ts +10 -14
  612. package/src/resources/extensions/gsd/undo.ts +9 -8
  613. package/src/resources/extensions/gsd/unit-closeout.ts +201 -0
  614. package/src/resources/extensions/gsd/unit-context-composer.ts +97 -21
  615. package/src/resources/extensions/gsd/unit-context-manifest.ts +4 -28
  616. package/src/resources/extensions/gsd/unit-registry.ts +412 -0
  617. package/src/resources/extensions/gsd/unit-runtime.ts +3 -2
  618. package/src/resources/extensions/gsd/unit-tool-contracts.ts +27 -191
  619. package/src/resources/extensions/gsd/user-input-boundary.ts +18 -0
  620. package/src/resources/extensions/gsd/validation-block-guard.ts +2 -0
  621. package/src/resources/extensions/gsd/web-app-uat.ts +144 -0
  622. package/src/resources/extensions/gsd/workflow-mcp.ts +22 -110
  623. package/src/resources/extensions/gsd/workflow-reconcile.ts +3 -3
  624. package/src/resources/extensions/gsd/workflow-tool-surface.ts +76 -0
  625. package/src/resources/extensions/gsd/workspace-git-guard.ts +1 -0
  626. package/src/resources/extensions/gsd/worktree-git-recovery.ts +314 -0
  627. package/src/resources/extensions/gsd/worktree-lifecycle.ts +17 -17
  628. package/src/resources/extensions/gsd/worktree-manager.ts +47 -28
  629. package/src/resources/extensions/gsd/worktree-placement.ts +63 -0
  630. package/src/resources/extensions/gsd/worktree-reentry.ts +10 -7
  631. package/src/resources/extensions/gsd/worktree-root.ts +29 -6
  632. package/src/resources/extensions/gsd/worktree-safety.ts +8 -5
  633. package/src/resources/extensions/gsd/worktree-session-state.ts +11 -11
  634. package/src/resources/extensions/gsd/worktree-state-projection.ts +55 -7
  635. package/src/resources/extensions/gsd/worktree-telemetry.ts +16 -0
  636. package/src/resources/extensions/search-the-web/native-search.ts +5 -3
  637. package/src/resources/extensions/shared/browser-contract.ts +66 -0
  638. package/src/resources/extensions/shared/gsd-browser-cli.ts +88 -4
  639. package/src/resources/extensions/shared/interview-ui.ts +15 -2
  640. package/src/resources/shared/claude-runtime-floor.ts +248 -0
  641. package/src/resources/skills/create-skill/references/executable-code.md +1 -1
  642. package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
  643. package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
  644. package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
  645. package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
  646. package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
  647. package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
  648. package/src/resources/skills/gsd-browser/SKILL.md +1 -1
  649. package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
  650. package/dist/web/standalone/.next/static/chunks/2659.feb6499ca863ebfc.js +0 -1
  651. package/dist/web/standalone/.next/static/chunks/2772.151789db0edea835.js +0 -1
  652. package/dist/web/standalone/.next/static/chunks/4283.10a065467b5340d8.js +0 -2
  653. package/dist/web/standalone/.next/static/chunks/5826.960dc4634cc9b0d3.js +0 -1
  654. package/dist/web/standalone/.next/static/chunks/796.46f811c0fac23aab.js +0 -10
  655. package/dist/web/standalone/.next/static/chunks/8785.d32f7a61f55c1600.js +0 -1
  656. /package/dist/web/standalone/.next/static/{Qbr81pQ-pbQXP4bq2VXLv → AOpDeK_gJHU8OZjRo31gQ}/_buildManifest.js +0 -0
  657. /package/dist/web/standalone/.next/static/{Qbr81pQ-pbQXP4bq2VXLv → AOpDeK_gJHU8OZjRo31gQ}/_ssgManifest.js +0 -0
@@ -8,7 +8,7 @@ export const MODELS = {
8
8
  api: "bedrock-converse-stream",
9
9
  provider: "amazon-bedrock",
10
10
  baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
11
- reasoning: false,
11
+ reasoning: true,
12
12
  input: ["text", "image"],
13
13
  cost: {
14
14
  input: 0.33,
@@ -70,6 +70,24 @@ export const MODELS = {
70
70
  contextWindow: 300000,
71
71
  maxTokens: 8192,
72
72
  },
73
+ "anthropic.claude-fable-5": {
74
+ id: "anthropic.claude-fable-5",
75
+ name: "Claude Fable 5",
76
+ api: "bedrock-converse-stream",
77
+ provider: "amazon-bedrock",
78
+ baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
79
+ reasoning: true,
80
+ thinkingLevelMap: { "xhigh": "xhigh" },
81
+ input: ["text", "image"],
82
+ cost: {
83
+ input: 10,
84
+ output: 50,
85
+ cacheRead: 1,
86
+ cacheWrite: 12.5,
87
+ },
88
+ contextWindow: 1000000,
89
+ maxTokens: 128000,
90
+ },
73
91
  "anthropic.claude-haiku-4-5-20251001-v1:0": {
74
92
  id: "anthropic.claude-haiku-4-5-20251001-v1:0",
75
93
  name: "Claude Haiku 4.5",
@@ -347,6 +365,24 @@ export const MODELS = {
347
365
  contextWindow: 163840,
348
366
  maxTokens: 81920,
349
367
  },
368
+ "eu.anthropic.claude-fable-5": {
369
+ id: "eu.anthropic.claude-fable-5",
370
+ name: "Claude Fable 5 (EU)",
371
+ api: "bedrock-converse-stream",
372
+ provider: "amazon-bedrock",
373
+ baseUrl: "https://bedrock-runtime.eu-central-1.amazonaws.com",
374
+ reasoning: true,
375
+ thinkingLevelMap: { "xhigh": "xhigh" },
376
+ input: ["text", "image"],
377
+ cost: {
378
+ input: 11,
379
+ output: 55,
380
+ cacheRead: 1.1,
381
+ cacheWrite: 13.75,
382
+ },
383
+ contextWindow: 1000000,
384
+ maxTokens: 128000,
385
+ },
350
386
  "eu.anthropic.claude-haiku-4-5-20251001-v1:0": {
351
387
  id: "eu.anthropic.claude-haiku-4-5-20251001-v1:0",
352
388
  name: "Claude Haiku 4.5 (EU)",
@@ -469,6 +505,24 @@ export const MODELS = {
469
505
  contextWindow: 1000000,
470
506
  maxTokens: 64000,
471
507
  },
508
+ "global.anthropic.claude-fable-5": {
509
+ id: "global.anthropic.claude-fable-5",
510
+ name: "Claude Fable 5 (Global)",
511
+ api: "bedrock-converse-stream",
512
+ provider: "amazon-bedrock",
513
+ baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
514
+ reasoning: true,
515
+ thinkingLevelMap: { "xhigh": "xhigh" },
516
+ input: ["text", "image"],
517
+ cost: {
518
+ input: 10,
519
+ output: 50,
520
+ cacheRead: 1,
521
+ cacheWrite: 12.5,
522
+ },
523
+ contextWindow: 1000000,
524
+ maxTokens: 128000,
525
+ },
472
526
  "global.anthropic.claude-haiku-4-5-20251001-v1:0": {
473
527
  id: "global.anthropic.claude-haiku-4-5-20251001-v1:0",
474
528
  name: "Claude Haiku 4.5 (Global)",
@@ -1128,7 +1182,7 @@ export const MODELS = {
1128
1182
  api: "bedrock-converse-stream",
1129
1183
  provider: "amazon-bedrock",
1130
1184
  baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
1131
- reasoning: false,
1185
+ reasoning: true,
1132
1186
  input: ["text"],
1133
1187
  cost: {
1134
1188
  input: 0.15,
@@ -1145,7 +1199,7 @@ export const MODELS = {
1145
1199
  api: "bedrock-converse-stream",
1146
1200
  provider: "amazon-bedrock",
1147
1201
  baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
1148
- reasoning: false,
1202
+ reasoning: true,
1149
1203
  input: ["text"],
1150
1204
  cost: {
1151
1205
  input: 0.15,
@@ -1162,7 +1216,7 @@ export const MODELS = {
1162
1216
  api: "bedrock-converse-stream",
1163
1217
  provider: "amazon-bedrock",
1164
1218
  baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
1165
- reasoning: false,
1219
+ reasoning: true,
1166
1220
  input: ["text"],
1167
1221
  cost: {
1168
1222
  input: 0.07,
@@ -1179,7 +1233,7 @@ export const MODELS = {
1179
1233
  api: "bedrock-converse-stream",
1180
1234
  provider: "amazon-bedrock",
1181
1235
  baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
1182
- reasoning: false,
1236
+ reasoning: true,
1183
1237
  input: ["text"],
1184
1238
  cost: {
1185
1239
  input: 0.07,
@@ -1343,6 +1397,24 @@ export const MODELS = {
1343
1397
  contextWindow: 262000,
1344
1398
  maxTokens: 262000,
1345
1399
  },
1400
+ "us.anthropic.claude-fable-5": {
1401
+ id: "us.anthropic.claude-fable-5",
1402
+ name: "Claude Fable 5 (US)",
1403
+ api: "bedrock-converse-stream",
1404
+ provider: "amazon-bedrock",
1405
+ baseUrl: "https://bedrock-runtime.us-east-1.amazonaws.com",
1406
+ reasoning: true,
1407
+ thinkingLevelMap: { "xhigh": "xhigh" },
1408
+ input: ["text", "image"],
1409
+ cost: {
1410
+ input: 10,
1411
+ output: 50,
1412
+ cacheRead: 1,
1413
+ cacheWrite: 12.5,
1414
+ },
1415
+ contextWindow: 1000000,
1416
+ maxTokens: 128000,
1417
+ },
1346
1418
  "us.anthropic.claude-haiku-4-5-20251001-v1:0": {
1347
1419
  id: "us.anthropic.claude-haiku-4-5-20251001-v1:0",
1348
1420
  name: "Claude Haiku 4.5 (US)",
@@ -1756,6 +1828,25 @@ export const MODELS = {
1756
1828
  contextWindow: 200000,
1757
1829
  maxTokens: 4096,
1758
1830
  },
1831
+ "claude-fable-5": {
1832
+ id: "claude-fable-5",
1833
+ name: "Claude Fable 5",
1834
+ api: "anthropic-messages",
1835
+ provider: "anthropic",
1836
+ baseUrl: "https://api.anthropic.com",
1837
+ compat: { "forceAdaptiveThinking": true },
1838
+ reasoning: true,
1839
+ thinkingLevelMap: { "xhigh": "xhigh" },
1840
+ input: ["text", "image"],
1841
+ cost: {
1842
+ input: 10,
1843
+ output: 50,
1844
+ cacheRead: 1,
1845
+ cacheWrite: 12.5,
1846
+ },
1847
+ contextWindow: 1000000,
1848
+ maxTokens: 128000,
1849
+ },
1759
1850
  "claude-haiku-4-5": {
1760
1851
  id: "claude-haiku-4-5",
1761
1852
  name: "Claude Haiku 4.5 (latest)",
@@ -2054,39 +2145,24 @@ export const MODELS = {
2054
2145
  contextWindow: 200000,
2055
2146
  maxTokens: 8192,
2056
2147
  },
2057
- "claude-3-5-sonnet@20241022": {
2058
- id: "claude-3-5-sonnet@20241022",
2059
- name: "Claude Sonnet 3.5 v2 (Vertex)",
2060
- api: "anthropic-vertex",
2061
- provider: "anthropic-vertex",
2062
- baseUrl: "https://{location}-aiplatform.googleapis.com",
2063
- reasoning: false,
2064
- input: ["text", "image"],
2065
- cost: {
2066
- input: 3,
2067
- output: 15,
2068
- cacheRead: 0.3,
2069
- cacheWrite: 3.75,
2070
- },
2071
- contextWindow: 200000,
2072
- maxTokens: 8192,
2073
- },
2074
- "claude-3-7-sonnet@20250219": {
2075
- id: "claude-3-7-sonnet@20250219",
2076
- name: "Claude Sonnet 3.7 (Vertex)",
2148
+ "claude-fable-5": {
2149
+ id: "claude-fable-5",
2150
+ name: "Claude Fable 5 (Vertex)",
2077
2151
  api: "anthropic-vertex",
2078
2152
  provider: "anthropic-vertex",
2079
2153
  baseUrl: "https://{location}-aiplatform.googleapis.com",
2154
+ compat: { "forceAdaptiveThinking": true },
2080
2155
  reasoning: true,
2156
+ thinkingLevelMap: { "xhigh": "xhigh" },
2081
2157
  input: ["text", "image"],
2082
2158
  cost: {
2083
- input: 3,
2084
- output: 15,
2085
- cacheRead: 0.3,
2086
- cacheWrite: 3.75,
2159
+ input: 10,
2160
+ output: 50,
2161
+ cacheRead: 1,
2162
+ cacheWrite: 12.5,
2087
2163
  },
2088
- contextWindow: 200000,
2089
- maxTokens: 64000,
2164
+ contextWindow: 1000000,
2165
+ maxTokens: 128000,
2090
2166
  },
2091
2167
  "claude-haiku-4-5@20251001": {
2092
2168
  id: "claude-haiku-4-5@20251001",
@@ -3016,30 +3092,13 @@ export const MODELS = {
3016
3092
  reasoning: true,
3017
3093
  input: ["text"],
3018
3094
  cost: {
3019
- input: 0.25,
3020
- output: 0.69,
3095
+ input: 0.35,
3096
+ output: 0.75,
3021
3097
  cacheRead: 0,
3022
3098
  cacheWrite: 0,
3023
3099
  },
3024
3100
  contextWindow: 131072,
3025
- maxTokens: 32768,
3026
- },
3027
- "llama3.1-8b": {
3028
- id: "llama3.1-8b",
3029
- name: "Llama 3.1 8B",
3030
- api: "openai-completions",
3031
- provider: "cerebras",
3032
- baseUrl: "https://api.cerebras.ai/v1",
3033
- reasoning: false,
3034
- input: ["text"],
3035
- cost: {
3036
- input: 0.1,
3037
- output: 0.1,
3038
- cacheRead: 0,
3039
- cacheWrite: 0,
3040
- },
3041
- contextWindow: 32000,
3042
- maxTokens: 8000,
3101
+ maxTokens: 40960,
3043
3102
  },
3044
3103
  "zai-glm-4.7": {
3045
3104
  id: "zai-glm-4.7",
@@ -3047,7 +3106,7 @@ export const MODELS = {
3047
3106
  api: "openai-completions",
3048
3107
  provider: "cerebras",
3049
3108
  baseUrl: "https://api.cerebras.ai/v1",
3050
- reasoning: false,
3109
+ reasoning: true,
3051
3110
  input: ["text"],
3052
3111
  cost: {
3053
3112
  input: 2.25,
@@ -3056,7 +3115,7 @@ export const MODELS = {
3056
3115
  cacheWrite: 0,
3057
3116
  },
3058
3117
  contextWindow: 131072,
3059
- maxTokens: 40000,
3118
+ maxTokens: 40960,
3060
3119
  },
3061
3120
  },
3062
3121
  "cloudflare-ai-gateway": {
@@ -3162,6 +3221,25 @@ export const MODELS = {
3162
3221
  contextWindow: 200000,
3163
3222
  maxTokens: 8192,
3164
3223
  },
3224
+ "claude-fable-5": {
3225
+ id: "claude-fable-5",
3226
+ name: "Claude Fable 5",
3227
+ api: "anthropic-messages",
3228
+ provider: "cloudflare-ai-gateway",
3229
+ baseUrl: "https://gateway.ai.cloudflare.com/v1/{CLOUDFLARE_ACCOUNT_ID}/{CLOUDFLARE_GATEWAY_ID}/anthropic",
3230
+ compat: { "forceAdaptiveThinking": true },
3231
+ reasoning: true,
3232
+ thinkingLevelMap: { "xhigh": "xhigh" },
3233
+ input: ["text", "image"],
3234
+ cost: {
3235
+ input: 10,
3236
+ output: 50,
3237
+ cacheRead: 1,
3238
+ cacheWrite: 12.5,
3239
+ },
3240
+ contextWindow: 1000000,
3241
+ maxTokens: 128000,
3242
+ },
3165
3243
  "claude-haiku-4-5": {
3166
3244
  id: "claude-haiku-4-5",
3167
3245
  name: "Claude Haiku 4.5 (latest)",
@@ -4168,6 +4246,26 @@ export const MODELS = {
4168
4246
  },
4169
4247
  },
4170
4248
  "github-copilot": {
4249
+ "claude-fable-5": {
4250
+ id: "claude-fable-5",
4251
+ name: "Claude Fable 5",
4252
+ api: "openai-completions",
4253
+ provider: "github-copilot",
4254
+ baseUrl: "https://api.individual.githubcopilot.com",
4255
+ headers: { "User-Agent": "GitHubCopilotChat/0.35.0", "Editor-Version": "vscode/1.107.0", "Editor-Plugin-Version": "copilot-chat/0.35.0", "Copilot-Integration-Id": "vscode-chat" },
4256
+ compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false },
4257
+ reasoning: true,
4258
+ thinkingLevelMap: { "xhigh": "xhigh" },
4259
+ input: ["text", "image"],
4260
+ cost: {
4261
+ input: 10,
4262
+ output: 50,
4263
+ cacheRead: 1,
4264
+ cacheWrite: 12.5,
4265
+ },
4266
+ contextWindow: 1000000,
4267
+ maxTokens: 128000,
4268
+ },
4171
4269
  "claude-haiku-4.5": {
4172
4270
  id: "claude-haiku-4.5",
4173
4271
  name: "Claude Haiku 4.5 (latest)",
@@ -5100,312 +5198,125 @@ export const MODELS = {
5100
5198
  },
5101
5199
  },
5102
5200
  "groq": {
5103
- "deepseek-r1-distill-llama-70b": {
5104
- id: "deepseek-r1-distill-llama-70b",
5105
- name: "DeepSeek R1 Distill Llama 70B",
5201
+ "llama-3.1-8b-instant": {
5202
+ id: "llama-3.1-8b-instant",
5203
+ name: "Llama 3.1 8B",
5106
5204
  api: "openai-completions",
5107
5205
  provider: "groq",
5108
5206
  baseUrl: "https://api.groq.com/openai/v1",
5109
- reasoning: true,
5207
+ reasoning: false,
5110
5208
  input: ["text"],
5111
5209
  cost: {
5112
- input: 0.75,
5113
- output: 0.99,
5210
+ input: 0.05,
5211
+ output: 0.08,
5114
5212
  cacheRead: 0,
5115
5213
  cacheWrite: 0,
5116
5214
  },
5117
5215
  contextWindow: 131072,
5118
- maxTokens: 8192,
5216
+ maxTokens: 131072,
5119
5217
  },
5120
- "gemma2-9b-it": {
5121
- id: "gemma2-9b-it",
5122
- name: "Gemma 2 9B",
5218
+ "llama-3.3-70b-versatile": {
5219
+ id: "llama-3.3-70b-versatile",
5220
+ name: "Llama 3.3 70B",
5123
5221
  api: "openai-completions",
5124
5222
  provider: "groq",
5125
5223
  baseUrl: "https://api.groq.com/openai/v1",
5126
5224
  reasoning: false,
5127
5225
  input: ["text"],
5128
5226
  cost: {
5129
- input: 0.2,
5130
- output: 0.2,
5227
+ input: 0.59,
5228
+ output: 0.79,
5131
5229
  cacheRead: 0,
5132
5230
  cacheWrite: 0,
5133
5231
  },
5134
- contextWindow: 8192,
5135
- maxTokens: 8192,
5232
+ contextWindow: 131072,
5233
+ maxTokens: 32768,
5136
5234
  },
5137
- "groq/compound": {
5138
- id: "groq/compound",
5139
- name: "Compound",
5235
+ "meta-llama/llama-4-scout-17b-16e-instruct": {
5236
+ id: "meta-llama/llama-4-scout-17b-16e-instruct",
5237
+ name: "Llama 4 Scout 17B 16E",
5140
5238
  api: "openai-completions",
5141
5239
  provider: "groq",
5142
5240
  baseUrl: "https://api.groq.com/openai/v1",
5143
- reasoning: true,
5144
- input: ["text"],
5241
+ reasoning: false,
5242
+ input: ["text", "image"],
5145
5243
  cost: {
5146
- input: 0,
5147
- output: 0,
5244
+ input: 0.11,
5245
+ output: 0.34,
5148
5246
  cacheRead: 0,
5149
5247
  cacheWrite: 0,
5150
5248
  },
5151
5249
  contextWindow: 131072,
5152
5250
  maxTokens: 8192,
5153
5251
  },
5154
- "groq/compound-mini": {
5155
- id: "groq/compound-mini",
5156
- name: "Compound Mini",
5252
+ "openai/gpt-oss-120b": {
5253
+ id: "openai/gpt-oss-120b",
5254
+ name: "GPT OSS 120B",
5157
5255
  api: "openai-completions",
5158
5256
  provider: "groq",
5159
5257
  baseUrl: "https://api.groq.com/openai/v1",
5160
5258
  reasoning: true,
5161
5259
  input: ["text"],
5162
5260
  cost: {
5163
- input: 0,
5164
- output: 0,
5165
- cacheRead: 0,
5261
+ input: 0.15,
5262
+ output: 0.6,
5263
+ cacheRead: 0.075,
5166
5264
  cacheWrite: 0,
5167
5265
  },
5168
5266
  contextWindow: 131072,
5169
- maxTokens: 8192,
5267
+ maxTokens: 65536,
5170
5268
  },
5171
- "llama-3.1-8b-instant": {
5172
- id: "llama-3.1-8b-instant",
5173
- name: "Llama 3.1 8B Instant",
5269
+ "openai/gpt-oss-20b": {
5270
+ id: "openai/gpt-oss-20b",
5271
+ name: "GPT OSS 20B",
5174
5272
  api: "openai-completions",
5175
5273
  provider: "groq",
5176
5274
  baseUrl: "https://api.groq.com/openai/v1",
5177
- reasoning: false,
5275
+ reasoning: true,
5178
5276
  input: ["text"],
5179
5277
  cost: {
5180
- input: 0.05,
5181
- output: 0.08,
5182
- cacheRead: 0,
5278
+ input: 0.075,
5279
+ output: 0.3,
5280
+ cacheRead: 0.0375,
5183
5281
  cacheWrite: 0,
5184
5282
  },
5185
5283
  contextWindow: 131072,
5186
- maxTokens: 131072,
5284
+ maxTokens: 65536,
5187
5285
  },
5188
- "llama-3.3-70b-versatile": {
5189
- id: "llama-3.3-70b-versatile",
5190
- name: "Llama 3.3 70B Versatile",
5286
+ "openai/gpt-oss-safeguard-20b": {
5287
+ id: "openai/gpt-oss-safeguard-20b",
5288
+ name: "Safety GPT OSS 20B",
5191
5289
  api: "openai-completions",
5192
5290
  provider: "groq",
5193
5291
  baseUrl: "https://api.groq.com/openai/v1",
5194
- reasoning: false,
5292
+ reasoning: true,
5195
5293
  input: ["text"],
5196
5294
  cost: {
5197
- input: 0.59,
5198
- output: 0.79,
5199
- cacheRead: 0,
5295
+ input: 0.075,
5296
+ output: 0.3,
5297
+ cacheRead: 0.037,
5200
5298
  cacheWrite: 0,
5201
5299
  },
5202
5300
  contextWindow: 131072,
5203
- maxTokens: 32768,
5301
+ maxTokens: 65536,
5204
5302
  },
5205
- "llama3-70b-8192": {
5206
- id: "llama3-70b-8192",
5207
- name: "Llama 3 70B",
5303
+ "qwen/qwen3-32b": {
5304
+ id: "qwen/qwen3-32b",
5305
+ name: "Qwen3-32B",
5208
5306
  api: "openai-completions",
5209
5307
  provider: "groq",
5210
5308
  baseUrl: "https://api.groq.com/openai/v1",
5211
- reasoning: false,
5309
+ reasoning: true,
5310
+ thinkingLevelMap: { "minimal": null, "low": null, "medium": null, "high": "default" },
5212
5311
  input: ["text"],
5213
5312
  cost: {
5214
- input: 0.59,
5215
- output: 0.79,
5313
+ input: 0.29,
5314
+ output: 0.59,
5216
5315
  cacheRead: 0,
5217
5316
  cacheWrite: 0,
5218
5317
  },
5219
- contextWindow: 8192,
5220
- maxTokens: 8192,
5221
- },
5222
- "llama3-8b-8192": {
5223
- id: "llama3-8b-8192",
5224
- name: "Llama 3 8B",
5225
- api: "openai-completions",
5226
- provider: "groq",
5227
- baseUrl: "https://api.groq.com/openai/v1",
5228
- reasoning: false,
5229
- input: ["text"],
5230
- cost: {
5231
- input: 0.05,
5232
- output: 0.08,
5233
- cacheRead: 0,
5234
- cacheWrite: 0,
5235
- },
5236
- contextWindow: 8192,
5237
- maxTokens: 8192,
5238
- },
5239
- "meta-llama/llama-4-maverick-17b-128e-instruct": {
5240
- id: "meta-llama/llama-4-maverick-17b-128e-instruct",
5241
- name: "Llama 4 Maverick 17B",
5242
- api: "openai-completions",
5243
- provider: "groq",
5244
- baseUrl: "https://api.groq.com/openai/v1",
5245
- reasoning: false,
5246
- input: ["text", "image"],
5247
- cost: {
5248
- input: 0.2,
5249
- output: 0.6,
5250
- cacheRead: 0,
5251
- cacheWrite: 0,
5252
- },
5253
- contextWindow: 131072,
5254
- maxTokens: 8192,
5255
- },
5256
- "meta-llama/llama-4-scout-17b-16e-instruct": {
5257
- id: "meta-llama/llama-4-scout-17b-16e-instruct",
5258
- name: "Llama 4 Scout 17B",
5259
- api: "openai-completions",
5260
- provider: "groq",
5261
- baseUrl: "https://api.groq.com/openai/v1",
5262
- reasoning: false,
5263
- input: ["text", "image"],
5264
- cost: {
5265
- input: 0.11,
5266
- output: 0.34,
5267
- cacheRead: 0,
5268
- cacheWrite: 0,
5269
- },
5270
- contextWindow: 131072,
5271
- maxTokens: 8192,
5272
- },
5273
- "mistral-saba-24b": {
5274
- id: "mistral-saba-24b",
5275
- name: "Mistral Saba 24B",
5276
- api: "openai-completions",
5277
- provider: "groq",
5278
- baseUrl: "https://api.groq.com/openai/v1",
5279
- reasoning: false,
5280
- input: ["text"],
5281
- cost: {
5282
- input: 0.79,
5283
- output: 0.79,
5284
- cacheRead: 0,
5285
- cacheWrite: 0,
5286
- },
5287
- contextWindow: 32768,
5288
- maxTokens: 32768,
5289
- },
5290
- "moonshotai/kimi-k2-instruct": {
5291
- id: "moonshotai/kimi-k2-instruct",
5292
- name: "Kimi K2 Instruct",
5293
- api: "openai-completions",
5294
- provider: "groq",
5295
- baseUrl: "https://api.groq.com/openai/v1",
5296
- reasoning: false,
5297
- input: ["text"],
5298
- cost: {
5299
- input: 1,
5300
- output: 3,
5301
- cacheRead: 0,
5302
- cacheWrite: 0,
5303
- },
5304
- contextWindow: 131072,
5305
- maxTokens: 16384,
5306
- },
5307
- "moonshotai/kimi-k2-instruct-0905": {
5308
- id: "moonshotai/kimi-k2-instruct-0905",
5309
- name: "Kimi K2 Instruct 0905",
5310
- api: "openai-completions",
5311
- provider: "groq",
5312
- baseUrl: "https://api.groq.com/openai/v1",
5313
- reasoning: false,
5314
- input: ["text"],
5315
- cost: {
5316
- input: 1,
5317
- output: 3,
5318
- cacheRead: 0.5,
5319
- cacheWrite: 0,
5320
- },
5321
- contextWindow: 262144,
5322
- maxTokens: 16384,
5323
- },
5324
- "openai/gpt-oss-120b": {
5325
- id: "openai/gpt-oss-120b",
5326
- name: "GPT OSS 120B",
5327
- api: "openai-completions",
5328
- provider: "groq",
5329
- baseUrl: "https://api.groq.com/openai/v1",
5330
- reasoning: true,
5331
- input: ["text"],
5332
- cost: {
5333
- input: 0.15,
5334
- output: 0.6,
5335
- cacheRead: 0.075,
5336
- cacheWrite: 0,
5337
- },
5338
- contextWindow: 131072,
5339
- maxTokens: 65536,
5340
- },
5341
- "openai/gpt-oss-20b": {
5342
- id: "openai/gpt-oss-20b",
5343
- name: "GPT OSS 20B",
5344
- api: "openai-completions",
5345
- provider: "groq",
5346
- baseUrl: "https://api.groq.com/openai/v1",
5347
- reasoning: true,
5348
- input: ["text"],
5349
- cost: {
5350
- input: 0.075,
5351
- output: 0.3,
5352
- cacheRead: 0.0375,
5353
- cacheWrite: 0,
5354
- },
5355
- contextWindow: 131072,
5356
- maxTokens: 65536,
5357
- },
5358
- "openai/gpt-oss-safeguard-20b": {
5359
- id: "openai/gpt-oss-safeguard-20b",
5360
- name: "Safety GPT OSS 20B",
5361
- api: "openai-completions",
5362
- provider: "groq",
5363
- baseUrl: "https://api.groq.com/openai/v1",
5364
- reasoning: true,
5365
- input: ["text"],
5366
- cost: {
5367
- input: 0.075,
5368
- output: 0.3,
5369
- cacheRead: 0.037,
5370
- cacheWrite: 0,
5371
- },
5372
- contextWindow: 131072,
5373
- maxTokens: 65536,
5374
- },
5375
- "qwen-qwq-32b": {
5376
- id: "qwen-qwq-32b",
5377
- name: "Qwen QwQ 32B",
5378
- api: "openai-completions",
5379
- provider: "groq",
5380
- baseUrl: "https://api.groq.com/openai/v1",
5381
- reasoning: true,
5382
- input: ["text"],
5383
- cost: {
5384
- input: 0.29,
5385
- output: 0.39,
5386
- cacheRead: 0,
5387
- cacheWrite: 0,
5388
- },
5389
- contextWindow: 131072,
5390
- maxTokens: 16384,
5391
- },
5392
- "qwen/qwen3-32b": {
5393
- id: "qwen/qwen3-32b",
5394
- name: "Qwen3 32B",
5395
- api: "openai-completions",
5396
- provider: "groq",
5397
- baseUrl: "https://api.groq.com/openai/v1",
5398
- reasoning: true,
5399
- thinkingLevelMap: { "minimal": null, "low": null, "medium": null, "high": "default" },
5400
- input: ["text"],
5401
- cost: {
5402
- input: 0.29,
5403
- output: 0.59,
5404
- cacheRead: 0,
5405
- cacheWrite: 0,
5406
- },
5407
- contextWindow: 131072,
5408
- maxTokens: 40960,
5318
+ contextWindow: 131072,
5319
+ maxTokens: 40960,
5409
5320
  },
5410
5321
  },
5411
5322
  "huggingface": {
@@ -7586,6 +7497,25 @@ export const MODELS = {
7586
7497
  contextWindow: 200000,
7587
7498
  maxTokens: 32000,
7588
7499
  },
7500
+ "claude-fable-5": {
7501
+ id: "claude-fable-5",
7502
+ name: "Claude Fable 5",
7503
+ api: "anthropic-messages",
7504
+ provider: "opencode",
7505
+ baseUrl: "https://opencode.ai/zen",
7506
+ compat: { "forceAdaptiveThinking": true },
7507
+ reasoning: true,
7508
+ thinkingLevelMap: { "xhigh": "xhigh" },
7509
+ input: ["text", "image"],
7510
+ cost: {
7511
+ input: 10,
7512
+ output: 50,
7513
+ cacheRead: 1,
7514
+ cacheWrite: 12.5,
7515
+ },
7516
+ contextWindow: 1000000,
7517
+ maxTokens: 128000,
7518
+ },
7589
7519
  "claude-haiku-4-5": {
7590
7520
  id: "claude-haiku-4-5",
7591
7521
  name: "Claude Haiku 4.5",
@@ -7759,7 +7689,7 @@ export const MODELS = {
7759
7689
  cost: {
7760
7690
  input: 0.14,
7761
7691
  output: 0.28,
7762
- cacheRead: 0.03,
7692
+ cacheRead: 0.028,
7763
7693
  cacheWrite: 0,
7764
7694
  },
7765
7695
  contextWindow: 1000000,
@@ -7784,6 +7714,25 @@ export const MODELS = {
7784
7714
  contextWindow: 200000,
7785
7715
  maxTokens: 128000,
7786
7716
  },
7717
+ "deepseek-v4-pro": {
7718
+ id: "deepseek-v4-pro",
7719
+ name: "DeepSeek V4 Pro",
7720
+ api: "openai-completions",
7721
+ provider: "opencode",
7722
+ baseUrl: "https://opencode.ai/zen/v1",
7723
+ compat: { "requiresReasoningContentOnAssistantMessages": true, "thinkingFormat": "deepseek" },
7724
+ reasoning: true,
7725
+ thinkingLevelMap: { "minimal": null, "low": null, "medium": null, "high": "high", "xhigh": "max" },
7726
+ input: ["text"],
7727
+ cost: {
7728
+ input: 1.74,
7729
+ output: 3.84,
7730
+ cacheRead: 0.145,
7731
+ cacheWrite: 0,
7732
+ },
7733
+ contextWindow: 1000000,
7734
+ maxTokens: 384000,
7735
+ },
7787
7736
  "gemini-3-flash": {
7788
7737
  id: "gemini-3-flash",
7789
7738
  name: "Gemini 3 Flash",
@@ -8262,26 +8211,26 @@ export const MODELS = {
8262
8211
  contextWindow: 204800,
8263
8212
  maxTokens: 131072,
8264
8213
  },
8265
- "minimax-m3-free": {
8266
- id: "minimax-m3-free",
8267
- name: "MiniMax M3 Free",
8268
- api: "anthropic-messages",
8214
+ "nemotron-3-ultra-free": {
8215
+ id: "nemotron-3-ultra-free",
8216
+ name: "Nemotron 3 Ultra Free",
8217
+ api: "openai-completions",
8269
8218
  provider: "opencode",
8270
- baseUrl: "https://opencode.ai/zen",
8219
+ baseUrl: "https://opencode.ai/zen/v1",
8271
8220
  reasoning: true,
8272
- input: ["text", "image"],
8221
+ input: ["text"],
8273
8222
  cost: {
8274
8223
  input: 0,
8275
8224
  output: 0,
8276
8225
  cacheRead: 0,
8277
8226
  cacheWrite: 0,
8278
8227
  },
8279
- contextWindow: 200000,
8280
- maxTokens: 32000,
8228
+ contextWindow: 1000000,
8229
+ maxTokens: 128000,
8281
8230
  },
8282
- "nemotron-3-ultra-free": {
8283
- id: "nemotron-3-ultra-free",
8284
- name: "Nemotron 3 Ultra Free",
8231
+ "north-mini-code-free": {
8232
+ id: "north-mini-code-free",
8233
+ name: "North Mini Code Free",
8285
8234
  api: "openai-completions",
8286
8235
  provider: "opencode",
8287
8236
  baseUrl: "https://opencode.ai/zen/v1",
@@ -8293,8 +8242,8 @@ export const MODELS = {
8293
8242
  cacheRead: 0,
8294
8243
  cacheWrite: 0,
8295
8244
  },
8296
- contextWindow: 1000000,
8297
- maxTokens: 128000,
8245
+ contextWindow: 256000,
8246
+ maxTokens: 64000,
8298
8247
  },
8299
8248
  "qwen3.5-plus": {
8300
8249
  id: "qwen3.5-plus",
@@ -8515,9 +8464,9 @@ export const MODELS = {
8515
8464
  reasoning: true,
8516
8465
  input: ["text", "image"],
8517
8466
  cost: {
8518
- input: 0.6,
8519
- output: 2.4,
8520
- cacheRead: 0.12,
8467
+ input: 0.3,
8468
+ output: 1.2,
8469
+ cacheRead: 0.06,
8521
8470
  cacheWrite: 0,
8522
8471
  },
8523
8472
  contextWindow: 512000,
@@ -8713,6 +8662,24 @@ export const MODELS = {
8713
8662
  contextWindow: 200000,
8714
8663
  maxTokens: 8192,
8715
8664
  },
8665
+ "anthropic/claude-fable-5": {
8666
+ id: "anthropic/claude-fable-5",
8667
+ name: "Anthropic: Claude Fable 5",
8668
+ api: "openai-completions",
8669
+ provider: "openrouter",
8670
+ baseUrl: "https://openrouter.ai/api/v1",
8671
+ reasoning: true,
8672
+ thinkingLevelMap: { "xhigh": "xhigh" },
8673
+ input: ["text", "image"],
8674
+ cost: {
8675
+ input: 10,
8676
+ output: 50,
8677
+ cacheRead: 1,
8678
+ cacheWrite: 12.5,
8679
+ },
8680
+ contextWindow: 1000000,
8681
+ maxTokens: 128000,
8682
+ },
8716
8683
  "anthropic/claude-haiku-4.5": {
8717
8684
  id: "anthropic/claude-haiku-4.5",
8718
8685
  name: "Anthropic: Claude Haiku 4.5",
@@ -9141,7 +9108,7 @@ export const MODELS = {
9141
9108
  cacheRead: 0.135,
9142
9109
  cacheWrite: 0,
9143
9110
  },
9144
- contextWindow: 163840,
9111
+ contextWindow: 131072,
9145
9112
  maxTokens: 16384,
9146
9113
  },
9147
9114
  "deepseek/deepseek-chat-v3.1": {
@@ -9583,12 +9550,12 @@ export const MODELS = {
9583
9550
  input: ["text", "image"],
9584
9551
  cost: {
9585
9552
  input: 0.12,
9586
- output: 0.36,
9553
+ output: 0.35,
9587
9554
  cacheRead: 0.09,
9588
9555
  cacheWrite: 0,
9589
9556
  },
9590
9557
  contextWindow: 262144,
9591
- maxTokens: 8192,
9558
+ maxTokens: 262144,
9592
9559
  },
9593
9560
  "google/gemma-4-31b-it:free": {
9594
9561
  id: "google/gemma-4-31b-it:free",
@@ -9873,8 +9840,8 @@ export const MODELS = {
9873
9840
  input: ["text"],
9874
9841
  cost: {
9875
9842
  input: 0.15,
9876
- output: 1.15,
9877
- cacheRead: 0,
9843
+ output: 0.9,
9844
+ cacheRead: 0.05,
9878
9845
  cacheWrite: 0,
9879
9846
  },
9880
9847
  contextWindow: 204800,
@@ -9889,13 +9856,13 @@ export const MODELS = {
9889
9856
  reasoning: true,
9890
9857
  input: ["text"],
9891
9858
  cost: {
9892
- input: 0.279,
9893
- output: 1.2,
9894
- cacheRead: 0,
9859
+ input: 0.25,
9860
+ output: 1,
9861
+ cacheRead: 0.05,
9895
9862
  cacheWrite: 0,
9896
9863
  },
9897
9864
  contextWindow: 204800,
9898
- maxTokens: 196608,
9865
+ maxTokens: 131072,
9899
9866
  },
9900
9867
  "minimax/minimax-m3": {
9901
9868
  id: "minimax/minimax-m3",
@@ -10280,17 +10247,17 @@ export const MODELS = {
10280
10247
  reasoning: true,
10281
10248
  input: ["text", "image"],
10282
10249
  cost: {
10283
- input: 0.684,
10284
- output: 3.42,
10285
- cacheRead: 0.144,
10250
+ input: 0.67,
10251
+ output: 3.39,
10252
+ cacheRead: 0.14,
10286
10253
  cacheWrite: 0,
10287
10254
  },
10288
10255
  contextWindow: 262144,
10289
10256
  maxTokens: 262144,
10290
10257
  },
10291
- "moonshotai/kimi-k2.6:free": {
10292
- id: "moonshotai/kimi-k2.6:free",
10293
- name: "MoonshotAI: Kimi K2.6 (free)",
10258
+ "nex-agi/nex-n2-pro:free": {
10259
+ id: "nex-agi/nex-n2-pro:free",
10260
+ name: "Nex AGI: Nex-N2-Pro (free)",
10294
10261
  api: "openai-completions",
10295
10262
  provider: "openrouter",
10296
10263
  baseUrl: "https://openrouter.ai/api/v1",
@@ -10303,24 +10270,7 @@ export const MODELS = {
10303
10270
  cacheWrite: 0,
10304
10271
  },
10305
10272
  contextWindow: 262144,
10306
- maxTokens: 4096,
10307
- },
10308
- "nex-agi/deepseek-v3.1-nex-n1": {
10309
- id: "nex-agi/deepseek-v3.1-nex-n1",
10310
- name: "Nex AGI: DeepSeek V3.1 Nex N1",
10311
- api: "openai-completions",
10312
- provider: "openrouter",
10313
- baseUrl: "https://openrouter.ai/api/v1",
10314
- reasoning: false,
10315
- input: ["text"],
10316
- cost: {
10317
- input: 0.135,
10318
- output: 0.5,
10319
- cacheRead: 0,
10320
- cacheWrite: 0,
10321
- },
10322
- contextWindow: 131072,
10323
- maxTokens: 163840,
10273
+ maxTokens: 262144,
10324
10274
  },
10325
10275
  "nvidia/llama-3.3-nemotron-super-49b-v1.5": {
10326
10276
  id: "nvidia/llama-3.3-nemotron-super-49b-v1.5",
@@ -10475,23 +10425,6 @@ export const MODELS = {
10475
10425
  contextWindow: 128000,
10476
10426
  maxTokens: 128000,
10477
10427
  },
10478
- "nvidia/nemotron-nano-9b-v2": {
10479
- id: "nvidia/nemotron-nano-9b-v2",
10480
- name: "NVIDIA: Nemotron Nano 9B V2",
10481
- api: "openai-completions",
10482
- provider: "openrouter",
10483
- baseUrl: "https://openrouter.ai/api/v1",
10484
- reasoning: true,
10485
- input: ["text"],
10486
- cost: {
10487
- input: 0.04,
10488
- output: 0.16,
10489
- cacheRead: 0,
10490
- cacheWrite: 0,
10491
- },
10492
- contextWindow: 131072,
10493
- maxTokens: 16384,
10494
- },
10495
10428
  "nvidia/nemotron-nano-9b-v2:free": {
10496
10429
  id: "nvidia/nemotron-nano-9b-v2:free",
10497
10430
  name: "NVIDIA: Nemotron Nano 9B V2 (free)",
@@ -12230,13 +12163,13 @@ export const MODELS = {
12230
12163
  reasoning: true,
12231
12164
  input: ["text", "image"],
12232
12165
  cost: {
12233
- input: 0.14,
12166
+ input: 0.15,
12234
12167
  output: 1,
12235
- cacheRead: 0,
12168
+ cacheRead: 0.05,
12236
12169
  cacheWrite: 0,
12237
12170
  },
12238
12171
  contextWindow: 262144,
12239
- maxTokens: 262140,
12172
+ maxTokens: 262144,
12240
12173
  },
12241
12174
  "qwen/qwen3.6-flash": {
12242
12175
  id: "qwen/qwen3.6-flash",
@@ -12315,10 +12248,10 @@ export const MODELS = {
12315
12248
  reasoning: true,
12316
12249
  input: ["text", "image"],
12317
12250
  cost: {
12318
- input: 0.4,
12319
- output: 1.6,
12320
- cacheRead: 0.08,
12321
- cacheWrite: 0.5,
12251
+ input: 0.32,
12252
+ output: 1.28,
12253
+ cacheRead: 0.064,
12254
+ cacheWrite: 0.4,
12322
12255
  },
12323
12256
  contextWindow: 1000000,
12324
12257
  maxTokens: 65536,
@@ -12578,23 +12511,6 @@ export const MODELS = {
12578
12511
  contextWindow: 1048576,
12579
12512
  maxTokens: 131072,
12580
12513
  },
12581
- "z-ai/glm-4-32b": {
12582
- id: "z-ai/glm-4-32b",
12583
- name: "Z.ai: GLM 4 32B ",
12584
- api: "openai-completions",
12585
- provider: "openrouter",
12586
- baseUrl: "https://openrouter.ai/api/v1",
12587
- reasoning: false,
12588
- input: ["text"],
12589
- cost: {
12590
- input: 0.1,
12591
- output: 0.1,
12592
- cacheRead: 0,
12593
- cacheWrite: 0,
12594
- },
12595
- contextWindow: 128000,
12596
- maxTokens: 4096,
12597
- },
12598
12514
  "z-ai/glm-4.5": {
12599
12515
  id: "z-ai/glm-4.5",
12600
12516
  name: "Z.ai: GLM 4.5",
@@ -12629,23 +12545,6 @@ export const MODELS = {
12629
12545
  contextWindow: 131072,
12630
12546
  maxTokens: 131070,
12631
12547
  },
12632
- "z-ai/glm-4.5-air:free": {
12633
- id: "z-ai/glm-4.5-air:free",
12634
- name: "Z.ai: GLM 4.5 Air (free)",
12635
- api: "openai-completions",
12636
- provider: "openrouter",
12637
- baseUrl: "https://openrouter.ai/api/v1",
12638
- reasoning: true,
12639
- input: ["text"],
12640
- cost: {
12641
- input: 0,
12642
- output: 0,
12643
- cacheRead: 0,
12644
- cacheWrite: 0,
12645
- },
12646
- contextWindow: 131072,
12647
- maxTokens: 96000,
12648
- },
12649
12548
  "z-ai/glm-4.5v": {
12650
12549
  id: "z-ai/glm-4.5v",
12651
12550
  name: "Z.ai: GLM 4.5V",
@@ -12691,11 +12590,11 @@ export const MODELS = {
12691
12590
  cost: {
12692
12591
  input: 0.3,
12693
12592
  output: 0.9,
12694
- cacheRead: 0.05,
12593
+ cacheRead: 0.055,
12695
12594
  cacheWrite: 0,
12696
12595
  },
12697
12596
  contextWindow: 131072,
12698
- maxTokens: 24000,
12597
+ maxTokens: 32768,
12699
12598
  },
12700
12599
  "z-ai/glm-4.7": {
12701
12600
  id: "z-ai/glm-4.7",
@@ -12762,7 +12661,7 @@ export const MODELS = {
12762
12661
  cacheRead: 0.24,
12763
12662
  cacheWrite: 0,
12764
12663
  },
12765
- contextWindow: 202752,
12664
+ contextWindow: 262144,
12766
12665
  maxTokens: 131072,
12767
12666
  },
12768
12667
  "z-ai/glm-5.1": {
@@ -12782,22 +12681,22 @@ export const MODELS = {
12782
12681
  contextWindow: 202752,
12783
12682
  maxTokens: 4096,
12784
12683
  },
12785
- "z-ai/glm-5v-turbo": {
12786
- id: "z-ai/glm-5v-turbo",
12787
- name: "Z.ai: GLM 5V Turbo",
12684
+ "~anthropic/claude-fable-latest": {
12685
+ id: "~anthropic/claude-fable-latest",
12686
+ name: "Anthropic: Claude Fable Latest",
12788
12687
  api: "openai-completions",
12789
12688
  provider: "openrouter",
12790
12689
  baseUrl: "https://openrouter.ai/api/v1",
12791
12690
  reasoning: true,
12792
12691
  input: ["text", "image"],
12793
12692
  cost: {
12794
- input: 1.2,
12795
- output: 4,
12796
- cacheRead: 0.24,
12797
- cacheWrite: 0,
12693
+ input: 10,
12694
+ output: 50,
12695
+ cacheRead: 1,
12696
+ cacheWrite: 12.5,
12798
12697
  },
12799
- contextWindow: 202752,
12800
- maxTokens: 131072,
12698
+ contextWindow: 1000000,
12699
+ maxTokens: 128000,
12801
12700
  },
12802
12701
  "~anthropic/claude-haiku-latest": {
12803
12702
  id: "~anthropic/claude-haiku-latest",
@@ -12893,9 +12792,9 @@ export const MODELS = {
12893
12792
  reasoning: true,
12894
12793
  input: ["text", "image"],
12895
12794
  cost: {
12896
- input: 0.684,
12897
- output: 3.42,
12898
- cacheRead: 0.144,
12795
+ input: 0.67,
12796
+ output: 3.39,
12797
+ cacheRead: 0.14,
12899
12798
  cacheWrite: 0,
12900
12799
  },
12901
12800
  contextWindow: 262144,
@@ -12937,25 +12836,6 @@ export const MODELS = {
12937
12836
  },
12938
12837
  },
12939
12838
  "together": {
12940
- "MiniMaxAI/MiniMax-M2.5": {
12941
- id: "MiniMaxAI/MiniMax-M2.5",
12942
- name: "MiniMax-M2.5",
12943
- api: "openai-completions",
12944
- provider: "together",
12945
- baseUrl: "https://api.together.ai/v1",
12946
- compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false },
12947
- reasoning: true,
12948
- thinkingLevelMap: { "off": null, "minimal": null, "low": null, "medium": null },
12949
- input: ["text"],
12950
- cost: {
12951
- input: 0.3,
12952
- output: 1.2,
12953
- cacheRead: 0.06,
12954
- cacheWrite: 0,
12955
- },
12956
- contextWindow: 204800,
12957
- maxTokens: 131072,
12958
- },
12959
12839
  "MiniMaxAI/MiniMax-M2.7": {
12960
12840
  id: "MiniMaxAI/MiniMax-M2.7",
12961
12841
  name: "MiniMax-M2.7",
@@ -12975,28 +12855,27 @@ export const MODELS = {
12975
12855
  contextWindow: 202752,
12976
12856
  maxTokens: 131072,
12977
12857
  },
12978
- "Qwen/Qwen3-235B-A22B-Instruct-2507-tput": {
12979
- id: "Qwen/Qwen3-235B-A22B-Instruct-2507-tput",
12980
- name: "Qwen3 235B A22B Instruct 2507 FP8",
12858
+ "Qwen/Qwen2.5-7B-Instruct-Turbo": {
12859
+ id: "Qwen/Qwen2.5-7B-Instruct-Turbo",
12860
+ name: "Qwen 2.5 7B Instruct Turbo",
12981
12861
  api: "openai-completions",
12982
12862
  provider: "together",
12983
12863
  baseUrl: "https://api.together.ai/v1",
12984
- compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
12985
- reasoning: true,
12986
- thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
12864
+ compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false },
12865
+ reasoning: false,
12987
12866
  input: ["text"],
12988
12867
  cost: {
12989
- input: 0.2,
12990
- output: 0.6,
12868
+ input: 0.3,
12869
+ output: 0.3,
12991
12870
  cacheRead: 0,
12992
12871
  cacheWrite: 0,
12993
12872
  },
12994
- contextWindow: 262144,
12995
- maxTokens: 262144,
12873
+ contextWindow: 32768,
12874
+ maxTokens: 32768,
12996
12875
  },
12997
- "Qwen/Qwen3-Coder-480B-A35B-Instruct-FP8": {
12998
- id: "Qwen/Qwen3-Coder-480B-A35B-Instruct-FP8",
12999
- name: "Qwen3 Coder 480B A35B Instruct",
12876
+ "Qwen/Qwen3-235B-A22B-Instruct-2507-tput": {
12877
+ id: "Qwen/Qwen3-235B-A22B-Instruct-2507-tput",
12878
+ name: "Qwen3 235B A22B Instruct 2507 FP8",
13000
12879
  api: "openai-completions",
13001
12880
  provider: "together",
13002
12881
  baseUrl: "https://api.together.ai/v1",
@@ -13004,36 +12883,36 @@ export const MODELS = {
13004
12883
  reasoning: false,
13005
12884
  input: ["text"],
13006
12885
  cost: {
13007
- input: 2,
13008
- output: 2,
12886
+ input: 0.2,
12887
+ output: 0.6,
13009
12888
  cacheRead: 0,
13010
12889
  cacheWrite: 0,
13011
12890
  },
13012
12891
  contextWindow: 262144,
13013
12892
  maxTokens: 262144,
13014
12893
  },
13015
- "Qwen/Qwen3-Coder-Next-FP8": {
13016
- id: "Qwen/Qwen3-Coder-Next-FP8",
13017
- name: "Qwen3 Coder Next FP8",
12894
+ "Qwen/Qwen3.5-397B-A17B": {
12895
+ id: "Qwen/Qwen3.5-397B-A17B",
12896
+ name: "Qwen3.5 397B A17B",
13018
12897
  api: "openai-completions",
13019
12898
  provider: "together",
13020
12899
  baseUrl: "https://api.together.ai/v1",
13021
12900
  compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
13022
12901
  reasoning: true,
13023
12902
  thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13024
- input: ["text"],
12903
+ input: ["text", "image"],
13025
12904
  cost: {
13026
- input: 0.5,
13027
- output: 1.2,
12905
+ input: 0.6,
12906
+ output: 3.6,
13028
12907
  cacheRead: 0,
13029
12908
  cacheWrite: 0,
13030
12909
  },
13031
12910
  contextWindow: 262144,
13032
- maxTokens: 262144,
12911
+ maxTokens: 130000,
13033
12912
  },
13034
- "Qwen/Qwen3.5-397B-A17B": {
13035
- id: "Qwen/Qwen3.5-397B-A17B",
13036
- name: "Qwen3.5 397B A17B",
12913
+ "Qwen/Qwen3.5-9B": {
12914
+ id: "Qwen/Qwen3.5-9B",
12915
+ name: "Qwen3.5 9B",
13037
12916
  api: "openai-completions",
13038
12917
  provider: "together",
13039
12918
  baseUrl: "https://api.together.ai/v1",
@@ -13042,13 +12921,13 @@ export const MODELS = {
13042
12921
  thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13043
12922
  input: ["text", "image"],
13044
12923
  cost: {
13045
- input: 0.6,
13046
- output: 3.6,
12924
+ input: 0.17,
12925
+ output: 0.25,
13047
12926
  cacheRead: 0,
13048
12927
  cacheWrite: 0,
13049
12928
  },
13050
12929
  contextWindow: 262144,
13051
- maxTokens: 130000,
12930
+ maxTokens: 65536,
13052
12931
  },
13053
12932
  "Qwen/Qwen3.6-Plus": {
13054
12933
  id: "Qwen/Qwen3.6-Plus",
@@ -13075,9 +12954,8 @@ export const MODELS = {
13075
12954
  api: "openai-completions",
13076
12955
  provider: "together",
13077
12956
  baseUrl: "https://api.together.ai/v1",
13078
- compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
13079
- reasoning: true,
13080
- thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
12957
+ compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false },
12958
+ reasoning: false,
13081
12959
  input: ["text"],
13082
12960
  cost: {
13083
12961
  input: 2.5,
@@ -13088,44 +12966,6 @@ export const MODELS = {
13088
12966
  contextWindow: 1000000,
13089
12967
  maxTokens: 500000,
13090
12968
  },
13091
- "deepseek-ai/DeepSeek-V3": {
13092
- id: "deepseek-ai/DeepSeek-V3",
13093
- name: "DeepSeek-V3",
13094
- api: "openai-completions",
13095
- provider: "together",
13096
- baseUrl: "https://api.together.ai/v1",
13097
- compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
13098
- reasoning: true,
13099
- thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13100
- input: ["text"],
13101
- cost: {
13102
- input: 1.25,
13103
- output: 1.25,
13104
- cacheRead: 0,
13105
- cacheWrite: 0,
13106
- },
13107
- contextWindow: 131072,
13108
- maxTokens: 131072,
13109
- },
13110
- "deepseek-ai/DeepSeek-V3-1": {
13111
- id: "deepseek-ai/DeepSeek-V3-1",
13112
- name: "DeepSeek V3.1",
13113
- api: "openai-completions",
13114
- provider: "together",
13115
- baseUrl: "https://api.together.ai/v1",
13116
- compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
13117
- reasoning: true,
13118
- thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13119
- input: ["text"],
13120
- cost: {
13121
- input: 0.6,
13122
- output: 1.7,
13123
- cacheRead: 0,
13124
- cacheWrite: 0,
13125
- },
13126
- contextWindow: 131072,
13127
- maxTokens: 131072,
13128
- },
13129
12969
  "deepseek-ai/DeepSeek-V4-Pro": {
13130
12970
  id: "deepseek-ai/DeepSeek-V4-Pro",
13131
12971
  name: "DeepSeek V4 Pro",
@@ -13137,8 +12977,8 @@ export const MODELS = {
13137
12977
  thinkingLevelMap: { "minimal": null, "low": null, "medium": null, "high": "high", "xhigh": null },
13138
12978
  input: ["text"],
13139
12979
  cost: {
13140
- input: 2.1,
13141
- output: 4.4,
12980
+ input: 1.74,
12981
+ output: 3.48,
13142
12982
  cacheRead: 0.2,
13143
12983
  cacheWrite: 0,
13144
12984
  },
@@ -13174,8 +13014,8 @@ export const MODELS = {
13174
13014
  thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13175
13015
  input: ["text", "image"],
13176
13016
  cost: {
13177
- input: 0.2,
13178
- output: 0.5,
13017
+ input: 0.39,
13018
+ output: 0.97,
13179
13019
  cacheRead: 0,
13180
13020
  cacheWrite: 0,
13181
13021
  },
@@ -13200,25 +13040,6 @@ export const MODELS = {
13200
13040
  contextWindow: 131072,
13201
13041
  maxTokens: 131072,
13202
13042
  },
13203
- "moonshotai/Kimi-K2.5": {
13204
- id: "moonshotai/Kimi-K2.5",
13205
- name: "Kimi K2.5",
13206
- api: "openai-completions",
13207
- provider: "together",
13208
- baseUrl: "https://api.together.ai/v1",
13209
- compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
13210
- reasoning: true,
13211
- thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13212
- input: ["text", "image"],
13213
- cost: {
13214
- input: 0.5,
13215
- output: 2.8,
13216
- cacheRead: 0,
13217
- cacheWrite: 0,
13218
- },
13219
- contextWindow: 262144,
13220
- maxTokens: 262144,
13221
- },
13222
13043
  "moonshotai/Kimi-K2.6": {
13223
13044
  id: "moonshotai/Kimi-K2.6",
13224
13045
  name: "Kimi K2.6",
@@ -13276,6 +13097,44 @@ export const MODELS = {
13276
13097
  contextWindow: 131072,
13277
13098
  maxTokens: 131072,
13278
13099
  },
13100
+ "openai/gpt-oss-20b": {
13101
+ id: "openai/gpt-oss-20b",
13102
+ name: "GPT OSS 20B",
13103
+ api: "openai-completions",
13104
+ provider: "together",
13105
+ baseUrl: "https://api.together.ai/v1",
13106
+ compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": true, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "openai" },
13107
+ reasoning: true,
13108
+ thinkingLevelMap: { "off": null, "minimal": null },
13109
+ input: ["text"],
13110
+ cost: {
13111
+ input: 0.05,
13112
+ output: 0.2,
13113
+ cacheRead: 0,
13114
+ cacheWrite: 0,
13115
+ },
13116
+ contextWindow: 131072,
13117
+ maxTokens: 131072,
13118
+ },
13119
+ "zai-org/GLM-5": {
13120
+ id: "zai-org/GLM-5",
13121
+ name: "GLM-5",
13122
+ api: "openai-completions",
13123
+ provider: "together",
13124
+ baseUrl: "https://api.together.ai/v1",
13125
+ compat: { "supportsStore": false, "supportsDeveloperRole": false, "supportsReasoningEffort": false, "maxTokensField": "max_tokens", "supportsStrictMode": false, "supportsLongCacheRetention": false, "thinkingFormat": "together" },
13126
+ reasoning: true,
13127
+ thinkingLevelMap: { "minimal": null, "low": null, "medium": null },
13128
+ input: ["text"],
13129
+ cost: {
13130
+ input: 1,
13131
+ output: 3.2,
13132
+ cacheRead: 0,
13133
+ cacheWrite: 0,
13134
+ },
13135
+ contextWindow: 202752,
13136
+ maxTokens: 131072,
13137
+ },
13279
13138
  "zai-org/GLM-5.1": {
13280
13139
  id: "zai-org/GLM-5.1",
13281
13140
  name: "GLM-5.1",
@@ -13340,8 +13199,8 @@ export const MODELS = {
13340
13199
  reasoning: true,
13341
13200
  input: ["text"],
13342
13201
  cost: {
13343
- input: 0.08,
13344
- output: 0.29,
13202
+ input: 0.12,
13203
+ output: 0.5,
13345
13204
  cacheRead: 0,
13346
13205
  cacheWrite: 0,
13347
13206
  },
@@ -13705,6 +13564,25 @@ export const MODELS = {
13705
13564
  contextWindow: 200000,
13706
13565
  maxTokens: 8192,
13707
13566
  },
13567
+ "anthropic/claude-fable-5": {
13568
+ id: "anthropic/claude-fable-5",
13569
+ name: "Claude Fable 5",
13570
+ api: "anthropic-messages",
13571
+ provider: "vercel-ai-gateway",
13572
+ baseUrl: "https://ai-gateway.vercel.sh",
13573
+ compat: { "forceAdaptiveThinking": true },
13574
+ reasoning: true,
13575
+ thinkingLevelMap: { "xhigh": "xhigh" },
13576
+ input: ["text", "image"],
13577
+ cost: {
13578
+ input: 10,
13579
+ output: 50,
13580
+ cacheRead: 1,
13581
+ cacheWrite: 12.5,
13582
+ },
13583
+ contextWindow: 1000000,
13584
+ maxTokens: 128000,
13585
+ },
13708
13586
  "anthropic/claude-haiku-4.5": {
13709
13587
  id: "anthropic/claude-haiku-4.5",
13710
13588
  name: "Claude Haiku 4.5",
@@ -14086,40 +13964,6 @@ export const MODELS = {
14086
13964
  contextWindow: 1000000,
14087
13965
  maxTokens: 384000,
14088
13966
  },
14089
- "google/gemini-2.0-flash": {
14090
- id: "google/gemini-2.0-flash",
14091
- name: "Gemini 2.0 Flash",
14092
- api: "anthropic-messages",
14093
- provider: "vercel-ai-gateway",
14094
- baseUrl: "https://ai-gateway.vercel.sh",
14095
- reasoning: false,
14096
- input: ["text", "image"],
14097
- cost: {
14098
- input: 0.15,
14099
- output: 0.6,
14100
- cacheRead: 0.025,
14101
- cacheWrite: 0,
14102
- },
14103
- contextWindow: 1048576,
14104
- maxTokens: 8192,
14105
- },
14106
- "google/gemini-2.0-flash-lite": {
14107
- id: "google/gemini-2.0-flash-lite",
14108
- name: "Gemini 2.0 Flash Lite",
14109
- api: "anthropic-messages",
14110
- provider: "vercel-ai-gateway",
14111
- baseUrl: "https://ai-gateway.vercel.sh",
14112
- reasoning: false,
14113
- input: ["text", "image"],
14114
- cost: {
14115
- input: 0.075,
14116
- output: 0.3,
14117
- cacheRead: 0.02,
14118
- cacheWrite: 0,
14119
- },
14120
- contextWindow: 1048576,
14121
- maxTokens: 8192,
14122
- },
14123
13967
  "google/gemini-2.5-flash": {
14124
13968
  id: "google/gemini-2.5-flash",
14125
13969
  name: "Gemini 2.5 Flash",
@@ -14868,40 +14712,6 @@ export const MODELS = {
14868
14712
  contextWindow: 262114,
14869
14713
  maxTokens: 262114,
14870
14714
  },
14871
- "moonshotai/kimi-k2-thinking-turbo": {
14872
- id: "moonshotai/kimi-k2-thinking-turbo",
14873
- name: "Kimi K2 Thinking Turbo",
14874
- api: "anthropic-messages",
14875
- provider: "vercel-ai-gateway",
14876
- baseUrl: "https://ai-gateway.vercel.sh",
14877
- reasoning: true,
14878
- input: ["text"],
14879
- cost: {
14880
- input: 1.15,
14881
- output: 8,
14882
- cacheRead: 0.15,
14883
- cacheWrite: 0,
14884
- },
14885
- contextWindow: 262114,
14886
- maxTokens: 262114,
14887
- },
14888
- "moonshotai/kimi-k2-turbo": {
14889
- id: "moonshotai/kimi-k2-turbo",
14890
- name: "Kimi K2 Turbo",
14891
- api: "anthropic-messages",
14892
- provider: "vercel-ai-gateway",
14893
- baseUrl: "https://ai-gateway.vercel.sh",
14894
- reasoning: false,
14895
- input: ["text"],
14896
- cost: {
14897
- input: 1.15,
14898
- output: 8,
14899
- cacheRead: 0.15,
14900
- cacheWrite: 0,
14901
- },
14902
- contextWindow: 256000,
14903
- maxTokens: 16384,
14904
- },
14905
14715
  "moonshotai/kimi-k2.5": {
14906
14716
  id: "moonshotai/kimi-k2.5",
14907
14717
  name: "Kimi K2.5",
@@ -16239,7 +16049,7 @@ export const MODELS = {
16239
16049
  cacheRead: 0.2,
16240
16050
  cacheWrite: 0,
16241
16051
  },
16242
- contextWindow: 2000000,
16052
+ contextWindow: 1000000,
16243
16053
  maxTokens: 30000,
16244
16054
  },
16245
16055
  "grok-4.20-0309-reasoning": {
@@ -16256,7 +16066,7 @@ export const MODELS = {
16256
16066
  cacheRead: 0.2,
16257
16067
  cacheWrite: 0,
16258
16068
  },
16259
- contextWindow: 2000000,
16069
+ contextWindow: 1000000,
16260
16070
  maxTokens: 30000,
16261
16071
  },
16262
16072
  "grok-4.3": {
@@ -16402,6 +16212,24 @@ export const MODELS = {
16402
16212
  contextWindow: 1048576,
16403
16213
  maxTokens: 131072,
16404
16214
  },
16215
+ "mimo-v2.5-pro-ultraspeed": {
16216
+ id: "mimo-v2.5-pro-ultraspeed",
16217
+ name: "MiMo-V2.5-Pro-UltraSpeed",
16218
+ api: "openai-completions",
16219
+ provider: "xiaomi",
16220
+ baseUrl: "https://api.xiaomimimo.com/v1",
16221
+ compat: { "requiresReasoningContentOnAssistantMessages": true, "thinkingFormat": "deepseek" },
16222
+ reasoning: true,
16223
+ input: ["text"],
16224
+ cost: {
16225
+ input: 1.305,
16226
+ output: 2.61,
16227
+ cacheRead: 0.0108,
16228
+ cacheWrite: 0,
16229
+ },
16230
+ contextWindow: 1048576,
16231
+ maxTokens: 131072,
16232
+ },
16405
16233
  },
16406
16234
  "xiaomi-token-plan-ams": {
16407
16235
  "mimo-v2-flash": {
@@ -16494,6 +16322,24 @@ export const MODELS = {
16494
16322
  contextWindow: 1048576,
16495
16323
  maxTokens: 131072,
16496
16324
  },
16325
+ "mimo-v2.5-pro-ultraspeed": {
16326
+ id: "mimo-v2.5-pro-ultraspeed",
16327
+ name: "MiMo-V2.5-Pro-UltraSpeed",
16328
+ api: "openai-completions",
16329
+ provider: "xiaomi-token-plan-ams",
16330
+ baseUrl: "https://token-plan-ams.xiaomimimo.com/v1",
16331
+ compat: { "requiresReasoningContentOnAssistantMessages": true, "thinkingFormat": "deepseek" },
16332
+ reasoning: true,
16333
+ input: ["text"],
16334
+ cost: {
16335
+ input: 1.305,
16336
+ output: 2.61,
16337
+ cacheRead: 0.0108,
16338
+ cacheWrite: 0,
16339
+ },
16340
+ contextWindow: 1048576,
16341
+ maxTokens: 131072,
16342
+ },
16497
16343
  },
16498
16344
  "xiaomi-token-plan-cn": {
16499
16345
  "mimo-v2-flash": {
@@ -16586,6 +16432,24 @@ export const MODELS = {
16586
16432
  contextWindow: 1048576,
16587
16433
  maxTokens: 131072,
16588
16434
  },
16435
+ "mimo-v2.5-pro-ultraspeed": {
16436
+ id: "mimo-v2.5-pro-ultraspeed",
16437
+ name: "MiMo-V2.5-Pro-UltraSpeed",
16438
+ api: "openai-completions",
16439
+ provider: "xiaomi-token-plan-cn",
16440
+ baseUrl: "https://token-plan-cn.xiaomimimo.com/v1",
16441
+ compat: { "requiresReasoningContentOnAssistantMessages": true, "thinkingFormat": "deepseek" },
16442
+ reasoning: true,
16443
+ input: ["text"],
16444
+ cost: {
16445
+ input: 1.305,
16446
+ output: 2.61,
16447
+ cacheRead: 0.0108,
16448
+ cacheWrite: 0,
16449
+ },
16450
+ contextWindow: 1048576,
16451
+ maxTokens: 131072,
16452
+ },
16589
16453
  },
16590
16454
  "xiaomi-token-plan-sgp": {
16591
16455
  "mimo-v2-flash": {
@@ -16678,6 +16542,24 @@ export const MODELS = {
16678
16542
  contextWindow: 1048576,
16679
16543
  maxTokens: 131072,
16680
16544
  },
16545
+ "mimo-v2.5-pro-ultraspeed": {
16546
+ id: "mimo-v2.5-pro-ultraspeed",
16547
+ name: "MiMo-V2.5-Pro-UltraSpeed",
16548
+ api: "openai-completions",
16549
+ provider: "xiaomi-token-plan-sgp",
16550
+ baseUrl: "https://token-plan-sgp.xiaomimimo.com/v1",
16551
+ compat: { "requiresReasoningContentOnAssistantMessages": true, "thinkingFormat": "deepseek" },
16552
+ reasoning: true,
16553
+ input: ["text"],
16554
+ cost: {
16555
+ input: 1.305,
16556
+ output: 2.61,
16557
+ cacheRead: 0.0108,
16558
+ cacheWrite: 0,
16559
+ },
16560
+ contextWindow: 1048576,
16561
+ maxTokens: 131072,
16562
+ },
16681
16563
  },
16682
16564
  "zai": {
16683
16565
  "glm-4.5-air": {