@mty-coder/cli 0.1.1

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 (1169) hide show
  1. package/Dockerfile +18 -0
  2. package/README.md +15 -0
  3. package/bin/mty +180 -0
  4. package/bunfig.toml +7 -0
  5. package/drizzle.config.ts +10 -0
  6. package/git +0 -0
  7. package/migration/20260127222353_familiar_lady_ursula/migration.sql +90 -0
  8. package/migration/20260127222353_familiar_lady_ursula/snapshot.json +796 -0
  9. package/migration/20260211171708_add_project_commands/migration.sql +1 -0
  10. package/migration/20260211171708_add_project_commands/snapshot.json +806 -0
  11. package/migration/20260213144116_wakeful_the_professor/migration.sql +11 -0
  12. package/migration/20260213144116_wakeful_the_professor/snapshot.json +897 -0
  13. package/migration/20260225215848_workspace/migration.sql +7 -0
  14. package/migration/20260225215848_workspace/snapshot.json +959 -0
  15. package/migration/20260227213759_add_session_workspace_id/migration.sql +2 -0
  16. package/migration/20260227213759_add_session_workspace_id/snapshot.json +983 -0
  17. package/migration/20260228203230_blue_harpoon/migration.sql +17 -0
  18. package/migration/20260228203230_blue_harpoon/snapshot.json +1102 -0
  19. package/migration/20260303231226_add_workspace_fields/migration.sql +5 -0
  20. package/migration/20260303231226_add_workspace_fields/snapshot.json +1013 -0
  21. package/migration/20260309230000_move_org_to_state/migration.sql +3 -0
  22. package/migration/20260309230000_move_org_to_state/snapshot.json +1156 -0
  23. package/migration/20260312043431_session_message_cursor/migration.sql +4 -0
  24. package/migration/20260312043431_session_message_cursor/snapshot.json +1168 -0
  25. package/migration/20260323234822_events/migration.sql +13 -0
  26. package/migration/20260323234822_events/snapshot.json +1271 -0
  27. package/migration/20260410174513_workspace-name/migration.sql +16 -0
  28. package/migration/20260410174513_workspace-name/snapshot.json +1271 -0
  29. package/migration/20260413175956_chief_energizer/migration.sql +13 -0
  30. package/migration/20260413175956_chief_energizer/snapshot.json +1399 -0
  31. package/migration/20260422160000_context_inheritance/migration.sql +3 -0
  32. package/migration/20260422170000_task_registry/migration.sql +18 -0
  33. package/migration/20260423145421_remove_session_entry/migration.sql +4 -0
  34. package/migration/20260515000000_actor_rename/migration.sql +7 -0
  35. package/migration/20260515010000_memory_fts/migration.sql +33 -0
  36. package/migration/20260515020000_user_task/migration.sql +29 -0
  37. package/migration/20260519000000_last_checkpoint_message_id/migration.sql +1 -0
  38. package/migration/20260521000000_message_agent_id/migration.sql +2 -0
  39. package/migration/20260521000100_actor_registry_v6/migration.sql +25 -0
  40. package/migration/20260521010000_memory_fts_v6/migration.sql +33 -0
  41. package/migration/20260521020000_memory_fts_triggers/migration.sql +17 -0
  42. package/migration/20260526000000_agent_id_main/migration.sql +14 -0
  43. package/migration/20260527000000_actor_lifecycle/migration.sql +8 -0
  44. package/migration/20260527000100_inbox/migration.sql +12 -0
  45. package/migration/20260529000000_task_todo_redesign/migration.sql +16 -0
  46. package/migration/20260603000000_task_in_progress_owner/migration.sql +1 -0
  47. package/migration/20260603000000_workflow_run/migration.sql +17 -0
  48. package/migration/20260604000000_workflow_script_sha/migration.sql +1 -0
  49. package/migration/20260608000000_claude_import/migration.sql +7 -0
  50. package/migration/20260608010000_claude_import_message_ids/migration.sql +1 -0
  51. package/migration/20260609000000_history_fts/migration.sql +29 -0
  52. package/migration/20260609230000_workflow_agent_timeout/migration.sql +1 -0
  53. package/migration/20260612000000_external_import/migration.sql +16 -0
  54. package/package.json +201 -0
  55. package/parsers-config.ts +290 -0
  56. package/script/build.ts +303 -0
  57. package/script/check-migrations.ts +16 -0
  58. package/script/fix-node-pty.ts +28 -0
  59. package/script/generate.ts +23 -0
  60. package/script/postinstall.mjs +102 -0
  61. package/script/publish.ts +74 -0
  62. package/script/run-workspace-server +106 -0
  63. package/script/schema.ts +63 -0
  64. package/script/time.ts +6 -0
  65. package/script/trace-imports.ts +153 -0
  66. package/script/upgrade-opentui.ts +64 -0
  67. package/src/account/account.sql.ts +39 -0
  68. package/src/account/account.ts +456 -0
  69. package/src/account/repo.ts +166 -0
  70. package/src/account/schema.ts +99 -0
  71. package/src/account/url.ts +8 -0
  72. package/src/acp/README.md +174 -0
  73. package/src/acp/agent.ts +1783 -0
  74. package/src/acp/session.ts +116 -0
  75. package/src/acp/types.ts +24 -0
  76. package/src/actor/actor.sql.ts +38 -0
  77. package/src/actor/events.ts +67 -0
  78. package/src/actor/index.ts +2 -0
  79. package/src/actor/registry.ts +412 -0
  80. package/src/actor/return-header.ts +24 -0
  81. package/src/actor/schema.ts +47 -0
  82. package/src/actor/spawn-ref.ts +16 -0
  83. package/src/actor/spawn.ts +741 -0
  84. package/src/actor/turn.ts +49 -0
  85. package/src/actor/waiter.ts +166 -0
  86. package/src/agent/agent.ts +554 -0
  87. package/src/agent/config.ts +5 -0
  88. package/src/agent/generate.txt +75 -0
  89. package/src/agent/prompt/checkpoint-writer.txt +167 -0
  90. package/src/agent/prompt/compaction.txt +9 -0
  91. package/src/agent/prompt/distill.txt +226 -0
  92. package/src/agent/prompt/dream.txt +155 -0
  93. package/src/agent/prompt/explore.txt +18 -0
  94. package/src/agent/prompt/summary.txt +11 -0
  95. package/src/agent/prompt/title.txt +44 -0
  96. package/src/audio.d.ts +9 -0
  97. package/src/auth/index.ts +97 -0
  98. package/src/bus/bus-event.ts +33 -0
  99. package/src/bus/global.ts +12 -0
  100. package/src/bus/index.ts +193 -0
  101. package/src/cli/bootstrap.ts +33 -0
  102. package/src/cli/cmd/account.ts +258 -0
  103. package/src/cli/cmd/acp.ts +70 -0
  104. package/src/cli/cmd/agent.ts +248 -0
  105. package/src/cli/cmd/cmd.ts +7 -0
  106. package/src/cli/cmd/db.ts +120 -0
  107. package/src/cli/cmd/debug/agent.ts +192 -0
  108. package/src/cli/cmd/debug/config.ts +17 -0
  109. package/src/cli/cmd/debug/file.ts +100 -0
  110. package/src/cli/cmd/debug/index.ts +48 -0
  111. package/src/cli/cmd/debug/lsp.ts +61 -0
  112. package/src/cli/cmd/debug/ripgrep.ts +105 -0
  113. package/src/cli/cmd/debug/scrap.ts +16 -0
  114. package/src/cli/cmd/debug/skill.ts +23 -0
  115. package/src/cli/cmd/debug/snapshot.ts +53 -0
  116. package/src/cli/cmd/export.ts +306 -0
  117. package/src/cli/cmd/generate.ts +50 -0
  118. package/src/cli/cmd/github.ts +1647 -0
  119. package/src/cli/cmd/import.ts +208 -0
  120. package/src/cli/cmd/init.ts +309 -0
  121. package/src/cli/cmd/mcp.ts +812 -0
  122. package/src/cli/cmd/models.ts +88 -0
  123. package/src/cli/cmd/plug.ts +233 -0
  124. package/src/cli/cmd/pr.ts +138 -0
  125. package/src/cli/cmd/providers.ts +692 -0
  126. package/src/cli/cmd/run-completion.ts +77 -0
  127. package/src/cli/cmd/run.ts +694 -0
  128. package/src/cli/cmd/serve.ts +21 -0
  129. package/src/cli/cmd/session.ts +181 -0
  130. package/src/cli/cmd/stats.ts +413 -0
  131. package/src/cli/cmd/tui/app.tsx +1153 -0
  132. package/src/cli/cmd/tui/asset/TEN_VAD_LICENSE +12 -0
  133. package/src/cli/cmd/tui/asset/charge.wav +0 -0
  134. package/src/cli/cmd/tui/asset/pulse-a.wav +0 -0
  135. package/src/cli/cmd/tui/asset/pulse-b.wav +0 -0
  136. package/src/cli/cmd/tui/asset/pulse-c.wav +0 -0
  137. package/src/cli/cmd/tui/asset/ten_vad.wasm +0 -0
  138. package/src/cli/cmd/tui/asset/ten_vad_loader.js +30 -0
  139. package/src/cli/cmd/tui/attach.ts +84 -0
  140. package/src/cli/cmd/tui/component/background-image.tsx +150 -0
  141. package/src/cli/cmd/tui/component/bg-pulse.tsx +130 -0
  142. package/src/cli/cmd/tui/component/border.tsx +21 -0
  143. package/src/cli/cmd/tui/component/dialog-agent.tsx +31 -0
  144. package/src/cli/cmd/tui/component/dialog-agreement.tsx +111 -0
  145. package/src/cli/cmd/tui/component/dialog-command.tsx +208 -0
  146. package/src/cli/cmd/tui/component/dialog-console-org.tsx +103 -0
  147. package/src/cli/cmd/tui/component/dialog-go-upsell.tsx +157 -0
  148. package/src/cli/cmd/tui/component/dialog-image-list.tsx +111 -0
  149. package/src/cli/cmd/tui/component/dialog-logo-design.tsx +37 -0
  150. package/src/cli/cmd/tui/component/dialog-mcp.tsx +86 -0
  151. package/src/cli/cmd/tui/component/dialog-model.tsx +253 -0
  152. package/src/cli/cmd/tui/component/dialog-mty-login.tsx +27 -0
  153. package/src/cli/cmd/tui/component/dialog-onboarding.tsx +97 -0
  154. package/src/cli/cmd/tui/component/dialog-provider.tsx +454 -0
  155. package/src/cli/cmd/tui/component/dialog-session-delete-failed.tsx +101 -0
  156. package/src/cli/cmd/tui/component/dialog-session-list.tsx +269 -0
  157. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +31 -0
  158. package/src/cli/cmd/tui/component/dialog-skill.tsx +42 -0
  159. package/src/cli/cmd/tui/component/dialog-stash.tsx +87 -0
  160. package/src/cli/cmd/tui/component/dialog-status.tsx +170 -0
  161. package/src/cli/cmd/tui/component/dialog-tag.tsx +44 -0
  162. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +50 -0
  163. package/src/cli/cmd/tui/component/dialog-variant.tsx +39 -0
  164. package/src/cli/cmd/tui/component/dialog-workflows.tsx +62 -0
  165. package/src/cli/cmd/tui/component/dialog-workspace-create.tsx +289 -0
  166. package/src/cli/cmd/tui/component/dialog-workspace-unavailable.tsx +81 -0
  167. package/src/cli/cmd/tui/component/dialog-worktree.tsx +90 -0
  168. package/src/cli/cmd/tui/component/error-component.tsx +92 -0
  169. package/src/cli/cmd/tui/component/logo.tsx +961 -0
  170. package/src/cli/cmd/tui/component/plugin-route-missing.tsx +14 -0
  171. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +684 -0
  172. package/src/cli/cmd/tui/component/prompt/cwd.ts +0 -0
  173. package/src/cli/cmd/tui/component/prompt/frecency.tsx +90 -0
  174. package/src/cli/cmd/tui/component/prompt/history.tsx +108 -0
  175. package/src/cli/cmd/tui/component/prompt/index.tsx +1874 -0
  176. package/src/cli/cmd/tui/component/prompt/part.ts +16 -0
  177. package/src/cli/cmd/tui/component/prompt/stash.tsx +101 -0
  178. package/src/cli/cmd/tui/component/spinner.tsx +24 -0
  179. package/src/cli/cmd/tui/component/starry-background.tsx +305 -0
  180. package/src/cli/cmd/tui/component/startup-loading.tsx +67 -0
  181. package/src/cli/cmd/tui/component/task-item.tsx +63 -0
  182. package/src/cli/cmd/tui/component/textarea-keybindings.ts +73 -0
  183. package/src/cli/cmd/tui/component/todo-item.tsx +32 -0
  184. package/src/cli/cmd/tui/config/cwd.ts +5 -0
  185. package/src/cli/cmd/tui/config/tui-migrate.ts +151 -0
  186. package/src/cli/cmd/tui/config/tui-schema.ts +38 -0
  187. package/src/cli/cmd/tui/config/tui.ts +219 -0
  188. package/src/cli/cmd/tui/context/args.tsx +16 -0
  189. package/src/cli/cmd/tui/context/directory.ts +15 -0
  190. package/src/cli/cmd/tui/context/event.ts +45 -0
  191. package/src/cli/cmd/tui/context/exit.tsx +65 -0
  192. package/src/cli/cmd/tui/context/helper.tsx +25 -0
  193. package/src/cli/cmd/tui/context/keybind.tsx +105 -0
  194. package/src/cli/cmd/tui/context/kv.tsx +86 -0
  195. package/src/cli/cmd/tui/context/language.tsx +91 -0
  196. package/src/cli/cmd/tui/context/local.tsx +455 -0
  197. package/src/cli/cmd/tui/context/plugin-keybinds.ts +41 -0
  198. package/src/cli/cmd/tui/context/project.tsx +109 -0
  199. package/src/cli/cmd/tui/context/prompt.tsx +18 -0
  200. package/src/cli/cmd/tui/context/route.tsx +61 -0
  201. package/src/cli/cmd/tui/context/sdk.tsx +150 -0
  202. package/src/cli/cmd/tui/context/sync.tsx +828 -0
  203. package/src/cli/cmd/tui/context/theme/aura.json +69 -0
  204. package/src/cli/cmd/tui/context/theme/ayu.json +80 -0
  205. package/src/cli/cmd/tui/context/theme/carbonfox.json +248 -0
  206. package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +230 -0
  207. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +230 -0
  208. package/src/cli/cmd/tui/context/theme/catppuccin.json +112 -0
  209. package/src/cli/cmd/tui/context/theme/cobalt2.json +225 -0
  210. package/src/cli/cmd/tui/context/theme/cursor.json +249 -0
  211. package/src/cli/cmd/tui/context/theme/dracula.json +219 -0
  212. package/src/cli/cmd/tui/context/theme/everforest.json +241 -0
  213. package/src/cli/cmd/tui/context/theme/flexoki.json +237 -0
  214. package/src/cli/cmd/tui/context/theme/frost.json +245 -0
  215. package/src/cli/cmd/tui/context/theme/github.json +233 -0
  216. package/src/cli/cmd/tui/context/theme/gruvbox.json +242 -0
  217. package/src/cli/cmd/tui/context/theme/kanagawa.json +77 -0
  218. package/src/cli/cmd/tui/context/theme/lucent-orng.json +234 -0
  219. package/src/cli/cmd/tui/context/theme/material.json +235 -0
  220. package/src/cli/cmd/tui/context/theme/matrix.json +77 -0
  221. package/src/cli/cmd/tui/context/theme/mercury.json +252 -0
  222. package/src/cli/cmd/tui/context/theme/monokai.json +221 -0
  223. package/src/cli/cmd/tui/context/theme/mtycoder.json +245 -0
  224. package/src/cli/cmd/tui/context/theme/nightowl.json +221 -0
  225. package/src/cli/cmd/tui/context/theme/nord.json +223 -0
  226. package/src/cli/cmd/tui/context/theme/one-dark.json +84 -0
  227. package/src/cli/cmd/tui/context/theme/orng.json +249 -0
  228. package/src/cli/cmd/tui/context/theme/osaka-jade.json +93 -0
  229. package/src/cli/cmd/tui/context/theme/palenight.json +222 -0
  230. package/src/cli/cmd/tui/context/theme/rosepine.json +234 -0
  231. package/src/cli/cmd/tui/context/theme/solarized.json +223 -0
  232. package/src/cli/cmd/tui/context/theme/synthwave84.json +226 -0
  233. package/src/cli/cmd/tui/context/theme/tokyonight.json +243 -0
  234. package/src/cli/cmd/tui/context/theme/vercel.json +245 -0
  235. package/src/cli/cmd/tui/context/theme/vesper.json +218 -0
  236. package/src/cli/cmd/tui/context/theme/zenburn.json +223 -0
  237. package/src/cli/cmd/tui/context/theme.tsx +1300 -0
  238. package/src/cli/cmd/tui/context/thinking.ts +48 -0
  239. package/src/cli/cmd/tui/context/tui-config.tsx +9 -0
  240. package/src/cli/cmd/tui/event.ts +56 -0
  241. package/src/cli/cmd/tui/feature-plugins/home/footer.tsx +93 -0
  242. package/src/cli/cmd/tui/feature-plugins/home/tips-view.tsx +215 -0
  243. package/src/cli/cmd/tui/feature-plugins/home/tips.tsx +55 -0
  244. package/src/cli/cmd/tui/feature-plugins/sidebar/context.tsx +114 -0
  245. package/src/cli/cmd/tui/feature-plugins/sidebar/cwd.tsx +45 -0
  246. package/src/cli/cmd/tui/feature-plugins/sidebar/files.tsx +62 -0
  247. package/src/cli/cmd/tui/feature-plugins/sidebar/footer.tsx +93 -0
  248. package/src/cli/cmd/tui/feature-plugins/sidebar/goal.tsx +84 -0
  249. package/src/cli/cmd/tui/feature-plugins/sidebar/instructions.tsx +54 -0
  250. package/src/cli/cmd/tui/feature-plugins/sidebar/lsp.tsx +66 -0
  251. package/src/cli/cmd/tui/feature-plugins/sidebar/mcp.tsx +98 -0
  252. package/src/cli/cmd/tui/feature-plugins/sidebar/task.tsx +95 -0
  253. package/src/cli/cmd/tui/feature-plugins/sidebar/todo.tsx +51 -0
  254. package/src/cli/cmd/tui/feature-plugins/sidebar/tps.ts +31 -0
  255. package/src/cli/cmd/tui/feature-plugins/system/plugins.tsx +274 -0
  256. package/src/cli/cmd/tui/i18n/en.ts +436 -0
  257. package/src/cli/cmd/tui/i18n/es.ts +478 -0
  258. package/src/cli/cmd/tui/i18n/fr.ts +485 -0
  259. package/src/cli/cmd/tui/i18n/ja.ts +437 -0
  260. package/src/cli/cmd/tui/i18n/locales.ts +82 -0
  261. package/src/cli/cmd/tui/i18n/ru.ts +497 -0
  262. package/src/cli/cmd/tui/i18n/zh.ts +429 -0
  263. package/src/cli/cmd/tui/i18n/zht.ts +405 -0
  264. package/src/cli/cmd/tui/layer.ts +6 -0
  265. package/src/cli/cmd/tui/plugin/api.tsx +402 -0
  266. package/src/cli/cmd/tui/plugin/index.ts +3 -0
  267. package/src/cli/cmd/tui/plugin/internal.ts +35 -0
  268. package/src/cli/cmd/tui/plugin/runtime.ts +1057 -0
  269. package/src/cli/cmd/tui/plugin/slots.tsx +60 -0
  270. package/src/cli/cmd/tui/routes/home.tsx +165 -0
  271. package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +76 -0
  272. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +116 -0
  273. package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +47 -0
  274. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +47 -0
  275. package/src/cli/cmd/tui/routes/session/footer.tsx +91 -0
  276. package/src/cli/cmd/tui/routes/session/index.tsx +2567 -0
  277. package/src/cli/cmd/tui/routes/session/permission.tsx +691 -0
  278. package/src/cli/cmd/tui/routes/session/question.tsx +488 -0
  279. package/src/cli/cmd/tui/routes/session/sidebar.tsx +97 -0
  280. package/src/cli/cmd/tui/routes/session/subagent-footer.tsx +142 -0
  281. package/src/cli/cmd/tui/thread.ts +323 -0
  282. package/src/cli/cmd/tui/ui/dialog-alert.tsx +61 -0
  283. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +95 -0
  284. package/src/cli/cmd/tui/ui/dialog-export-options.tsx +223 -0
  285. package/src/cli/cmd/tui/ui/dialog-help.tsx +99 -0
  286. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +123 -0
  287. package/src/cli/cmd/tui/ui/dialog-select.tsx +452 -0
  288. package/src/cli/cmd/tui/ui/dialog.tsx +207 -0
  289. package/src/cli/cmd/tui/ui/link.tsx +28 -0
  290. package/src/cli/cmd/tui/ui/spinner.ts +378 -0
  291. package/src/cli/cmd/tui/ui/toast.tsx +102 -0
  292. package/src/cli/cmd/tui/util/clipboard.ts +203 -0
  293. package/src/cli/cmd/tui/util/editor.ts +35 -0
  294. package/src/cli/cmd/tui/util/image-protocol.ts +35 -0
  295. package/src/cli/cmd/tui/util/index.ts +6 -0
  296. package/src/cli/cmd/tui/util/model.ts +23 -0
  297. package/src/cli/cmd/tui/util/provider-origin.ts +7 -0
  298. package/src/cli/cmd/tui/util/revert-diff.ts +18 -0
  299. package/src/cli/cmd/tui/util/scroll.ts +23 -0
  300. package/src/cli/cmd/tui/util/selection.ts +23 -0
  301. package/src/cli/cmd/tui/util/signal.ts +41 -0
  302. package/src/cli/cmd/tui/util/sound.ts +154 -0
  303. package/src/cli/cmd/tui/util/system-locale.ts +209 -0
  304. package/src/cli/cmd/tui/util/terminal.ts +110 -0
  305. package/src/cli/cmd/tui/util/transcript.ts +112 -0
  306. package/src/cli/cmd/tui/util/vad.ts +229 -0
  307. package/src/cli/cmd/tui/util/voice.ts +450 -0
  308. package/src/cli/cmd/tui/win32.ts +130 -0
  309. package/src/cli/cmd/tui/worker.ts +104 -0
  310. package/src/cli/cmd/uninstall.ts +351 -0
  311. package/src/cli/cmd/upgrade.ts +79 -0
  312. package/src/cli/cmd/web.ts +82 -0
  313. package/src/cli/effect/prompt.ts +25 -0
  314. package/src/cli/error.ts +82 -0
  315. package/src/cli/heap.ts +59 -0
  316. package/src/cli/i18n.ts +15 -0
  317. package/src/cli/logo.ts +53 -0
  318. package/src/cli/network.ts +62 -0
  319. package/src/cli/ui.ts +133 -0
  320. package/src/cli/upgrade.ts +41 -0
  321. package/src/command/index.ts +325 -0
  322. package/src/command/template/initialize.txt +66 -0
  323. package/src/command/template/mty-backend.txt +164 -0
  324. package/src/command/template/mty-frontend-design.txt +173 -0
  325. package/src/command/template/mty-frontend.txt +164 -0
  326. package/src/command/template/mty-team.txt +239 -0
  327. package/src/command/template/review.txt +101 -0
  328. package/src/config/agent.ts +197 -0
  329. package/src/config/command.ts +69 -0
  330. package/src/config/config.ts +1036 -0
  331. package/src/config/console-state.ts +16 -0
  332. package/src/config/entry-name.ts +16 -0
  333. package/src/config/error.ts +21 -0
  334. package/src/config/formatter.ts +17 -0
  335. package/src/config/history.ts +21 -0
  336. package/src/config/index.ts +16 -0
  337. package/src/config/keybinds.ts +127 -0
  338. package/src/config/layout.ts +10 -0
  339. package/src/config/lsp.ts +45 -0
  340. package/src/config/managed.ts +70 -0
  341. package/src/config/markdown.ts +97 -0
  342. package/src/config/mcp.ts +172 -0
  343. package/src/config/model-id.ts +14 -0
  344. package/src/config/parse.ts +44 -0
  345. package/src/config/paths.ts +73 -0
  346. package/src/config/permission.ts +76 -0
  347. package/src/config/plugin.ts +88 -0
  348. package/src/config/provider.ts +118 -0
  349. package/src/config/server.ts +20 -0
  350. package/src/config/skills.ts +16 -0
  351. package/src/config/variable.ts +90 -0
  352. package/src/control-plane/adaptors/index.ts +52 -0
  353. package/src/control-plane/adaptors/worktree.ts +47 -0
  354. package/src/control-plane/dev/debug-workspace-plugin.ts +73 -0
  355. package/src/control-plane/schema.ts +19 -0
  356. package/src/control-plane/sse.ts +66 -0
  357. package/src/control-plane/types.ts +34 -0
  358. package/src/control-plane/util.ts +37 -0
  359. package/src/control-plane/workspace-context.ts +26 -0
  360. package/src/control-plane/workspace.sql.ts +17 -0
  361. package/src/control-plane/workspace.ts +615 -0
  362. package/src/effect/app-runtime.ts +146 -0
  363. package/src/effect/bootstrap-runtime.ts +33 -0
  364. package/src/effect/bridge.ts +48 -0
  365. package/src/effect/cross-spawn-spawner.ts +514 -0
  366. package/src/effect/index.ts +5 -0
  367. package/src/effect/instance-ref.ts +11 -0
  368. package/src/effect/instance-registry.ts +12 -0
  369. package/src/effect/instance-state.ts +81 -0
  370. package/src/effect/logger.ts +73 -0
  371. package/src/effect/memo-map.ts +3 -0
  372. package/src/effect/observability.ts +107 -0
  373. package/src/effect/run-service.ts +52 -0
  374. package/src/effect/runner.ts +210 -0
  375. package/src/effect/runtime.ts +19 -0
  376. package/src/env/index.ts +37 -0
  377. package/src/file/ignore.ts +81 -0
  378. package/src/file/index.ts +664 -0
  379. package/src/file/protected.ts +59 -0
  380. package/src/file/ripgrep.ts +485 -0
  381. package/src/file/watcher.ts +163 -0
  382. package/src/flag/flag.ts +167 -0
  383. package/src/format/formatter.ts +403 -0
  384. package/src/format/index.ts +203 -0
  385. package/src/git/index.ts +260 -0
  386. package/src/global/index.ts +54 -0
  387. package/src/history/backfill.ts +162 -0
  388. package/src/history/extract.ts +67 -0
  389. package/src/history/fts-query.ts +15 -0
  390. package/src/history/fts.sql.ts +20 -0
  391. package/src/history/index.ts +10 -0
  392. package/src/history/resolve.ts +65 -0
  393. package/src/history/service.ts +258 -0
  394. package/src/history/writer.ts +112 -0
  395. package/src/id/id.ts +87 -0
  396. package/src/ide/index.ts +73 -0
  397. package/src/inbox/inbox-ref.ts +38 -0
  398. package/src/inbox/inbox.sql.ts +26 -0
  399. package/src/inbox/inbox.ts +223 -0
  400. package/src/inbox/index.ts +3 -0
  401. package/src/inbox/render.ts +40 -0
  402. package/src/index.ts +264 -0
  403. package/src/installation/index.ts +362 -0
  404. package/src/installation/version.ts +8 -0
  405. package/src/lsp/client.ts +249 -0
  406. package/src/lsp/diagnostic.ts +29 -0
  407. package/src/lsp/index.ts +3 -0
  408. package/src/lsp/language.ts +120 -0
  409. package/src/lsp/launch.ts +21 -0
  410. package/src/lsp/lsp.ts +519 -0
  411. package/src/lsp/server.ts +1956 -0
  412. package/src/mcp/auth.ts +144 -0
  413. package/src/mcp/index.ts +944 -0
  414. package/src/mcp/oauth-callback.ts +232 -0
  415. package/src/mcp/oauth-provider.ts +214 -0
  416. package/src/memory/fts-query.ts +37 -0
  417. package/src/memory/fts.sql.ts +19 -0
  418. package/src/memory/index.ts +1 -0
  419. package/src/memory/paths.ts +116 -0
  420. package/src/memory/reconcile.ts +231 -0
  421. package/src/memory/service.ts +152 -0
  422. package/src/metrics/client.ts +40 -0
  423. package/src/metrics/event.ts +43 -0
  424. package/src/metrics/index.ts +5 -0
  425. package/src/metrics/installation.ts +18 -0
  426. package/src/metrics/subscriber.ts +58 -0
  427. package/src/metrics/util.ts +9 -0
  428. package/src/node.ts +6 -0
  429. package/src/npm/config.ts +0 -0
  430. package/src/npm/index.ts +293 -0
  431. package/src/npmcli-config.d.ts +43 -0
  432. package/src/patch/index.ts +680 -0
  433. package/src/permission/arity.ts +163 -0
  434. package/src/permission/evaluate.ts +15 -0
  435. package/src/permission/index.ts +378 -0
  436. package/src/permission/schema.ts +17 -0
  437. package/src/plugin/checkpoint-splitover.ts +60 -0
  438. package/src/plugin/cloudflare.ts +76 -0
  439. package/src/plugin/codex.ts +607 -0
  440. package/src/plugin/github-copilot/copilot.ts +368 -0
  441. package/src/plugin/github-copilot/models.ts +153 -0
  442. package/src/plugin/index.ts +584 -0
  443. package/src/plugin/install.ts +439 -0
  444. package/src/plugin/loader.ts +216 -0
  445. package/src/plugin/matcher.ts +33 -0
  446. package/src/plugin/meta.ts +188 -0
  447. package/src/plugin/mty.ts +9 -0
  448. package/src/plugin/shared.ts +323 -0
  449. package/src/plugin/subagent-progress-checker.ts +147 -0
  450. package/src/project/bootstrap.ts +59 -0
  451. package/src/project/index.ts +2 -0
  452. package/src/project/instance.ts +190 -0
  453. package/src/project/project-id.ts +48 -0
  454. package/src/project/project.sql.ts +16 -0
  455. package/src/project/project.ts +522 -0
  456. package/src/project/schema.ts +15 -0
  457. package/src/project/vcs.ts +227 -0
  458. package/src/project/workspace-trust.ts +67 -0
  459. package/src/provider/auth.ts +234 -0
  460. package/src/provider/error.ts +216 -0
  461. package/src/provider/index.ts +5 -0
  462. package/src/provider/models.ts +180 -0
  463. package/src/provider/provider.ts +1787 -0
  464. package/src/provider/schema.ts +36 -0
  465. package/src/provider/sdk/copilot/README.md +5 -0
  466. package/src/provider/sdk/copilot/chat/convert-to-openai-compatible-chat-messages.ts +170 -0
  467. package/src/provider/sdk/copilot/chat/get-response-metadata.ts +15 -0
  468. package/src/provider/sdk/copilot/chat/map-openai-compatible-finish-reason.ts +19 -0
  469. package/src/provider/sdk/copilot/chat/openai-compatible-api-types.ts +64 -0
  470. package/src/provider/sdk/copilot/chat/openai-compatible-chat-language-model.ts +815 -0
  471. package/src/provider/sdk/copilot/chat/openai-compatible-chat-options.ts +28 -0
  472. package/src/provider/sdk/copilot/chat/openai-compatible-metadata-extractor.ts +44 -0
  473. package/src/provider/sdk/copilot/chat/openai-compatible-prepare-tools.ts +83 -0
  474. package/src/provider/sdk/copilot/copilot-provider.ts +100 -0
  475. package/src/provider/sdk/copilot/index.ts +2 -0
  476. package/src/provider/sdk/copilot/openai-compatible-error.ts +27 -0
  477. package/src/provider/sdk/copilot/responses/convert-to-openai-responses-input.ts +335 -0
  478. package/src/provider/sdk/copilot/responses/map-openai-responses-finish-reason.ts +22 -0
  479. package/src/provider/sdk/copilot/responses/openai-config.ts +18 -0
  480. package/src/provider/sdk/copilot/responses/openai-error.ts +22 -0
  481. package/src/provider/sdk/copilot/responses/openai-responses-api-types.ts +214 -0
  482. package/src/provider/sdk/copilot/responses/openai-responses-language-model.ts +1770 -0
  483. package/src/provider/sdk/copilot/responses/openai-responses-prepare-tools.ts +173 -0
  484. package/src/provider/sdk/copilot/responses/openai-responses-settings.ts +1 -0
  485. package/src/provider/sdk/copilot/responses/tool/code-interpreter.ts +87 -0
  486. package/src/provider/sdk/copilot/responses/tool/file-search.ts +127 -0
  487. package/src/provider/sdk/copilot/responses/tool/image-generation.ts +114 -0
  488. package/src/provider/sdk/copilot/responses/tool/local-shell.ts +64 -0
  489. package/src/provider/sdk/copilot/responses/tool/web-search-preview.ts +103 -0
  490. package/src/provider/sdk/copilot/responses/tool/web-search.ts +102 -0
  491. package/src/provider/transform.ts +1322 -0
  492. package/src/pty/index.ts +364 -0
  493. package/src/pty/pty.bun.ts +26 -0
  494. package/src/pty/pty.node.ts +27 -0
  495. package/src/pty/pty.ts +25 -0
  496. package/src/pty/schema.ts +17 -0
  497. package/src/question/index.ts +252 -0
  498. package/src/question/schema.ts +17 -0
  499. package/src/server/adapter.bun.ts +40 -0
  500. package/src/server/adapter.node.ts +66 -0
  501. package/src/server/adapter.ts +21 -0
  502. package/src/server/auth.ts +16 -0
  503. package/src/server/error.ts +53 -0
  504. package/src/server/event.ts +7 -0
  505. package/src/server/fence.ts +81 -0
  506. package/src/server/mdns.ts +60 -0
  507. package/src/server/middleware.ts +96 -0
  508. package/src/server/projectors.ts +28 -0
  509. package/src/server/proxy.ts +171 -0
  510. package/src/server/pty-ticket.ts +42 -0
  511. package/src/server/routes/control/index.ts +160 -0
  512. package/src/server/routes/control/workspace.ts +203 -0
  513. package/src/server/routes/global.ts +367 -0
  514. package/src/server/routes/instance/bash-interactive.ts +82 -0
  515. package/src/server/routes/instance/config.ts +89 -0
  516. package/src/server/routes/instance/event.ts +108 -0
  517. package/src/server/routes/instance/experimental.ts +408 -0
  518. package/src/server/routes/instance/file.ts +190 -0
  519. package/src/server/routes/instance/httpapi/config.ts +51 -0
  520. package/src/server/routes/instance/httpapi/permission.ts +72 -0
  521. package/src/server/routes/instance/httpapi/project.ts +62 -0
  522. package/src/server/routes/instance/httpapi/provider.ts +142 -0
  523. package/src/server/routes/instance/httpapi/question.ts +121 -0
  524. package/src/server/routes/instance/httpapi/server.ts +136 -0
  525. package/src/server/routes/instance/index.ts +301 -0
  526. package/src/server/routes/instance/mcp.ts +260 -0
  527. package/src/server/routes/instance/middleware.ts +35 -0
  528. package/src/server/routes/instance/permission.ts +73 -0
  529. package/src/server/routes/instance/project.ts +122 -0
  530. package/src/server/routes/instance/provider.ts +158 -0
  531. package/src/server/routes/instance/pty.ts +302 -0
  532. package/src/server/routes/instance/question.ts +162 -0
  533. package/src/server/routes/instance/session.ts +1296 -0
  534. package/src/server/routes/instance/sync.ts +143 -0
  535. package/src/server/routes/instance/trace.ts +59 -0
  536. package/src/server/routes/instance/tui.ts +384 -0
  537. package/src/server/routes/instance/workflows.ts +72 -0
  538. package/src/server/routes/ui.ts +37 -0
  539. package/src/server/server.ts +136 -0
  540. package/src/server/workspace.ts +122 -0
  541. package/src/session/auto-dream.ts +204 -0
  542. package/src/session/boundary.ts +77 -0
  543. package/src/session/budgeted-read.ts +118 -0
  544. package/src/session/checkpoint-align.ts +29 -0
  545. package/src/session/checkpoint-context.ts +36 -0
  546. package/src/session/checkpoint-paths.ts +86 -0
  547. package/src/session/checkpoint-progress-reconcile.ts +111 -0
  548. package/src/session/checkpoint-retry.ts +192 -0
  549. package/src/session/checkpoint-templates.ts +114 -0
  550. package/src/session/checkpoint-validator.ts +259 -0
  551. package/src/session/checkpoint.ts +1478 -0
  552. package/src/session/classify.ts +92 -0
  553. package/src/session/claude-import.ts +381 -0
  554. package/src/session/codex-import.ts +416 -0
  555. package/src/session/compaction.ts +543 -0
  556. package/src/session/external-import.sql.ts +18 -0
  557. package/src/session/external-import.ts +136 -0
  558. package/src/session/goal.ts +232 -0
  559. package/src/session/index.ts +1 -0
  560. package/src/session/instruction.ts +276 -0
  561. package/src/session/last-message-info.ts +32 -0
  562. package/src/session/llm-request-prefix.ts +82 -0
  563. package/src/session/llm.ts +735 -0
  564. package/src/session/max-mode.ts +397 -0
  565. package/src/session/message-v2.ts +1136 -0
  566. package/src/session/message.ts +191 -0
  567. package/src/session/opencode-import.ts +281 -0
  568. package/src/session/overflow.ts +62 -0
  569. package/src/session/prefix-capture-ref.ts +48 -0
  570. package/src/session/processor.ts +985 -0
  571. package/src/session/projectors.ts +137 -0
  572. package/src/session/prompt/anthropic.txt +154 -0
  573. package/src/session/prompt/beast.txt +155 -0
  574. package/src/session/prompt/build-switch.txt +5 -0
  575. package/src/session/prompt/codex.txt +79 -0
  576. package/src/session/prompt/compose.txt +115 -0
  577. package/src/session/prompt/copilot-gpt-5.txt +143 -0
  578. package/src/session/prompt/default.txt +151 -0
  579. package/src/session/prompt/gemini.txt +155 -0
  580. package/src/session/prompt/gpt.txt +107 -0
  581. package/src/session/prompt/kimi.txt +95 -0
  582. package/src/session/prompt/max-steps.txt +16 -0
  583. package/src/session/prompt/text-loop-recovery.ts +40 -0
  584. package/src/session/prompt/trinity.txt +97 -0
  585. package/src/session/prompt-utils.ts +58 -0
  586. package/src/session/prompt.ts +3482 -0
  587. package/src/session/prune.ts +481 -0
  588. package/src/session/retry.ts +166 -0
  589. package/src/session/revert.ts +161 -0
  590. package/src/session/run-state.ts +135 -0
  591. package/src/session/schema.ts +36 -0
  592. package/src/session/session.sql.ts +110 -0
  593. package/src/session/session.ts +908 -0
  594. package/src/session/status.ts +89 -0
  595. package/src/session/summary.ts +163 -0
  596. package/src/session/system.ts +86 -0
  597. package/src/session/todo.ts +77 -0
  598. package/src/share/index.ts +2 -0
  599. package/src/share/session.ts +57 -0
  600. package/src/share/share-next.ts +381 -0
  601. package/src/share/share.sql.ts +13 -0
  602. package/src/shell/shell.ts +110 -0
  603. package/src/skill/compose/.bundle/ask/SKILL.md +58 -0
  604. package/src/skill/compose/.bundle/brainstorm/SKILL.md +220 -0
  605. package/src/skill/compose/.bundle/brainstorm/scripts/frame-template.html +214 -0
  606. package/src/skill/compose/.bundle/brainstorm/scripts/helper.js +88 -0
  607. package/src/skill/compose/.bundle/brainstorm/scripts/server.cjs +354 -0
  608. package/src/skill/compose/.bundle/brainstorm/scripts/start-server.sh +148 -0
  609. package/src/skill/compose/.bundle/brainstorm/scripts/stop-server.sh +56 -0
  610. package/src/skill/compose/.bundle/brainstorm/spec-document-reviewer-prompt.md +50 -0
  611. package/src/skill/compose/.bundle/brainstorm/visual-companion.md +287 -0
  612. package/src/skill/compose/.bundle/code-review/SKILL.md +68 -0
  613. package/src/skill/compose/.bundle/debug/CREATION-LOG.md +119 -0
  614. package/src/skill/compose/.bundle/debug/SKILL.md +297 -0
  615. package/src/skill/compose/.bundle/debug/condition-based-waiting-example.ts +158 -0
  616. package/src/skill/compose/.bundle/debug/condition-based-waiting.md +115 -0
  617. package/src/skill/compose/.bundle/debug/defense-in-depth.md +122 -0
  618. package/src/skill/compose/.bundle/debug/find-polluter.sh +63 -0
  619. package/src/skill/compose/.bundle/debug/root-cause-tracing.md +169 -0
  620. package/src/skill/compose/.bundle/debug/test-academic.md +14 -0
  621. package/src/skill/compose/.bundle/debug/test-pressure-1.md +58 -0
  622. package/src/skill/compose/.bundle/debug/test-pressure-2.md +68 -0
  623. package/src/skill/compose/.bundle/debug/test-pressure-3.md +69 -0
  624. package/src/skill/compose/.bundle/execute/SKILL.md +71 -0
  625. package/src/skill/compose/.bundle/feedback/SKILL.md +214 -0
  626. package/src/skill/compose/.bundle/frontend-design/LICENSE.txt +177 -0
  627. package/src/skill/compose/.bundle/frontend-design/SKILL.md +42 -0
  628. package/src/skill/compose/.bundle/mcp-builder/LICENSE.txt +202 -0
  629. package/src/skill/compose/.bundle/mcp-builder/SKILL.md +236 -0
  630. package/src/skill/compose/.bundle/mcp-builder/reference/evaluation.md +602 -0
  631. package/src/skill/compose/.bundle/mcp-builder/reference/mcp_best_practices.md +249 -0
  632. package/src/skill/compose/.bundle/mcp-builder/reference/node_mcp_server.md +970 -0
  633. package/src/skill/compose/.bundle/mcp-builder/reference/python_mcp_server.md +719 -0
  634. package/src/skill/compose/.bundle/mcp-builder/scripts/connections.py +151 -0
  635. package/src/skill/compose/.bundle/mcp-builder/scripts/evaluation.py +373 -0
  636. package/src/skill/compose/.bundle/mcp-builder/scripts/example_evaluation.xml +22 -0
  637. package/src/skill/compose/.bundle/mcp-builder/scripts/requirements.txt +2 -0
  638. package/src/skill/compose/.bundle/merge/SKILL.md +252 -0
  639. package/src/skill/compose/.bundle/new-skill/SKILL.md +656 -0
  640. package/src/skill/compose/.bundle/new-skill/anthropic-best-practices.md +1150 -0
  641. package/src/skill/compose/.bundle/new-skill/examples/CLAUDE_MD_TESTING.md +189 -0
  642. package/src/skill/compose/.bundle/new-skill/graphviz-conventions.dot +172 -0
  643. package/src/skill/compose/.bundle/new-skill/persuasion-principles.md +187 -0
  644. package/src/skill/compose/.bundle/new-skill/render-graphs.js +168 -0
  645. package/src/skill/compose/.bundle/new-skill/testing-skills-with-subagents.md +384 -0
  646. package/src/skill/compose/.bundle/parallel/SKILL.md +182 -0
  647. package/src/skill/compose/.bundle/plan/SKILL.md +161 -0
  648. package/src/skill/compose/.bundle/plan/plan-document-reviewer-prompt.md +50 -0
  649. package/src/skill/compose/.bundle/report/SKILL.md +180 -0
  650. package/src/skill/compose/.bundle/review/SKILL.md +104 -0
  651. package/src/skill/compose/.bundle/review/code-reviewer.md +171 -0
  652. package/src/skill/compose/.bundle/search-first/SKILL.md +161 -0
  653. package/src/skill/compose/.bundle/security-review/SKILL.md +495 -0
  654. package/src/skill/compose/.bundle/security-review/cloud-infrastructure-security.md +361 -0
  655. package/src/skill/compose/.bundle/self-extend/SKILL.md +131 -0
  656. package/src/skill/compose/.bundle/self-extend/reference/hook-api.md +242 -0
  657. package/src/skill/compose/.bundle/self-extend/reference/skill-api.md +114 -0
  658. package/src/skill/compose/.bundle/self-extend/reference/tool-api.md +115 -0
  659. package/src/skill/compose/.bundle/self-extend/reference/tui-api.md +258 -0
  660. package/src/skill/compose/.bundle/skill-status/SKILL.md +37 -0
  661. package/src/skill/compose/.bundle/strategic-compact/SKILL.md +103 -0
  662. package/src/skill/compose/.bundle/strategic-compact/suggest-compact.sh +54 -0
  663. package/src/skill/compose/.bundle/subagent/SKILL.md +344 -0
  664. package/src/skill/compose/.bundle/subagent/code-quality-reviewer-prompt.md +24 -0
  665. package/src/skill/compose/.bundle/subagent/implementer-prompt.md +126 -0
  666. package/src/skill/compose/.bundle/subagent/spec-reviewer-prompt.md +112 -0
  667. package/src/skill/compose/.bundle/tdd/SKILL.md +372 -0
  668. package/src/skill/compose/.bundle/tdd/testing-anti-patterns.md +299 -0
  669. package/src/skill/compose/.bundle/verification-loop/SKILL.md +126 -0
  670. package/src/skill/compose/.bundle/verify/SKILL.md +140 -0
  671. package/src/skill/compose/.bundle/worktree/SKILL.md +234 -0
  672. package/src/skill/compose/LICENSE-karpathy +28 -0
  673. package/src/skill/compose/LICENSE-superpowers +26 -0
  674. package/src/skill/compose/bundle.macro.ts +30 -0
  675. package/src/skill/compose/extract.ts +85 -0
  676. package/src/skill/discovery.ts +116 -0
  677. package/src/skill/index.ts +317 -0
  678. package/src/snapshot/index.ts +777 -0
  679. package/src/sql.d.ts +4 -0
  680. package/src/storage/db.bun.ts +8 -0
  681. package/src/storage/db.node.ts +8 -0
  682. package/src/storage/db.ts +172 -0
  683. package/src/storage/index.ts +26 -0
  684. package/src/storage/json-migration.ts +426 -0
  685. package/src/storage/read-sqlite.bun.ts +11 -0
  686. package/src/storage/read-sqlite.node.ts +13 -0
  687. package/src/storage/read-sqlite.ts +10 -0
  688. package/src/storage/schema.sql.ts +10 -0
  689. package/src/storage/schema.ts +7 -0
  690. package/src/storage/storage.ts +331 -0
  691. package/src/sync/README.md +179 -0
  692. package/src/sync/event.sql.ts +16 -0
  693. package/src/sync/index.ts +278 -0
  694. package/src/sync/schema.ts +14 -0
  695. package/src/task/events.ts +28 -0
  696. package/src/task/gate-state.ts +54 -0
  697. package/src/task/gate.ts +116 -0
  698. package/src/task/index.ts +1 -0
  699. package/src/task/registry.ts +394 -0
  700. package/src/task/schema.ts +43 -0
  701. package/src/task/task.sql.ts +50 -0
  702. package/src/team/events.ts +22 -0
  703. package/src/team/index.ts +113 -0
  704. package/src/team/schema.ts +31 -0
  705. package/src/temporary.ts +33 -0
  706. package/src/tool/actor.shell.txt +72 -0
  707. package/src/tool/actor.ts +808 -0
  708. package/src/tool/actor.txt +103 -0
  709. package/src/tool/apply_patch.ts +308 -0
  710. package/src/tool/apply_patch.txt +33 -0
  711. package/src/tool/bash-interactive.ts +183 -0
  712. package/src/tool/bash.ts +696 -0
  713. package/src/tool/bash.txt +123 -0
  714. package/src/tool/change-directory.ts +91 -0
  715. package/src/tool/codesearch.ts +63 -0
  716. package/src/tool/codesearch.txt +12 -0
  717. package/src/tool/edit.ts +702 -0
  718. package/src/tool/edit.txt +10 -0
  719. package/src/tool/external-directory.ts +132 -0
  720. package/src/tool/glob.ts +100 -0
  721. package/src/tool/glob.txt +6 -0
  722. package/src/tool/grep.ts +145 -0
  723. package/src/tool/grep.txt +8 -0
  724. package/src/tool/history.ts +146 -0
  725. package/src/tool/history.txt +17 -0
  726. package/src/tool/index.ts +4 -0
  727. package/src/tool/invalid.ts +20 -0
  728. package/src/tool/invocation-style.ts +17 -0
  729. package/src/tool/lsp.ts +91 -0
  730. package/src/tool/lsp.txt +19 -0
  731. package/src/tool/mcp-exa.ts +78 -0
  732. package/src/tool/memory-path-guard.ts +162 -0
  733. package/src/tool/memory.ts +81 -0
  734. package/src/tool/memory.txt +69 -0
  735. package/src/tool/multiedit.ts +61 -0
  736. package/src/tool/multiedit.txt +41 -0
  737. package/src/tool/plan-enter.txt +14 -0
  738. package/src/tool/plan-exit.txt +13 -0
  739. package/src/tool/plan.ts +90 -0
  740. package/src/tool/question.ts +67 -0
  741. package/src/tool/question.txt +10 -0
  742. package/src/tool/read.ts +327 -0
  743. package/src/tool/read.txt +14 -0
  744. package/src/tool/recoverable.ts +35 -0
  745. package/src/tool/registry.ts +423 -0
  746. package/src/tool/schema.ts +17 -0
  747. package/src/tool/session-cwd.ts +35 -0
  748. package/src/tool/shell-tokenize.ts +346 -0
  749. package/src/tool/shell-wrap.ts +190 -0
  750. package/src/tool/skill.ts +76 -0
  751. package/src/tool/skill.txt +5 -0
  752. package/src/tool/task.shell.txt +57 -0
  753. package/src/tool/task.ts +456 -0
  754. package/src/tool/task.txt +56 -0
  755. package/src/tool/tool.ts +166 -0
  756. package/src/tool/truncate.ts +201 -0
  757. package/src/tool/truncation-dir.ts +4 -0
  758. package/src/tool/webfetch.ts +199 -0
  759. package/src/tool/webfetch.txt +13 -0
  760. package/src/tool/websearch/index.ts +104 -0
  761. package/src/tool/websearch/mty.ts +14 -0
  762. package/src/tool/websearch/websearch.txt +14 -0
  763. package/src/tool/workflow.ts +164 -0
  764. package/src/tool/workflow.txt +25 -0
  765. package/src/tool/write.ts +97 -0
  766. package/src/tool/write.txt +9 -0
  767. package/src/util/abort.ts +35 -0
  768. package/src/util/archive.ts +15 -0
  769. package/src/util/color.ts +17 -0
  770. package/src/util/data-url.ts +9 -0
  771. package/src/util/defer.ts +10 -0
  772. package/src/util/effect-http-client.ts +11 -0
  773. package/src/util/effect-zod.ts +367 -0
  774. package/src/util/error.ts +78 -0
  775. package/src/util/filesystem.ts +243 -0
  776. package/src/util/fn.ts +21 -0
  777. package/src/util/format.ts +20 -0
  778. package/src/util/iife.ts +3 -0
  779. package/src/util/index.ts +12 -0
  780. package/src/util/keybind.ts +101 -0
  781. package/src/util/lazy.ts +18 -0
  782. package/src/util/local-context.ts +23 -0
  783. package/src/util/locale.ts +79 -0
  784. package/src/util/lock.ts +96 -0
  785. package/src/util/log.ts +228 -0
  786. package/src/util/media.ts +26 -0
  787. package/src/util/mty-process.ts +24 -0
  788. package/src/util/network.ts +9 -0
  789. package/src/util/process.ts +174 -0
  790. package/src/util/queue.ts +60 -0
  791. package/src/util/record.ts +3 -0
  792. package/src/util/rpc.ts +64 -0
  793. package/src/util/schema.ts +53 -0
  794. package/src/util/scrap.ts +10 -0
  795. package/src/util/signal.ts +12 -0
  796. package/src/util/timeout.ts +14 -0
  797. package/src/util/token.ts +5 -0
  798. package/src/util/update-schema.ts +13 -0
  799. package/src/util/which.ts +14 -0
  800. package/src/util/wildcard.ts +57 -0
  801. package/src/workflow/builtin/deep-research.js +391 -0
  802. package/src/workflow/builtin.ts +54 -0
  803. package/src/workflow/events.ts +72 -0
  804. package/src/workflow/meta.ts +335 -0
  805. package/src/workflow/persistence.ts +312 -0
  806. package/src/workflow/resolve.ts +45 -0
  807. package/src/workflow/runtime-ref.ts +18 -0
  808. package/src/workflow/runtime.ts +1234 -0
  809. package/src/workflow/sandbox.ts +286 -0
  810. package/src/workflow/workflow.sql.ts +31 -0
  811. package/src/workflow/workspace.ts +69 -0
  812. package/src/worktree/index.ts +614 -0
  813. package/sst-env.d.ts +10 -0
  814. package/test/AGENTS.md +133 -0
  815. package/test/account/repo.test.ts +352 -0
  816. package/test/account/service.test.ts +456 -0
  817. package/test/acp/agent-interface.test.ts +51 -0
  818. package/test/acp/event-subscription.test.ts +725 -0
  819. package/test/actor/cancel-cascade.test.ts +432 -0
  820. package/test/actor/no-completion-listener.test.ts +41 -0
  821. package/test/actor/poststop-progress-write-permission.repro.test.ts +414 -0
  822. package/test/actor/registry-render.test.ts +113 -0
  823. package/test/actor/registry-status.test.ts +111 -0
  824. package/test/actor/registry.test.ts +619 -0
  825. package/test/actor/return-header.test.ts +40 -0
  826. package/test/actor/spawn-lifecycle.test.ts +346 -0
  827. package/test/actor/spawn-no-deadlock.test.ts +340 -0
  828. package/test/actor/spawn-notification.test.ts +393 -0
  829. package/test/actor/spawn-task-autostart.test.ts +530 -0
  830. package/test/actor/spawn.test.ts +1072 -0
  831. package/test/actor/status-event-payload.test.ts +132 -0
  832. package/test/actor/terminology.test.ts +39 -0
  833. package/test/actor/turn.test.ts +125 -0
  834. package/test/actor/waiter.test.ts +246 -0
  835. package/test/agent/agent.test.ts +874 -0
  836. package/test/agent/allowlist.test.ts +45 -0
  837. package/test/auth/auth.test.ts +86 -0
  838. package/test/bus/bus-effect.test.ts +162 -0
  839. package/test/bus/bus-integration.test.ts +87 -0
  840. package/test/bus/bus.test.ts +219 -0
  841. package/test/cli/account.test.ts +26 -0
  842. package/test/cli/cmd/tui/prompt-part.test.ts +47 -0
  843. package/test/cli/error.test.ts +18 -0
  844. package/test/cli/github-action.test.ts +198 -0
  845. package/test/cli/github-remote.test.ts +80 -0
  846. package/test/cli/import.test.ts +54 -0
  847. package/test/cli/plugin-auth-picker.test.ts +120 -0
  848. package/test/cli/run-completion.test.ts +131 -0
  849. package/test/cli/tui/keybind-plugin.test.ts +90 -0
  850. package/test/cli/tui/plugin-add.test.ts +111 -0
  851. package/test/cli/tui/plugin-install.test.ts +87 -0
  852. package/test/cli/tui/plugin-lifecycle.test.ts +224 -0
  853. package/test/cli/tui/plugin-loader-entrypoint.test.ts +484 -0
  854. package/test/cli/tui/plugin-loader-pure.test.ts +71 -0
  855. package/test/cli/tui/plugin-loader.test.ts +816 -0
  856. package/test/cli/tui/plugin-toggle.test.ts +157 -0
  857. package/test/cli/tui/revert-diff.test.ts +35 -0
  858. package/test/cli/tui/route-agent-id.test.ts +26 -0
  859. package/test/cli/tui/sidebar-tps.test.ts +63 -0
  860. package/test/cli/tui/slot-replace.test.tsx +47 -0
  861. package/test/cli/tui/sync-bucket.test.ts +29 -0
  862. package/test/cli/tui/theme-store.test.ts +51 -0
  863. package/test/cli/tui/thread.test.ts +122 -0
  864. package/test/cli/tui/transcript.test.ts +426 -0
  865. package/test/cli/tui/use-event.test.tsx +175 -0
  866. package/test/cli/tui/voice.test.ts +443 -0
  867. package/test/command/deep-research-command.test.ts +16 -0
  868. package/test/config/agent-color.test.ts +77 -0
  869. package/test/config/checkpoint-fork.test.ts +21 -0
  870. package/test/config/config.test.ts +2577 -0
  871. package/test/config/fixtures/empty-frontmatter.md +4 -0
  872. package/test/config/fixtures/frontmatter.md +28 -0
  873. package/test/config/fixtures/markdown-header.md +11 -0
  874. package/test/config/fixtures/no-frontmatter.md +1 -0
  875. package/test/config/fixtures/weird-model-id.md +13 -0
  876. package/test/config/lsp.test.ts +87 -0
  877. package/test/config/markdown.test.ts +228 -0
  878. package/test/config/plugin.test.ts +0 -0
  879. package/test/config/tui.test.ts +627 -0
  880. package/test/control-plane/adaptors.test.ts +71 -0
  881. package/test/control-plane/sse.test.ts +56 -0
  882. package/test/effect/app-runtime-logger.test.ts +92 -0
  883. package/test/effect/cross-spawn-spawner.test.ts +411 -0
  884. package/test/effect/instance-state.test.ts +482 -0
  885. package/test/effect/observability.test.ts +46 -0
  886. package/test/effect/run-service.test.ts +46 -0
  887. package/test/effect/runner-warn-log.test.ts +111 -0
  888. package/test/effect/runner.test.ts +494 -0
  889. package/test/fake/provider.ts +90 -0
  890. package/test/file/fsmonitor.test.ts +68 -0
  891. package/test/file/ignore.test.ts +10 -0
  892. package/test/file/index.test.ts +956 -0
  893. package/test/file/path-traversal.test.ts +204 -0
  894. package/test/file/ripgrep.test.ts +214 -0
  895. package/test/file/watcher.test.ts +249 -0
  896. package/test/filesystem/filesystem.test.ts +319 -0
  897. package/test/fixture/db.ts +11 -0
  898. package/test/fixture/fixture.test.ts +58 -0
  899. package/test/fixture/fixture.ts +190 -0
  900. package/test/fixture/flock-worker.ts +72 -0
  901. package/test/fixture/lsp/fake-lsp-server.js +75 -0
  902. package/test/fixture/plug-worker.ts +93 -0
  903. package/test/fixture/plugin-meta-worker.ts +19 -0
  904. package/test/fixture/skills/agents-sdk/SKILL.md +152 -0
  905. package/test/fixture/skills/agents-sdk/references/callable.md +92 -0
  906. package/test/fixture/skills/cloudflare/SKILL.md +211 -0
  907. package/test/fixture/skills/index.json +6 -0
  908. package/test/fixture/tui-plugin.ts +328 -0
  909. package/test/fixture/tui-runtime.ts +31 -0
  910. package/test/format/format.test.ts +244 -0
  911. package/test/git/git.test.ts +128 -0
  912. package/test/global/fixture/global-paths-worker.ts +17 -0
  913. package/test/global/mtycoder-home.test.ts +143 -0
  914. package/test/history/backfill.test.ts +149 -0
  915. package/test/history/extract.test.ts +106 -0
  916. package/test/history/fts-query.test.ts +30 -0
  917. package/test/history/resolve.test.ts +130 -0
  918. package/test/history/service.test.ts +210 -0
  919. package/test/history/writer.test.ts +163 -0
  920. package/test/ide/ide.test.ts +82 -0
  921. package/test/inbox/drain-in-loop.test.ts +230 -0
  922. package/test/inbox/fork-agent-compat.test.ts +387 -0
  923. package/test/inbox/gc-on-init.test.ts +167 -0
  924. package/test/inbox/send-no-block.test.ts +120 -0
  925. package/test/inbox/sender-cancel-independence.test.ts +160 -0
  926. package/test/inbox/wake-matrix.test.ts +141 -0
  927. package/test/installation/installation.test.ts +255 -0
  928. package/test/keybind.test.ts +421 -0
  929. package/test/lib/effect.ts +53 -0
  930. package/test/lib/filesystem.ts +10 -0
  931. package/test/lib/llm-server.ts +770 -0
  932. package/test/lib/mock-llm.ts +159 -0
  933. package/test/lib/scripted-llm-server.ts +245 -0
  934. package/test/lsp/client.test.ts +98 -0
  935. package/test/lsp/index.test.ts +109 -0
  936. package/test/lsp/launch.test.ts +22 -0
  937. package/test/lsp/lifecycle.test.ts +184 -0
  938. package/test/mcp/headers.test.ts +178 -0
  939. package/test/mcp/lifecycle.test.ts +824 -0
  940. package/test/mcp/oauth-auto-connect.test.ts +281 -0
  941. package/test/mcp/oauth-browser.test.ts +268 -0
  942. package/test/mcp/oauth-callback.test.ts +34 -0
  943. package/test/memory/abort-leak-webfetch.ts +49 -0
  944. package/test/memory/abort-leak.test.ts +127 -0
  945. package/test/memory/cc-frontmatter.test.ts +85 -0
  946. package/test/memory/cc-paths.test.ts +60 -0
  947. package/test/memory/cc-reconcile.test.ts +239 -0
  948. package/test/memory/cc-search.test.ts +151 -0
  949. package/test/memory/fts-query.test.ts +48 -0
  950. package/test/memory/fts-rowid-stability.test.ts +271 -0
  951. package/test/memory/paths.test.ts +210 -0
  952. package/test/memory/reconcile.test.ts +115 -0
  953. package/test/memory/service.test.ts +169 -0
  954. package/test/npm.test.ts +18 -0
  955. package/test/patch/patch.test.ts +348 -0
  956. package/test/permission/abort.test.ts +116 -0
  957. package/test/permission/arity.test.ts +33 -0
  958. package/test/permission/disabled.test.ts +51 -0
  959. package/test/permission/next.test.ts +1080 -0
  960. package/test/permission/non-interactive.test.ts +55 -0
  961. package/test/permission-task.test.ts +326 -0
  962. package/test/plugin/actor-hooks.test.ts +1471 -0
  963. package/test/plugin/auth-override.test.ts +79 -0
  964. package/test/plugin/checkpoint-splitover.test.ts +434 -0
  965. package/test/plugin/cloudflare.test.ts +68 -0
  966. package/test/plugin/codex.test.ts +123 -0
  967. package/test/plugin/github-copilot-models.test.ts +163 -0
  968. package/test/plugin/install-concurrency.test.ts +140 -0
  969. package/test/plugin/install.test.ts +570 -0
  970. package/test/plugin/loader-shared.test.ts +1169 -0
  971. package/test/plugin/matcher.test.ts +97 -0
  972. package/test/plugin/meta.test.ts +137 -0
  973. package/test/plugin/shared.test.ts +88 -0
  974. package/test/plugin/subagent-progress-checker.test.ts +227 -0
  975. package/test/plugin/trigger.test.ts +116 -0
  976. package/test/plugin/workspace-adaptor.test.ts +109 -0
  977. package/test/preload.ts +102 -0
  978. package/test/project/migrate-global.test.ts +150 -0
  979. package/test/project/project-id.test.ts +64 -0
  980. package/test/project/project.test.ts +502 -0
  981. package/test/project/vcs.test.ts +286 -0
  982. package/test/project/worktree-remove.test.ts +126 -0
  983. package/test/project/worktree.test.ts +214 -0
  984. package/test/provider/amazon-bedrock.test.ts +462 -0
  985. package/test/provider/copilot/convert-to-copilot-messages.test.ts +523 -0
  986. package/test/provider/copilot/copilot-chat-model.test.ts +592 -0
  987. package/test/provider/error.test.ts +160 -0
  988. package/test/provider/gitlab-duo.test.ts +413 -0
  989. package/test/provider/model-groups.test.ts +389 -0
  990. package/test/provider/provider-chunk-timeout.test.ts +23 -0
  991. package/test/provider/provider.test.ts +2648 -0
  992. package/test/provider/transform.test.ts +3379 -0
  993. package/test/pty/pty-output-isolation.test.ts +146 -0
  994. package/test/pty/pty-session.test.ts +102 -0
  995. package/test/pty/pty-shell.test.ts +69 -0
  996. package/test/question/question.test.ts +464 -0
  997. package/test/server/global-session-list.test.ts +105 -0
  998. package/test/server/project-init-git.test.ts +122 -0
  999. package/test/server/session-actions.test.ts +49 -0
  1000. package/test/server/session-list.test.ts +110 -0
  1001. package/test/server/session-messages.test.ts +220 -0
  1002. package/test/server/session-prompt-busy.test.ts +146 -0
  1003. package/test/server/session-select.test.ts +100 -0
  1004. package/test/server/session-task-route.test.ts +165 -0
  1005. package/test/server/summarize-route-main-slice.test.ts +99 -0
  1006. package/test/server/trace-attributes.test.ts +76 -0
  1007. package/test/server/workflows-route.test.ts +279 -0
  1008. package/test/session/bootstrap-skip-system.test.ts +121 -0
  1009. package/test/session/boundary.test.ts +33 -0
  1010. package/test/session/budgeted-read.test.ts +74 -0
  1011. package/test/session/checkpoint-align.test.ts +58 -0
  1012. package/test/session/checkpoint-boundary.test.ts +186 -0
  1013. package/test/session/checkpoint-child-session.test.ts +508 -0
  1014. package/test/session/checkpoint-context.test.ts +141 -0
  1015. package/test/session/checkpoint-drain.test.ts +188 -0
  1016. package/test/session/checkpoint-extract-titles.test.ts +58 -0
  1017. package/test/session/checkpoint-fork-mode.test.ts +576 -0
  1018. package/test/session/checkpoint-main-slice.test.ts +259 -0
  1019. package/test/session/checkpoint-paths.test.ts +78 -0
  1020. package/test/session/checkpoint-permission.test.ts +136 -0
  1021. package/test/session/checkpoint-progress-reconcile.test.ts +219 -0
  1022. package/test/session/checkpoint-rebuild-unify.test.ts +143 -0
  1023. package/test/session/checkpoint-rebuild-v3.test.ts +248 -0
  1024. package/test/session/checkpoint-render-verify.test.ts +512 -0
  1025. package/test/session/checkpoint-retry.test.ts +150 -0
  1026. package/test/session/checkpoint-splitover-integration.test.ts +533 -0
  1027. package/test/session/checkpoint-templates.test.ts +51 -0
  1028. package/test/session/checkpoint-thresholds.test.ts +120 -0
  1029. package/test/session/checkpoint-validator.test.ts +189 -0
  1030. package/test/session/classify-integration.test.ts +476 -0
  1031. package/test/session/classify.test.ts +335 -0
  1032. package/test/session/codex-import.test.ts +331 -0
  1033. package/test/session/compaction-agent-scope.test.ts +209 -0
  1034. package/test/session/context-inheritance.test.ts +46 -0
  1035. package/test/session/external-import.test.ts +17 -0
  1036. package/test/session/fork-prefix-invariant.test.ts +116 -0
  1037. package/test/session/goal.test.ts +106 -0
  1038. package/test/session/instruction.test.ts +387 -0
  1039. package/test/session/invalid-output-continuation.test.ts +150 -0
  1040. package/test/session/last-message-info.test.ts +47 -0
  1041. package/test/session/length-tool-safety.test.ts +121 -0
  1042. package/test/session/llm-request-prefix.test.ts +197 -0
  1043. package/test/session/llm-retry.test.ts +59 -0
  1044. package/test/session/llm-system-prompt.test.ts +479 -0
  1045. package/test/session/llm.test.ts +1272 -0
  1046. package/test/session/main-lifecycle.test.ts +51 -0
  1047. package/test/session/main-runloop-history-invariant.test.ts +182 -0
  1048. package/test/session/max-mode-econnreset.test.ts +229 -0
  1049. package/test/session/max-mode.test.ts +54 -0
  1050. package/test/session/message-v2-filter.test.ts +197 -0
  1051. package/test/session/message-v2.test.ts +1119 -0
  1052. package/test/session/messages-default-main.test.ts +105 -0
  1053. package/test/session/messages-pagination.test.ts +888 -0
  1054. package/test/session/overflow.test.ts +576 -0
  1055. package/test/session/processor-effect.test.ts +853 -0
  1056. package/test/session/prompt-effect.test.ts +1609 -0
  1057. package/test/session/prompt-rebuild-loop.test.ts +108 -0
  1058. package/test/session/prompt-rebuild-reset.test.ts +67 -0
  1059. package/test/session/prompt-sweep.test.ts +145 -0
  1060. package/test/session/prompt-task-gate.test.ts +127 -0
  1061. package/test/session/prompt.test.ts +703 -0
  1062. package/test/session/prune-main-slice.test.ts +272 -0
  1063. package/test/session/prune-skip-system.test.ts +346 -0
  1064. package/test/session/prune.test.ts +419 -0
  1065. package/test/session/rebuild-microcompact.test.ts +318 -0
  1066. package/test/session/recall-reminder.test.ts +37 -0
  1067. package/test/session/retry.test.ts +410 -0
  1068. package/test/session/revert-compact.test.ts +639 -0
  1069. package/test/session/run-state-tuple-key.test.ts +152 -0
  1070. package/test/session/session-create-registers-main.test.ts +70 -0
  1071. package/test/session/session.test.ts +181 -0
  1072. package/test/session/snapshot-tool-race.test.ts +301 -0
  1073. package/test/session/structured-output-integration.test.ts +264 -0
  1074. package/test/session/structured-output-retry.test.ts +127 -0
  1075. package/test/session/structured-output.test.ts +397 -0
  1076. package/test/session/summary-main-slice.test.ts +170 -0
  1077. package/test/session/system.test.ts +72 -0
  1078. package/test/session/text-loop-detection.test.ts +185 -0
  1079. package/test/session/text-loop-integration.test.ts +448 -0
  1080. package/test/share/share-next.test.ts +332 -0
  1081. package/test/shell/shell.test.ts +73 -0
  1082. package/test/skill/compose-review.test.ts +141 -0
  1083. package/test/skill/discovery.test.ts +116 -0
  1084. package/test/skill/skill.test.ts +465 -0
  1085. package/test/snapshot/snapshot.test.ts +1531 -0
  1086. package/test/storage/db.test.ts +16 -0
  1087. package/test/storage/json-migration.test.ts +831 -0
  1088. package/test/storage/storage.test.ts +293 -0
  1089. package/test/sync/index.test.ts +237 -0
  1090. package/test/task/gate-state.test.ts +66 -0
  1091. package/test/task/gate.test.ts +167 -0
  1092. package/test/task/registry.test.ts +171 -0
  1093. package/test/task/state-machine.test.ts +292 -0
  1094. package/test/team/migrate-to-inbox.test.ts +124 -0
  1095. package/test/team/team.test.ts +75 -0
  1096. package/test/tool/__snapshots__/tool.test.ts.snap +9 -0
  1097. package/test/tool/actor-cancel.test.ts +206 -0
  1098. package/test/tool/actor-recover.test.ts +50 -0
  1099. package/test/tool/actor-send.test.ts +200 -0
  1100. package/test/tool/actor-status.test.ts +296 -0
  1101. package/test/tool/actor-wait.test.ts +193 -0
  1102. package/test/tool/actor.shell.test.ts +250 -0
  1103. package/test/tool/actor.test.ts +748 -0
  1104. package/test/tool/apply_patch.test.ts +626 -0
  1105. package/test/tool/bash.test.ts +1195 -0
  1106. package/test/tool/describe-workflow.test.ts +12 -0
  1107. package/test/tool/edit.test.ts +691 -0
  1108. package/test/tool/external-directory.test.ts +207 -0
  1109. package/test/tool/fixtures/large-image.png +0 -0
  1110. package/test/tool/fixtures/models-api.json +65179 -0
  1111. package/test/tool/glob.test.ts +81 -0
  1112. package/test/tool/grep.test.ts +114 -0
  1113. package/test/tool/history.test.ts +144 -0
  1114. package/test/tool/invocation-style.test.ts +30 -0
  1115. package/test/tool/memory-edit-ask-skip.test.ts +62 -0
  1116. package/test/tool/memory-path-guard.test.ts +594 -0
  1117. package/test/tool/memory.test.ts +71 -0
  1118. package/test/tool/question.test.ts +167 -0
  1119. package/test/tool/read.test.ts +483 -0
  1120. package/test/tool/recoverable.test.ts +36 -0
  1121. package/test/tool/registry-invocation-style.test.ts +121 -0
  1122. package/test/tool/registry.test.ts +164 -0
  1123. package/test/tool/shell-tokenize.test.ts +273 -0
  1124. package/test/tool/shell-wrap-missing-script.test.ts +128 -0
  1125. package/test/tool/shell-wrap.test.ts +257 -0
  1126. package/test/tool/skill.test.ts +99 -0
  1127. package/test/tool/task-recover.test.ts +36 -0
  1128. package/test/tool/task.shell.test.ts +234 -0
  1129. package/test/tool/task.test.ts +296 -0
  1130. package/test/tool/tool-def-shell-shape.test.ts +23 -0
  1131. package/test/tool/tool-define.test.ts +59 -0
  1132. package/test/tool/tool-validation-error.test.ts +25 -0
  1133. package/test/tool/truncation.test.ts +253 -0
  1134. package/test/tool/webfetch.test.ts +103 -0
  1135. package/test/tool/whitelist.test.ts +373 -0
  1136. package/test/tool/write.test.ts +244 -0
  1137. package/test/util/data-url.test.ts +14 -0
  1138. package/test/util/effect-zod.test.ts +869 -0
  1139. package/test/util/error.test.ts +38 -0
  1140. package/test/util/filesystem.test.ts +656 -0
  1141. package/test/util/format.test.ts +59 -0
  1142. package/test/util/glob.test.ts +164 -0
  1143. package/test/util/iife.test.ts +36 -0
  1144. package/test/util/lazy.test.ts +50 -0
  1145. package/test/util/lock.test.ts +72 -0
  1146. package/test/util/log.test.ts +69 -0
  1147. package/test/util/module.test.ts +59 -0
  1148. package/test/util/process.test.ts +128 -0
  1149. package/test/util/queue.test.ts +64 -0
  1150. package/test/util/timeout.test.ts +21 -0
  1151. package/test/util/which.test.ts +100 -0
  1152. package/test/util/wildcard.test.ts +90 -0
  1153. package/test/workflow/builtin.test.ts +22 -0
  1154. package/test/workflow/deep-research-cluster.test.ts +47 -0
  1155. package/test/workflow/lib.ts +243 -0
  1156. package/test/workflow/meta.test.ts +142 -0
  1157. package/test/workflow/model-routing.test.ts +68 -0
  1158. package/test/workflow/persistence.test.ts +229 -0
  1159. package/test/workflow/resolve.test.ts +37 -0
  1160. package/test/workflow/runtime-nested.test.ts +419 -0
  1161. package/test/workflow/runtime-worktree.test.ts +261 -0
  1162. package/test/workflow/runtime.test.ts +1078 -0
  1163. package/test/workflow/sandbox.test.ts +259 -0
  1164. package/test/workflow/tool.test.ts +473 -0
  1165. package/test/workflow/verify-wow.test.ts +144 -0
  1166. package/test/workflow/workspace.test.ts +88 -0
  1167. package/test/workspace/workspace-restore.test.ts +281 -0
  1168. package/test/worktree/index.test.ts +30 -0
  1169. package/tsconfig.json +24 -0
@@ -0,0 +1,344 @@
1
+ ---
2
+ name: compose:subagent
3
+ hidden: true
4
+ description: Use when executing implementation plans with independent tasks in the current session
5
+ ---
6
+
7
+ # Subagent-Driven Development
8
+
9
+ Execute plan by dispatching fresh subagent per task, with two-stage review after each: spec compliance review first, then code quality review.
10
+
11
+ **Why subagents:** You delegate tasks to specialized agents with isolated context. By precisely crafting their instructions and context, you ensure they stay focused and succeed at their task. They should never inherit your session's context or history — you construct exactly what they need. This also preserves your own context for coordination work.
12
+
13
+ **Core principle:** Fresh subagent per task + two-stage review (spec then quality) = high quality, fast iteration
14
+
15
+ **Continuous execution:** Do not pause to check in with your human partner between tasks. Execute all tasks from the plan without stopping. The only reasons to stop are: BLOCKED status you cannot resolve, ambiguity that genuinely prevents progress, or all tasks complete. "Should I continue?" prompts and progress summaries waste their time — they asked you to execute the plan, so execute it. When you must stop for ambiguity or a blocker, use `compose:ask` to present the situation with structured options. If no user is available, resolve it with your best judgment and continue.
16
+
17
+ ## When to Use
18
+
19
+ ```dot
20
+ digraph when_to_use {
21
+ "Have implementation plan?" [shape=diamond];
22
+ "Tasks mostly independent?" [shape=diamond];
23
+ "Stay in this session?" [shape=diamond];
24
+ "compose:subagent" [shape=box];
25
+ "compose:execute" [shape=box];
26
+ "Manual execution or brainstorm first" [shape=box];
27
+
28
+ "Have implementation plan?" -> "Tasks mostly independent?" [label="yes"];
29
+ "Have implementation plan?" -> "Manual execution or brainstorm first" [label="no"];
30
+ "Tasks mostly independent?" -> "Stay in this session?" [label="yes"];
31
+ "Tasks mostly independent?" -> "Manual execution or brainstorm first" [label="no - tightly coupled"];
32
+ "Stay in this session?" -> "compose:subagent" [label="yes"];
33
+ "Stay in this session?" -> "compose:execute" [label="no - parallel session"];
34
+ }
35
+ ```
36
+
37
+ **vs. Executing Plans (parallel session):**
38
+ - Same session (no context switch)
39
+ - Fresh subagent per task (no context pollution)
40
+ - Two-stage review after each task: spec compliance first, then code quality
41
+ - Faster iteration (no human-in-loop between tasks)
42
+
43
+ ## The Process
44
+
45
+ ```dot
46
+ digraph process {
47
+ rankdir=TB;
48
+
49
+ subgraph cluster_per_task {
50
+ label="Per Task";
51
+ "Inject covered spec as Intent, dispatch implementer (./implementer-prompt.md)" [shape=box label="Create+bind task (--task <TID>, auto-starts), inject Intent, dispatch implementer (./implementer-prompt.md)"];
52
+ "Implementer subagent asks questions?" [shape=diamond];
53
+ "Answer questions, provide context" [shape=box];
54
+ "Implementer subagent implements, tests, commits, self-reviews" [shape=box];
55
+ "Dispatch spec reviewer phase 1 (spec + diff only, no report)" [shape=box];
56
+ "Phase 1 flagged anything?" [shape=diamond];
57
+ "Dispatch spec reviewer phase 2 (report explains flags, downgrade-only)" [shape=box];
58
+ "Gate: all in-scope claims pass with evidence?" [shape=diamond];
59
+ "Implementer subagent fixes failing/unverifiable claims" [shape=box];
60
+ "Dispatch code quality reviewer subagent (./code-quality-reviewer-prompt.md)" [shape=box];
61
+ "Code quality reviewer subagent approves?" [shape=diamond];
62
+ "Implementer subagent fixes quality issues" [shape=box];
63
+ "Mark task done (task done <TID>)" [shape=box];
64
+ }
65
+
66
+ "Read plan, extract all tasks with full text, note context, create a task per plan task (task create)" [shape=box];
67
+ "More tasks remain?" [shape=diamond];
68
+ "Dispatch final code reviewer subagent for entire implementation" [shape=box];
69
+ "Use compose:merge" [shape=box style=filled fillcolor=lightgreen];
70
+
71
+ "Read plan, extract all tasks with full text, note context, create a task per plan task (task create)" -> "Inject covered spec as Intent, dispatch implementer (./implementer-prompt.md)";
72
+ "Inject covered spec as Intent, dispatch implementer (./implementer-prompt.md)" -> "Implementer subagent asks questions?";
73
+ "Implementer subagent asks questions?" -> "Answer questions, provide context" [label="yes"];
74
+ "Answer questions, provide context" -> "Inject covered spec as Intent, dispatch implementer (./implementer-prompt.md)";
75
+ "Implementer subagent asks questions?" -> "Implementer subagent implements, tests, commits, self-reviews" [label="no"];
76
+ "Implementer subagent implements, tests, commits, self-reviews" -> "Dispatch spec reviewer phase 1 (spec + diff only, no report)";
77
+ "Dispatch spec reviewer phase 1 (spec + diff only, no report)" -> "Phase 1 flagged anything?";
78
+ "Phase 1 flagged anything?" -> "Dispatch spec reviewer phase 2 (report explains flags, downgrade-only)" [label="yes"];
79
+ "Phase 1 flagged anything?" -> "Gate: all in-scope claims pass with evidence?" [label="no"];
80
+ "Dispatch spec reviewer phase 2 (report explains flags, downgrade-only)" -> "Gate: all in-scope claims pass with evidence?";
81
+ "Gate: all in-scope claims pass with evidence?" -> "Implementer subagent fixes failing/unverifiable claims" [label="no"];
82
+ "Implementer subagent fixes failing/unverifiable claims" -> "Dispatch spec reviewer phase 1 (spec + diff only, no report)" [label="re-review"];
83
+ "Gate: all in-scope claims pass with evidence?" -> "Dispatch code quality reviewer subagent (./code-quality-reviewer-prompt.md)" [label="yes"];
84
+ "Dispatch code quality reviewer subagent (./code-quality-reviewer-prompt.md)" -> "Code quality reviewer subagent approves?";
85
+ "Code quality reviewer subagent approves?" -> "Implementer subagent fixes quality issues" [label="no"];
86
+ "Implementer subagent fixes quality issues" -> "Dispatch code quality reviewer subagent (./code-quality-reviewer-prompt.md)" [label="re-review"];
87
+ "Code quality reviewer subagent approves?" -> "Mark task done (task done <TID>)" [label="yes"];
88
+ "Mark task done (task done <TID>)" -> "More tasks remain?";
89
+ "More tasks remain?" -> "Inject covered spec as Intent, dispatch implementer (./implementer-prompt.md)" [label="yes"];
90
+ "More tasks remain?" -> "Dispatch final code reviewer subagent for entire implementation" [label="no"];
91
+ "Dispatch final code reviewer subagent for entire implementation" -> "Use compose:merge";
92
+ }
93
+ ```
94
+
95
+ ## Spec-Anchored Review Gate
96
+
97
+ This is how each task's spec-compliance review works. It replaces a single
98
+ prose review with intent-grounded implementation and a two-phase, evidence-gated
99
+ verdict.
100
+
101
+ **1. Create and bind a task before dispatching.** Before the implementer runs, create
102
+ a work-item with the `task` tool (`task create "<plan task summary>"`) and capture its
103
+ TID. Dispatch the implementer bound to that task by passing `--task <TID>` on the actor
104
+ call (`actor run general "<desc>" "<prompt>" --task T3`). Binding auto-starts the task
105
+ to `in_progress` with the subagent as owner, and lets the postStop hook validate the
106
+ task's progress. Do NOT mark the task done here — completion is gated on review (step 4).
107
+
108
+ **2. Inject intent before dispatching the implementer.** Read the task's `Covers:`
109
+ field, pull the verbatim text of those `[Sn]` spec sections, and paste it into the
110
+ implementer prompt's `## Intent (from spec)` block (see `./implementer-prompt.md`).
111
+ The implementer never reads the spec itself — you hand it exactly the sections its
112
+ task covers, with the scope boundary intact.
113
+
114
+ **3. Run the spec reviewer in two phases** (see `./spec-reviewer-prompt.md`):
115
+ - **Phase 1:** dispatch with the covered spec section text + `git diff` ONLY. Do NOT
116
+ include the implementer's report — its claims anchor the reviewer toward confirming
117
+ what was reported and away from spotting silent omissions. Phase 1 returns a
118
+ structured per-claim verdict.
119
+ - **Phase 2:** only if phase 1 flagged anything. Re-dispatch the same reviewer with
120
+ its phase-1 verdict + the implementer's report, solely to let the report explain
121
+ flagged diffs. Phase 2 may downgrade a flagged item; it cannot add passes.
122
+
123
+ **4. Gate on the verdict.** The task is complete ONLY when the final verdict is
124
+ `Status: pass` AND every `in-scope` claim is `status: pass` with evidence. Any
125
+ `fail` or `unverifiable` in-scope claim → re-dispatch the implementer with the
126
+ specific failing claims, then re-review. Loop until the gate passes. Then run the
127
+ code quality review (spec compliance always precedes quality), and once that also
128
+ passes, mark the bound task done with `task done <TID>`.
129
+
130
+ A structured `pass` without verifiable evidence (test name, command output, or
131
+ `file:line`) does not satisfy the gate — treat it as `fail`. Prose is not evidence.
132
+
133
+ ## Model Selection
134
+
135
+ Use the least powerful model that can handle each role to conserve cost and increase speed.
136
+
137
+ **Mechanical implementation tasks** (isolated functions, clear specs, 1-2 files): use a fast, cheap model. Most implementation tasks are mechanical when the plan is well-specified.
138
+
139
+ **Integration and judgment tasks** (multi-file coordination, pattern matching, debugging): use a standard model.
140
+
141
+ **Architecture, design, and review tasks**: use the most capable available model.
142
+
143
+ **Task complexity signals:**
144
+ - Touches 1-2 files with a complete spec → cheap model
145
+ - Touches multiple files with integration concerns → standard model
146
+ - Requires design judgment or broad codebase understanding → most capable model
147
+
148
+ **Reviewer tier:** Dispatch the spec reviewer at a model tier at least as capable as
149
+ the implementer's. A reviewer weaker than the implementer shares its blind spots and
150
+ rubber-stamps the same misreadings; the adversarial value of review comes from the
151
+ reviewer interpreting the spec independently, which a weaker model cannot reliably do.
152
+
153
+ ## Handling Implementer Status
154
+
155
+ Implementer subagents report one of four statuses. Handle each appropriately:
156
+
157
+ **DONE:** Proceed to spec compliance review.
158
+
159
+ **DONE_WITH_CONCERNS:** The implementer completed the work but flagged doubts. Read the concerns before proceeding. If the concerns are about correctness or scope, address them before review. If they're observations (e.g., "this file is getting large"), note them and proceed to review.
160
+
161
+ **NEEDS_CONTEXT:** The implementer needs information that wasn't provided. Provide the missing context and re-dispatch.
162
+
163
+ **BLOCKED:** The implementer cannot complete the task. Assess the blocker:
164
+ 1. If it's a context problem, provide more context and re-dispatch with the same model
165
+ 2. If the task requires more reasoning, re-dispatch with a more capable model
166
+ 3. If the task is too large, break it into smaller pieces
167
+ 4. If the plan itself is wrong, escalate to the human
168
+
169
+ **Never** ignore an escalation or force the same model to retry without changes. If the implementer said it's stuck, something needs to change.
170
+
171
+ ## Prompt Templates
172
+
173
+ - `./implementer-prompt.md` - Dispatch implementer subagent
174
+ - `./spec-reviewer-prompt.md` - Dispatch spec compliance reviewer (two-phase, evidence-gated verdict)
175
+ - `./code-quality-reviewer-prompt.md` - Dispatch code quality reviewer subagent
176
+
177
+ ## Example Workflow
178
+
179
+ ```
180
+ You: I'm using Subagent-Driven Development to execute this plan.
181
+
182
+ [Read plan file once: docs/compose/plans/feature-plan.md]
183
+ [Extract all 5 tasks with full text and context]
184
+ [Create a task per plan task with `task create`, capturing each TID]
185
+
186
+ Task 1: Hook installation script
187
+
188
+ [Get Task 1 text and context (already extracted)]
189
+ [Dispatch implementation subagent with full task text + context, bound to its task: actor run general "..." "..." --task T1 — binding auto-starts T1 to in_progress]
190
+
191
+ Implementer: "Before I begin - should the hook be installed at user or system level?"
192
+
193
+ You: "User level (~/.config/compose/hooks/)"
194
+
195
+ Implementer: "Got it. Implementing now..."
196
+ [Later] Implementer:
197
+ - Implemented install-hook command
198
+ - Added tests, 5/5 passing
199
+ - Self-review: Found I missed --force flag, added it
200
+ - Committed
201
+
202
+ [Inject covered spec [Sn] sections as Intent; implementer builds]
203
+ [Dispatch spec reviewer phase 1: spec sections + diff only, no report]
204
+ Spec reviewer (phase 1):
205
+ Status: pass
206
+ Claims: [S1 · "install at user level"] in-scope · pass — evidence: test "installs to ~/.config" 5/5
207
+ [Phase 1 all-pass → skip phase 2; gate passes]
208
+
209
+ [Dispatch code quality reviewer]
210
+ Code reviewer: Strengths: Good test coverage, clean. Issues: None. Approved.
211
+
212
+ [Gate passed → mark Task 1 done: task done T1]
213
+
214
+ Task 2: Recovery modes
215
+
216
+ [Get Task 2 text and context (already extracted)]
217
+ [Dispatch implementation subagent with full task text + context]
218
+
219
+ Implementer: [No questions, proceeds]
220
+ Implementer:
221
+ - Added verify/repair modes
222
+ - 8/8 tests passing
223
+ - Self-review: All good
224
+ - Committed
225
+
226
+ [Dispatch spec reviewer phase 1: spec sections + diff only, no report]
227
+ Spec reviewer (phase 1):
228
+ Status: fail
229
+ Claims:
230
+ - [S4 · "report every 100 items"] in-scope · fail — evidence: no progress code in diff (omission)
231
+ - [S4 · "verify/repair modes"] in-scope · pass — evidence: test "repairs index" 8/8
232
+ Extra work: --json flag (no covered claim requires it)
233
+ [Phase 1 flagged items → dispatch phase 2 with report]
234
+ Spec reviewer (phase 2): report gives no justification for --json; progress still missing — Status: fail
235
+ [Gate blocks: in-scope fail]
236
+
237
+ [Implementer fixes: removed --json, added progress reporting]
238
+ [Re-dispatch phase 1]
239
+ Spec reviewer (phase 1): Status: pass — all in-scope claims pass with evidence
240
+ [Gate passes]
241
+
242
+ [Dispatch code quality reviewer]
243
+ Code reviewer: Strengths: Solid. Issues (Important): Magic number (100)
244
+
245
+ [Implementer fixes]
246
+ Implementer: Extracted PROGRESS_INTERVAL constant
247
+
248
+ [Code reviewer reviews again]
249
+ Code reviewer: ✅ Approved
250
+
251
+ [Gate passed → mark Task 2 done: task done T2]
252
+
253
+ ...
254
+
255
+ [After all tasks]
256
+ [Dispatch final code-reviewer]
257
+ Final reviewer: All requirements met, ready to merge
258
+
259
+ Done!
260
+ ```
261
+
262
+ ## Advantages
263
+
264
+ **vs. Manual execution:**
265
+ - Subagents follow TDD naturally
266
+ - Fresh context per task (no confusion)
267
+ - Parallel-safe (subagents don't interfere)
268
+ - Subagent can ask questions (before AND during work)
269
+
270
+ **vs. Executing Plans:**
271
+ - Same session (no handoff)
272
+ - Continuous progress (no waiting)
273
+ - Review checkpoints automatic
274
+
275
+ **Efficiency gains:**
276
+ - No file reading overhead (controller provides full text)
277
+ - Controller curates exactly what context is needed
278
+ - Subagent gets complete information upfront
279
+ - Questions surfaced before work begins (not after)
280
+
281
+ **Quality gates:**
282
+ - Self-review catches issues before handoff
283
+ - Two-stage review: spec compliance, then code quality
284
+ - Review loops ensure fixes actually work
285
+ - Spec compliance prevents over/under-building
286
+ - Code quality ensures implementation is well-built
287
+
288
+ **Cost:**
289
+ - More subagent invocations (implementer + 2 reviewers per task)
290
+ - Controller does more prep work (extracting all tasks upfront)
291
+ - Review loops add iterations
292
+ - But catches issues early (cheaper than debugging later)
293
+
294
+ ## Red Flags
295
+
296
+ **Never:**
297
+ - Start implementation on main/master branch without explicit user consent
298
+ - Skip reviews (spec compliance OR code quality)
299
+ - Proceed with unfixed issues
300
+ - Dispatch multiple implementation subagents in parallel (conflicts)
301
+ - Make subagent read plan file (provide full text instead)
302
+ - Skip scene-setting context (subagent needs to understand where task fits)
303
+ - Ignore subagent questions (answer before letting them proceed)
304
+ - Accept "close enough" on spec compliance (spec reviewer found issues = not done)
305
+ - Skip review loops (reviewer found issues = implementer fixes = review again)
306
+ - Let implementer self-review replace actual review (both are needed)
307
+ - **Start code quality review before spec compliance is ✅** (wrong order)
308
+ - Move to next task while either review has open issues
309
+ - Pass the spec gate on a `status: pass` that has no verifiable evidence (test/exec/file:line)
310
+ - Include the implementer's report in the phase-1 spec review context
311
+ - Mark a task complete while any in-scope claim is `fail` or `unverifiable`
312
+
313
+ **If subagent asks questions:**
314
+ - Answer clearly and completely
315
+ - Provide additional context if needed
316
+ - Don't rush them into implementation
317
+
318
+ **If reviewer finds issues:**
319
+ - Implementer (same subagent) fixes them
320
+ - Reviewer reviews again
321
+ - Repeat until approved
322
+ - Don't skip the re-review
323
+
324
+ **If subagent fails task:**
325
+ - Dispatch fix subagent with specific instructions
326
+ - Don't try to fix manually (context pollution)
327
+
328
+ ## Integration
329
+
330
+ **Required workflow skills:**
331
+ - **compose:worktree** - Ensures isolated workspace (creates one or verifies existing)
332
+ - **compose:plan** - Creates the plan this skill executes
333
+ - **compose:review** - Code review template for reviewer subagents
334
+ - **compose:merge** - Complete development after all tasks
335
+
336
+ **Subagents should use:**
337
+ - **compose:tdd** - Subagents follow TDD for each task
338
+
339
+ **Important: Passing skills to subagents**
340
+
341
+ Compose skills do NOT appear in subagents' `available_skills` list. When a subagent needs to use a skill, pass the relevant `<compose_skills>` block (or subset) directly in the subagent's prompt. Include this note alongside the block: "The skills listed in <compose_skills> are NOT in your available_skills — this is by design. You can invoke them by name using the skill tool, or read the SKILL.md at the location path."
342
+
343
+ **Alternative workflow:**
344
+ - **compose:execute** - Use for parallel session instead of same-session execution
@@ -0,0 +1,24 @@
1
+ # Code Quality Reviewer Prompt Template
2
+
3
+ Use this template when dispatching a code quality reviewer subagent.
4
+
5
+ **Purpose:** Verify implementation is well-built (clean, tested, maintainable)
6
+
7
+ **Only dispatch after spec compliance review passes.**
8
+
9
+ Dispatch a `general` subagent via the `actor` tool, following the syntax in that
10
+ tool's own description. Build the prompt from
11
+ `<compose:review>/code-reviewer.md`, filling in:
12
+
13
+ - DESCRIPTION: [task summary, from implementer's report]
14
+ - PLAN_OR_REQUIREMENTS: Task N from [plan-file]
15
+ - BASE_SHA: [commit before task]
16
+ - HEAD_SHA: [current commit]
17
+
18
+ **In addition to standard code quality concerns, the reviewer should check:**
19
+ - Does each file have one clear responsibility with a well-defined interface?
20
+ - Are units decomposed so they can be understood and tested independently?
21
+ - Is the implementation following the file structure from the plan?
22
+ - Did this implementation create new files that are already large, or significantly grow existing files? (Don't flag pre-existing file sizes — focus on what this change contributed.)
23
+
24
+ **Code reviewer returns:** Strengths, Issues (Critical/Important/Minor), Assessment
@@ -0,0 +1,126 @@
1
+ # Implementer Subagent Prompt Template
2
+
3
+ Use this template when dispatching an implementer subagent.
4
+
5
+ Dispatch a `general` subagent via the `actor` tool, following the syntax in that
6
+ tool's own description. Use a title like "Implement Task N: [task name]" and give
7
+ it this prompt:
8
+
9
+ ~~~
10
+ You are implementing Task N: [task name]
11
+
12
+ ## Intent (from spec)
13
+
14
+ [Controller pastes the verbatim text of the spec `[Sn]` sections this task's
15
+ Covers field lists — the WHY and the acceptance criteria behind the task. If the
16
+ task covers no spec section (pure scaffolding), write "(no spec section — scaffolding task)".]
17
+
18
+ **Scope boundary:** This intent is background so you understand what the task
19
+ serves. Implement ONLY the claims this task covers, as detailed in the Task
20
+ Description below. Do NOT build other claims that appear in these spec sections —
21
+ other tasks cover them. If the Task Description seems to contradict this intent,
22
+ stop and report DONE_WITH_CONCERNS rather than guessing which to follow.
23
+
24
+ ## Task Description
25
+
26
+ [FULL TEXT of task from plan - paste it here, don't make subagent read file]
27
+
28
+ ## Context
29
+
30
+ [Scene-setting: where this fits, dependencies, architectural context]
31
+
32
+ ## Before You Begin
33
+
34
+ If you have questions about:
35
+ - The requirements or acceptance criteria
36
+ - The approach or implementation strategy
37
+ - Dependencies or assumptions
38
+ - Anything unclear in the task description
39
+
40
+ **Ask them now.** Raise any concerns before starting work.
41
+
42
+ ## Your Job
43
+
44
+ Once you're clear on requirements:
45
+ 1. Implement exactly what the task specifies
46
+ 2. Write tests (following TDD if task says to)
47
+ 3. Verify implementation works
48
+ 4. Commit your work
49
+ 5. Self-review (see below)
50
+ 6. Report back
51
+
52
+ Work from: [directory]
53
+
54
+ **While you work:** If you encounter something unexpected or unclear, **ask questions**.
55
+ It's always OK to pause and clarify. Don't guess or make assumptions.
56
+
57
+ ## Code Organization
58
+
59
+ You reason best about code you can hold in context at once, and your edits are more
60
+ reliable when files are focused. Keep this in mind:
61
+ - Follow the file structure defined in the plan
62
+ - Each file should have one clear responsibility with a well-defined interface
63
+ - If a file you're creating is growing beyond the plan's intent, stop and report
64
+ it as DONE_WITH_CONCERNS — don't split files on your own without plan guidance
65
+ - If an existing file you're modifying is already large or tangled, work carefully
66
+ and note it as a concern in your report
67
+ - In existing codebases, follow established patterns. Improve code you're touching
68
+ the way a good developer would, but don't restructure things outside your task.
69
+
70
+ ## When You're in Over Your Head
71
+
72
+ It is always OK to stop and say "this is too hard for me." Bad work is worse than
73
+ no work. You will not be penalized for escalating.
74
+
75
+ **STOP and escalate when:**
76
+ - The task requires architectural decisions with multiple valid approaches
77
+ - You need to understand code beyond what was provided and can't find clarity
78
+ - You feel uncertain about whether your approach is correct
79
+ - The task involves restructuring existing code in ways the plan didn't anticipate
80
+ - You've been reading file after file trying to understand the system without progress
81
+
82
+ **How to escalate:** Report back with status BLOCKED or NEEDS_CONTEXT. Describe
83
+ specifically what you're stuck on, what you've tried, and what kind of help you need.
84
+ The controller can provide more context, re-dispatch with a more capable model,
85
+ or break the task into smaller pieces.
86
+
87
+ ## Before Reporting Back: Self-Review
88
+
89
+ Review your work with fresh eyes. Ask yourself:
90
+
91
+ **Completeness:**
92
+ - Did I fully implement everything in the spec?
93
+ - Did I miss any requirements?
94
+ - Are there edge cases I didn't handle?
95
+
96
+ **Quality:**
97
+ - Is this my best work?
98
+ - Are names clear and accurate (match what things do, not how they work)?
99
+ - Is the code clean and maintainable?
100
+
101
+ **Discipline:**
102
+ - Did I avoid overbuilding (YAGNI)?
103
+ - Did I only build what was requested?
104
+ - Did I follow existing patterns in the codebase?
105
+
106
+ **Testing:**
107
+ - Do tests actually verify behavior (not just mock behavior)?
108
+ - Did I follow TDD if required?
109
+ - Are tests comprehensive?
110
+
111
+ If you find issues during self-review, fix them now before reporting.
112
+
113
+ ## Report Format
114
+
115
+ When done, report:
116
+ - **Status:** DONE | DONE_WITH_CONCERNS | BLOCKED | NEEDS_CONTEXT
117
+ - What you implemented (or what you attempted, if blocked)
118
+ - What you tested and test results
119
+ - Files changed
120
+ - Self-review findings (if any)
121
+ - Any issues or concerns
122
+
123
+ Use DONE_WITH_CONCERNS if you completed the work but have doubts about correctness.
124
+ Use BLOCKED if you cannot complete the task. Use NEEDS_CONTEXT if you need
125
+ information that wasn't provided. Never silently produce work you're unsure about.
126
+ ~~~
@@ -0,0 +1,112 @@
1
+ # Spec Compliance Reviewer Prompt Template
2
+
3
+ Use this template when dispatching a spec compliance reviewer subagent.
4
+
5
+ **Purpose:** Verify the implementation matches the spec it claims to cover — nothing
6
+ missing, nothing misinterpreted, nothing extra — and return a machine-checkable
7
+ verdict the controller can gate on.
8
+
9
+ This reviewer runs in **two phases**. Dispatch phase 1 first. Dispatch phase 2 only
10
+ if phase 1 flags anything (if phase 1 is all-pass there is nothing to downgrade, so
11
+ skip phase 2).
12
+
13
+ ## Phase 1 — independent judgment (no implementer report)
14
+
15
+ Dispatch with the spec section text and the diff ONLY. Do NOT include the
16
+ implementer's report — its claims would anchor the reviewer toward confirming what
17
+ was reported and away from finding what was silently omitted.
18
+
19
+ Dispatch a spec-compliance reviewer as a `general` subagent via the `actor` tool,
20
+ following the syntax in that tool's own description. Use a title like "Spec
21
+ review Task N — phase 1" and give it this prompt:
22
+
23
+ ~~~
24
+ You are verifying whether an implementation matches its specification. Judge
25
+ INDEPENDENTLY. You are given the spec sections the task must satisfy and the
26
+ code diff — nothing else. There is deliberately no implementer report; do not
27
+ ask for one.
28
+
29
+ ## Spec sections this task covers
30
+
31
+ [Controller pastes verbatim text of the covered [Sn] spec sections]
32
+
33
+ ## Git range to review
34
+
35
+ **Base:** {BASE_SHA}
36
+ **Head:** {HEAD_SHA}
37
+
38
+ ```bash
39
+ git diff {BASE_SHA}..{HEAD_SHA}
40
+ ```
41
+
42
+ ## Your job
43
+
44
+ 1. Read each covered spec section and enumerate the distinct, checkable CLAIMS
45
+ inside it (a section usually contains several). A claim is one verifiable
46
+ statement about required behavior.
47
+ 2. For each claim, decide if it is in scope for THIS task. The task covers a
48
+ subset of the section; claims other tasks own are out of scope here.
49
+ 3. For each in-scope claim, verify it against the diff. Remember: the diff shows
50
+ what changed, not what is missing. A required behavior with no corresponding
51
+ code is a FAIL even though no diff line points to it — actively look for
52
+ omissions.
53
+ 4. Evidence is mandatory. A claim's status is backed by a test name, command
54
+ execution output, or a `file:line` reference. A status asserted without such
55
+ evidence is `fail`. Prose like "looks implemented" is NOT evidence.
56
+ 5. If a claim describes runtime behavior you cannot judge from the diff alone,
57
+ run the relevant test or command and cite the output. If you cannot verify it,
58
+ mark it `unverifiable` — never a silent pass.
59
+
60
+ ## Output format (return EXACTLY this structure)
61
+
62
+ **Status**: pass | fail
63
+ (pass only if every in-scope claim is `pass` with evidence)
64
+
65
+ **Claims**:
66
+ - [Sn · "<short claim text>"] in-scope · status: pass
67
+ evidence: <test name | command output | file:line>
68
+ - [Sn · "<short claim text>"] in-scope · status: fail
69
+ evidence: <what's missing or wrong, with file:line if applicable>
70
+ - [Sn · "<short claim text>"] out-of-scope-for-this-task
71
+ - [Sn · "<short claim text>"] in-scope · status: unverifiable
72
+ evidence: <why it can't be verified from available material>
73
+
74
+ **Extra work not traced to any covered claim**:
75
+ - <file:line — what was built that no covered claim required, or "(none)">
76
+ ~~~
77
+
78
+ ## Phase 2 — rationale reconciliation (sees the report)
79
+
80
+ Only if phase 1 flagged any `fail`, `unverifiable`, or extra work. Give the SAME
81
+ reviewer its phase-1 verdict plus the implementer's report. The report may explain a
82
+ flagged diff ("that odd line is a deliberate decision described in my report").
83
+
84
+ Dispatch the same reviewer again as a `general` subagent via the `actor` tool,
85
+ with a title like "Spec review Task N — phase 2", and this prompt:
86
+
87
+ ~~~
88
+ Here is your phase-1 verdict and the implementer's report. Use the report ONLY
89
+ to explain items you flagged. You may downgrade a flagged item to a phase-2 note
90
+ if the report justifies it. You CANNOT add new passes and CANNOT upgrade a
91
+ `fail` to `pass` — a report claim is not evidence. If a fail genuinely needs
92
+ re-verification with fresh evidence (test/exec/file:line), that belongs in a new
93
+ phase-1 re-review after the implementer acts, not here.
94
+
95
+ ## Your phase-1 verdict
96
+ [paste phase-1 output]
97
+
98
+ ## Implementer report
99
+ [paste implementer's report]
100
+
101
+ ## Output format
102
+ **Status**: pass | fail (unchanged unless a downgrade clears the last failure)
103
+ **Claims**: [same structure as phase 1, with any downgraded items annotated]
104
+ **Phase-2 notes**:
105
+ - [Sn · "<claim>"] downgraded: <report's justification> — was: <prior status>
106
+ ~~~
107
+
108
+ **Placeholders:** `{BASE_SHA}`, `{HEAD_SHA}` — commit range for this task.
109
+
110
+ **Reviewer returns:** structured Status + per-claim verdicts. The controller gates on
111
+ this (see `compose:subagent`): the task is not complete while any in-scope claim is
112
+ `fail` or `unverifiable`.