saeeol 1.2.5 → 1.2.7

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 (483) hide show
  1. package/package.json +15 -12
  2. package/src/ltm/config.ts +15 -15
  3. package/src/ltm/events.ts +1 -1
  4. package/src/ltm/index.ts +1 -1
  5. package/src/ltm/pipeline.ts +22 -22
  6. package/src/ltm/scheduler.ts +20 -20
  7. package/src/ltm/store.ts +9 -7
  8. package/src/ltm/types.ts +16 -16
  9. package/src/provider/local/embedder.ts +21 -21
  10. package/src/provider/models-snapshot.d.ts +2 -0
  11. package/src/provider/models-snapshot.js +3 -0
  12. package/src/session/message/message-errors.ts +1 -1
  13. package/src/session/message/message-parts.ts +1 -1
  14. package/src/session/message/message-transform.ts +1 -1
  15. package/src/session/message/message-types.ts +1 -1
  16. package/src/tool/core/tool.ts +1 -1
  17. package/AGENTS.md +0 -72
  18. package/BUN_SHELL_MIGRATION_PLAN.md +0 -136
  19. package/Dockerfile +0 -18
  20. package/assets/saeeol.ico +0 -0
  21. package/bin/saeeol +0 -187
  22. package/bunfig.toml +0 -7
  23. package/database.db +0 -0
  24. package/drizzle.config.ts +0 -10
  25. package/git +0 -0
  26. package/migration/20260127222353_familiar_lady_ursula/migration.sql +0 -90
  27. package/migration/20260127222353_familiar_lady_ursula/snapshot.json +0 -796
  28. package/migration/20260211171708_add_project_commands/migration.sql +0 -1
  29. package/migration/20260211171708_add_project_commands/snapshot.json +0 -806
  30. package/migration/20260213144116_wakeful_the_professor/migration.sql +0 -11
  31. package/migration/20260213144116_wakeful_the_professor/snapshot.json +0 -897
  32. package/migration/20260225215848_workspace/migration.sql +0 -7
  33. package/migration/20260225215848_workspace/snapshot.json +0 -959
  34. package/migration/20260227213759_add_session_workspace_id/migration.sql +0 -2
  35. package/migration/20260227213759_add_session_workspace_id/snapshot.json +0 -983
  36. package/migration/20260228203230_blue_harpoon/migration.sql +0 -17
  37. package/migration/20260228203230_blue_harpoon/snapshot.json +0 -1102
  38. package/migration/20260303231226_add_workspace_fields/migration.sql +0 -5
  39. package/migration/20260303231226_add_workspace_fields/snapshot.json +0 -1013
  40. package/migration/20260309230000_move_org_to_state/migration.sql +0 -3
  41. package/migration/20260309230000_move_org_to_state/snapshot.json +0 -1156
  42. package/migration/20260312043431_session_message_cursor/migration.sql +0 -4
  43. package/migration/20260312043431_session_message_cursor/snapshot.json +0 -1168
  44. package/migration/20260323234822_events/migration.sql +0 -13
  45. package/migration/20260323234822_events/snapshot.json +0 -1271
  46. package/migration/20260410174513_workspace-name/migration.sql +0 -16
  47. package/migration/20260410174513_workspace-name/snapshot.json +0 -1271
  48. package/migration/20260413175956_chief_energizer/migration.sql +0 -13
  49. package/migration/20260413175956_chief_energizer/snapshot.json +0 -1399
  50. package/migration/20260423070820_add_icon_url_override/migration.sql +0 -2
  51. package/migration/20260423070820_add_icon_url_override/snapshot.json +0 -1409
  52. package/migration/20260428004200_add_session_path/migration.sql +0 -1
  53. package/migration/20260428004200_add_session_path/snapshot.json +0 -1419
  54. package/npm/bin/saeeol +0 -42
  55. package/npm/package.json +0 -39
  56. package/npm/postinstall.js +0 -162
  57. package/parsers-config.ts +0 -289
  58. package/script/build.ts +0 -393
  59. package/script/check-migrations.ts +0 -16
  60. package/script/fix-node-pty.ts +0 -34
  61. package/script/generate.ts +0 -23
  62. package/script/postinstall.mjs +0 -189
  63. package/script/publish.ts +0 -200
  64. package/script/run-workspace-server +0 -106
  65. package/script/schema.ts +0 -63
  66. package/script/test-runner.ts +0 -420
  67. package/script/time.ts +0 -6
  68. package/script/trace-imports.ts +0 -153
  69. package/script/upgrade-opentui.ts +0 -64
  70. package/scripts/diff-sdk-types.sh +0 -52
  71. package/specs/effect/facades.md +0 -221
  72. package/specs/effect/http-api.md +0 -401
  73. package/specs/effect/instance-context.md +0 -309
  74. package/specs/effect/loose-ends.md +0 -34
  75. package/specs/effect/migration.md +0 -299
  76. package/specs/effect/routes.md +0 -64
  77. package/specs/effect/schema.md +0 -399
  78. package/specs/effect/server-package.md +0 -668
  79. package/specs/effect/tools.md +0 -90
  80. package/specs/tui-plugins.md +0 -433
  81. package/specs/v2/api.ts +0 -67
  82. package/specs/v2/keymappings.md +0 -10
  83. package/specs/v2/message-shape.md +0 -136
  84. package/src/tool/apply_patch.txt +0 -33
  85. package/src/tool/bash.txt +0 -119
  86. package/src/tool/edit.txt +0 -10
  87. package/src/tool/glob.txt +0 -6
  88. package/src/tool/grep.txt +0 -8
  89. package/src/tool/lsp.txt +0 -24
  90. package/src/tool/plan-enter.txt +0 -14
  91. package/src/tool/plan-exit.txt +0 -13
  92. package/src/tool/question.txt +0 -11
  93. package/src/tool/read.txt +0 -14
  94. package/src/tool/recall.txt +0 -12
  95. package/src/tool/skill.txt +0 -5
  96. package/src/tool/task.txt +0 -57
  97. package/src/tool/todowrite.txt +0 -167
  98. package/src/tool/warpgrep.txt +0 -10
  99. package/src/tool/webfetch.txt +0 -13
  100. package/src/tool/websearch.txt +0 -14
  101. package/src/tool/write.txt +0 -8
  102. package/sst-env.d.ts +0 -10
  103. package/test/AGENTS.md +0 -133
  104. package/test/account/repo.test.ts +0 -352
  105. package/test/account/service.test.ts +0 -456
  106. package/test/acp/agent-interface.test.ts +0 -51
  107. package/test/acp/event-subscription.test.ts +0 -725
  108. package/test/agent/agent.test.ts +0 -890
  109. package/test/auth/auth.test.ts +0 -86
  110. package/test/bun/registry.test.ts +0 -75
  111. package/test/bus/bus-effect.test.ts +0 -161
  112. package/test/bus/bus-integration.test.ts +0 -87
  113. package/test/bus/bus.test.ts +0 -219
  114. package/test/cli/account.test.ts +0 -26
  115. package/test/cli/auto-mode.test.ts +0 -75
  116. package/test/cli/bin-saeeol.test.ts +0 -8
  117. package/test/cli/cmd/tui/prompt-part.test.ts +0 -47
  118. package/test/cli/cmd/tui/prompt-traits.test.ts +0 -38
  119. package/test/cli/cmd/tui/sync.test.tsx +0 -159
  120. package/test/cli/error.test.ts +0 -18
  121. package/test/cli/github-action.test.ts +0 -198
  122. package/test/cli/github-remote.test.ts +0 -85
  123. package/test/cli/import.test.ts +0 -97
  124. package/test/cli/install-artifact.test.ts +0 -72
  125. package/test/cli/plugin-auth-picker.test.ts +0 -120
  126. package/test/cli/pr.test.ts +0 -59
  127. package/test/cli/tui/editor-context-zed.test.ts +0 -356
  128. package/test/cli/tui/editor-context.test.tsx +0 -228
  129. package/test/cli/tui/keybind-plugin.test.ts +0 -90
  130. package/test/cli/tui/markdown.test.ts +0 -161
  131. package/test/cli/tui/plugin-add.test.ts +0 -111
  132. package/test/cli/tui/plugin-install.test.ts +0 -87
  133. package/test/cli/tui/plugin-lifecycle.test.ts +0 -224
  134. package/test/cli/tui/plugin-loader-entrypoint.test.ts +0 -484
  135. package/test/cli/tui/plugin-loader-pure.test.ts +0 -71
  136. package/test/cli/tui/plugin-loader.test.ts +0 -816
  137. package/test/cli/tui/plugin-toggle.test.ts +0 -157
  138. package/test/cli/tui/revert-diff.test.ts +0 -35
  139. package/test/cli/tui/slot-replace.test.tsx +0 -47
  140. package/test/cli/tui/theme-store.test.ts +0 -54
  141. package/test/cli/tui/thread.test.ts +0 -28
  142. package/test/cli/tui/transcript.test.ts +0 -426
  143. package/test/cli/tui/usage.test.ts +0 -60
  144. package/test/cli/tui/use-event.test.tsx +0 -175
  145. package/test/config/agent-color.test.ts +0 -67
  146. package/test/config/config.test.ts +0 -2544
  147. package/test/config/fixtures/empty-frontmatter.md +0 -4
  148. package/test/config/fixtures/frontmatter.md +0 -28
  149. package/test/config/fixtures/markdown-header.md +0 -11
  150. package/test/config/fixtures/no-frontmatter.md +0 -1
  151. package/test/config/fixtures/weird-model-id.md +0 -13
  152. package/test/config/lsp.test.ts +0 -87
  153. package/test/config/markdown.test.ts +0 -228
  154. package/test/config/plugin.test.ts +0 -0
  155. package/test/config/tui.test.ts +0 -624
  156. package/test/control-plane/adapters.test.ts +0 -71
  157. package/test/control-plane/workspace.test.ts +0 -1526
  158. package/test/effect/app-runtime-logger.test.ts +0 -98
  159. package/test/effect/config-service.test.ts +0 -65
  160. package/test/effect/instance-state.test.ts +0 -394
  161. package/test/effect/run-service.test.ts +0 -89
  162. package/test/effect/runner.test.ts +0 -523
  163. package/test/fake/provider.ts +0 -82
  164. package/test/file/fsmonitor.test.ts +0 -68
  165. package/test/file/ignore.test.ts +0 -10
  166. package/test/file/index.test.ts +0 -954
  167. package/test/file/path-traversal.test.ts +0 -205
  168. package/test/file/ripgrep.test.ts +0 -226
  169. package/test/file/watcher.test.ts +0 -249
  170. package/test/filesystem/filesystem.test.ts +0 -319
  171. package/test/fixture/db.ts +0 -11
  172. package/test/fixture/fixture.test.ts +0 -26
  173. package/test/fixture/fixture.ts +0 -175
  174. package/test/fixture/flock-worker.ts +0 -72
  175. package/test/fixture/log-init-worker.ts +0 -62
  176. package/test/fixture/lsp/fake-lsp-server.js +0 -249
  177. package/test/fixture/plug-worker.ts +0 -93
  178. package/test/fixture/plugin-meta-worker.ts +0 -19
  179. package/test/fixture/skills/agents-sdk/SKILL.md +0 -152
  180. package/test/fixture/skills/cloudflare/SKILL.md +0 -211
  181. package/test/fixture/skills/index.json +0 -6
  182. package/test/fixture/tui-plugin.ts +0 -323
  183. package/test/fixture/tui-runtime.ts +0 -31
  184. package/test/format/format.test.ts +0 -272
  185. package/test/git/git.test.ts +0 -128
  186. package/test/ide/ide.test.ts +0 -82
  187. package/test/installation/installation.test.ts +0 -168
  188. package/test/keybind.test.ts +0 -421
  189. package/test/lib/effect.ts +0 -53
  190. package/test/lib/filesystem.ts +0 -10
  191. package/test/lib/llm-server.ts +0 -778
  192. package/test/lib/websocket.ts +0 -46
  193. package/test/lsp/client.test.ts +0 -482
  194. package/test/lsp/index.test.ts +0 -160
  195. package/test/lsp/launch.test.ts +0 -22
  196. package/test/lsp/lifecycle.test.ts +0 -184
  197. package/test/ltm/ltm.test.ts +0 -230
  198. package/test/mcp/headers.test.ts +0 -178
  199. package/test/mcp/lifecycle.test.ts +0 -787
  200. package/test/mcp/oauth-auto-connect.test.ts +0 -311
  201. package/test/mcp/oauth-browser.test.ts +0 -276
  202. package/test/mcp/oauth-callback.test.ts +0 -34
  203. package/test/memory/abort-leak-webfetch.ts +0 -49
  204. package/test/memory/abort-leak.test.ts +0 -128
  205. package/test/patch/patch.test.ts +0 -348
  206. package/test/permission/arity.test.ts +0 -33
  207. package/test/permission/next.test.ts +0 -1227
  208. package/test/permission/next.toConfig.test.ts +0 -110
  209. package/test/permission-task.test.ts +0 -326
  210. package/test/plugin/auth-override.test.ts +0 -79
  211. package/test/plugin/cloudflare.test.ts +0 -68
  212. package/test/plugin/codex.test.ts +0 -123
  213. package/test/plugin/github-copilot-models.test.ts +0 -261
  214. package/test/plugin/install-concurrency.test.ts +0 -140
  215. package/test/plugin/install.test.ts +0 -570
  216. package/test/plugin/loader-shared.test.ts +0 -1169
  217. package/test/plugin/meta.test.ts +0 -137
  218. package/test/plugin/shared.test.ts +0 -88
  219. package/test/plugin/trigger.test.ts +0 -102
  220. package/test/plugin/workspace-adapter.test.ts +0 -109
  221. package/test/preload.ts +0 -77
  222. package/test/project/instance.test.ts +0 -276
  223. package/test/project/migrate-global.test.ts +0 -152
  224. package/test/project/project.test.ts +0 -600
  225. package/test/project/vcs.test.ts +0 -286
  226. package/test/project/worktree-remove.test.ts +0 -126
  227. package/test/project/worktree.test.ts +0 -223
  228. package/test/provider/amazon-bedrock.test.ts +0 -462
  229. package/test/provider/copilot/convert-to-copilot-messages.test.ts +0 -523
  230. package/test/provider/copilot/copilot-chat-model.test.ts +0 -592
  231. package/test/provider/gitlab-duo.test.ts +0 -413
  232. package/test/provider/local.test.ts +0 -208
  233. package/test/provider/models.test.ts +0 -261
  234. package/test/provider/provider-category.test.ts +0 -190
  235. package/test/provider/provider.test.ts +0 -2758
  236. package/test/provider/transform.test.ts +0 -3681
  237. package/test/pty/pty-output-isolation.test.ts +0 -147
  238. package/test/pty/pty-session.test.ts +0 -102
  239. package/test/pty/pty-shell.test.ts +0 -104
  240. package/test/question/question.test.ts +0 -490
  241. package/test/saeeol/agent-global-config-dirs.test.ts +0 -24
  242. package/test/saeeol/agent-manager-tool.test.ts +0 -71
  243. package/test/saeeol/agent-permission-overrides.test.ts +0 -75
  244. package/test/saeeol/agent-skill-permissions.test.ts +0 -37
  245. package/test/saeeol/ask-agent-permissions.test.ts +0 -303
  246. package/test/saeeol/bash-hierarchy.test.ts +0 -64
  247. package/test/saeeol/bash-permission-metadata.test.ts +0 -66
  248. package/test/saeeol/bash-security-extended.test.ts +0 -243
  249. package/test/saeeol/bedrock-claude-empty-content.test.ts +0 -138
  250. package/test/saeeol/boxes-integration.test.ts +0 -415
  251. package/test/saeeol/builtin-skills.test.ts +0 -75
  252. package/test/saeeol/cleanup.ts +0 -28
  253. package/test/saeeol/cli/dev-setup.test.ts +0 -74
  254. package/test/saeeol/cli/roll-call.test.ts +0 -161
  255. package/test/saeeol/cli-run-auto-helper.test.ts +0 -58
  256. package/test/saeeol/codex-auth-refresh.test.ts +0 -124
  257. package/test/saeeol/commit-message/generate.test.ts +0 -188
  258. package/test/saeeol/commit-message/git-context.test.ts +0 -303
  259. package/test/saeeol/commit-message-windows.test.ts +0 -38
  260. package/test/saeeol/compaction-payload-recovery.test.ts +0 -406
  261. package/test/saeeol/compaction-preservation-audit.test.ts +0 -122
  262. package/test/saeeol/compaction-skip-guard.test.ts +0 -224
  263. package/test/saeeol/compaction-smart-select.test.ts +0 -100
  264. package/test/saeeol/config/config.test.ts +0 -166
  265. package/test/saeeol/config/indexing-default-plugin.test.ts +0 -82
  266. package/test/saeeol/config/opentelemetry-default.test.ts +0 -29
  267. package/test/saeeol/config-gitignore.test.ts +0 -70
  268. package/test/saeeol/config-injector.test.ts +0 -305
  269. package/test/saeeol/config-resilience.test.ts +0 -234
  270. package/test/saeeol/config-validation.test.ts +0 -183
  271. package/test/saeeol/cost-propagation.test.ts +0 -94
  272. package/test/saeeol/cost-tracker-extended.test.ts +0 -141
  273. package/test/saeeol/cost-tracker.test.ts +0 -64
  274. package/test/saeeol/custom-provider-delete.test.ts +0 -149
  275. package/test/saeeol/diff-full.test.ts +0 -226
  276. package/test/saeeol/edit-permission-filediff.test.ts +0 -223
  277. package/test/saeeol/encoding.test.ts +0 -364
  278. package/test/saeeol/enhance-prompt.test.ts +0 -61
  279. package/test/saeeol/ensure-plan-dir.test.ts +0 -32
  280. package/test/saeeol/errors.test.ts +0 -144
  281. package/test/saeeol/external-directory-boundary.test.ts +0 -96
  282. package/test/saeeol/gateway-headers.test.ts +0 -88
  283. package/test/saeeol/help.test.ts +0 -191
  284. package/test/saeeol/ignore-migrator.test.ts +0 -308
  285. package/test/saeeol/indexing-auth.test.ts +0 -45
  286. package/test/saeeol/indexing-feature.test.ts +0 -44
  287. package/test/saeeol/indexing-label.test.ts +0 -70
  288. package/test/saeeol/indexing-startup.test.ts +0 -381
  289. package/test/saeeol/indexing-worktree.test.ts +0 -73
  290. package/test/saeeol/instruction.test.ts +0 -136
  291. package/test/saeeol/lancedb-runtime.test.ts +0 -116
  292. package/test/saeeol/loader-auth.test.ts +0 -168
  293. package/test/saeeol/local-model.test.ts +0 -621
  294. package/test/saeeol/logo.test.ts +0 -31
  295. package/test/saeeol/lsp-typescript-lightweight.test.ts +0 -89
  296. package/test/saeeol/mcp-branding.test.ts +0 -33
  297. package/test/saeeol/mcp-docker-rm.test.ts +0 -32
  298. package/test/saeeol/mcp-migrator.test.ts +0 -736
  299. package/test/saeeol/mcp-oauth-callback.test.ts +0 -33
  300. package/test/saeeol/memory-io.test.ts +0 -198
  301. package/test/saeeol/memory-paths.test.ts +0 -87
  302. package/test/saeeol/memory-security.test.ts +0 -166
  303. package/test/saeeol/model-cache-org.test.ts +0 -164
  304. package/test/saeeol/model-info-panel-utils.test.ts +0 -52
  305. package/test/saeeol/model-info-panel.types.test.ts +0 -7
  306. package/test/saeeol/models-401-fallback.test.ts +0 -52
  307. package/test/saeeol/modes-migrator.test.ts +0 -320
  308. package/test/saeeol/nvidia-headers.test.ts +0 -74
  309. package/test/saeeol/patch-jsonc.test.ts +0 -73
  310. package/test/saeeol/patch.test.ts +0 -172
  311. package/test/saeeol/paths.test.ts +0 -265
  312. package/test/saeeol/permission/config-paths.test.ts +0 -174
  313. package/test/saeeol/permission/env-read.test.ts +0 -149
  314. package/test/saeeol/permission/external-directory-allow.test.ts +0 -327
  315. package/test/saeeol/permission/next.always-rules.test.ts +0 -882
  316. package/test/saeeol/permission/next.reply-http.test.ts +0 -205
  317. package/test/saeeol/permission/next.reply-routing.test.ts +0 -184
  318. package/test/saeeol/plan-exit-detection.test.ts +0 -494
  319. package/test/saeeol/plan-followup.test.ts +0 -1376
  320. package/test/saeeol/project-config-update.test.ts +0 -120
  321. package/test/saeeol/project-id.test.ts +0 -455
  322. package/test/saeeol/provider-cost.test.ts +0 -171
  323. package/test/saeeol/provider-list-failed-state.test.ts +0 -100
  324. package/test/saeeol/question-dismiss-all.test.ts +0 -174
  325. package/test/saeeol/read-directory.test.ts +0 -116
  326. package/test/saeeol/rules-migrator.test.ts +0 -257
  327. package/test/saeeol/run-auto.test.ts +0 -176
  328. package/test/saeeol/run-network.test.ts +0 -224
  329. package/test/saeeol/semantic-search.test.ts +0 -186
  330. package/test/saeeol/server/permission-allow-everything.test.ts +0 -125
  331. package/test/saeeol/session/instruction-substitution.test.ts +0 -72
  332. package/test/saeeol/session/platform-attribution.test.ts +0 -118
  333. package/test/saeeol/session/session.test.ts +0 -105
  334. package/test/saeeol/session-compaction-cap.test.ts +0 -399
  335. package/test/saeeol/session-compaction-chunks.test.ts +0 -501
  336. package/test/saeeol/session-compaction-safety.test.ts +0 -481
  337. package/test/saeeol/session-fork-remap.test.ts +0 -251
  338. package/test/saeeol/session-import-service.test.ts +0 -114
  339. package/test/saeeol/session-list.test.ts +0 -47
  340. package/test/saeeol/session-message-metadata.test.ts +0 -128
  341. package/test/saeeol/session-overflow.test.ts +0 -78
  342. package/test/saeeol/session-processor-empty-tool-calls.test.ts +0 -571
  343. package/test/saeeol/session-processor-network-offline.test.ts +0 -204
  344. package/test/saeeol/session-processor-retry-limit.test.ts +0 -238
  345. package/test/saeeol/session-processor-review-telemetry.test.ts +0 -82
  346. package/test/saeeol/session-prompt-compaction-safety.test.ts +0 -517
  347. package/test/saeeol/session-prompt-queue.test.ts +0 -815
  348. package/test/saeeol/sessions/inflight-cache.test.ts +0 -157
  349. package/test/saeeol/sessions/ingest-queue.test.ts +0 -402
  350. package/test/saeeol/sessions/remote-protocol.test.ts +0 -258
  351. package/test/saeeol/sessions/remote-sender.test.ts +0 -1036
  352. package/test/saeeol/sessions/remote-ws.test.ts +0 -367
  353. package/test/saeeol/sessions/sessions-enable-remote.test.disable +0 -181
  354. package/test/saeeol/slot-prop-reactivity.test.ts +0 -142
  355. package/test/saeeol/snapshot-cache.test.ts +0 -84
  356. package/test/saeeol/snapshot-freeze-repro.test.ts +0 -100
  357. package/test/saeeol/snapshot-track-timeout.test.ts +0 -519
  358. package/test/saeeol/stats-subagent-cost.test.ts +0 -123
  359. package/test/saeeol/suggestion/auto-dismiss.test.ts +0 -65
  360. package/test/saeeol/suggestion/suggestion.test.ts +0 -145
  361. package/test/saeeol/suggestion/tool.test.ts +0 -298
  362. package/test/saeeol/summary-file-diff.test.ts +0 -28
  363. package/test/saeeol/system-prompt.test.ts +0 -142
  364. package/test/saeeol/task-nesting.test.ts +0 -193
  365. package/test/saeeol/telemetry/feedback.test.ts +0 -8
  366. package/test/saeeol/todo-view.test.ts +0 -57
  367. package/test/saeeol/tool-encoding.test.ts +0 -455
  368. package/test/saeeol/tool-registry-indexing-import-failure.test.ts +0 -49
  369. package/test/saeeol/tool-registry-indexing.test.ts +0 -236
  370. package/test/saeeol/tool-registry-semantic-import-failure.test.ts +0 -55
  371. package/test/saeeol/tool-task-model.test.ts +0 -352
  372. package/test/saeeol/transform-opus-4.7.test.ts +0 -89
  373. package/test/saeeol/tui-diff.test.ts +0 -91
  374. package/test/saeeol/tui-sync.test.ts +0 -80
  375. package/test/saeeol/util/url.test.ts +0 -141
  376. package/test/saeeol/workflows-migrator.test.ts +0 -261
  377. package/test/saeeol/worktree-diff-summary.test.ts +0 -64
  378. package/test/saeeol/worktree-diff.test.ts +0 -223
  379. package/test/saeeol/worktree-remove-lock.test.ts +0 -82
  380. package/test/server/AGENTS.md +0 -15
  381. package/test/server/contract.test.ts +0 -231
  382. package/test/server/experimental-session-list.test.ts +0 -157
  383. package/test/server/global-session-list.test.ts +0 -155
  384. package/test/server/httpapi-authorization.test.ts +0 -103
  385. package/test/server/httpapi-bridge.test.ts +0 -440
  386. package/test/server/httpapi-config.test.ts +0 -67
  387. package/test/server/httpapi-cors.test.ts +0 -89
  388. package/test/server/httpapi-event.test.ts +0 -57
  389. package/test/server/httpapi-experimental.test.ts +0 -219
  390. package/test/server/httpapi-file.test.ts +0 -79
  391. package/test/server/httpapi-instance-context.test.ts +0 -237
  392. package/test/server/httpapi-instance.legacy.test.ts +0 -140
  393. package/test/server/httpapi-instance.test.ts +0 -83
  394. package/test/server/httpapi-json-parity.test.ts +0 -263
  395. package/test/server/httpapi-mcp-oauth.test.ts +0 -76
  396. package/test/server/httpapi-mcp.test.ts +0 -189
  397. package/test/server/httpapi-provider.test.ts +0 -153
  398. package/test/server/httpapi-pty-websocket.test.ts +0 -16
  399. package/test/server/httpapi-pty.test.ts +0 -175
  400. package/test/server/httpapi-raw-route-auth.test.ts +0 -89
  401. package/test/server/httpapi-sdk.test.ts +0 -679
  402. package/test/server/httpapi-session.test.ts +0 -464
  403. package/test/server/httpapi-sync.test.ts +0 -130
  404. package/test/server/httpapi-tui.test.ts +0 -121
  405. package/test/server/httpapi-workspace-routing.test.ts +0 -471
  406. package/test/server/httpapi-workspace.test.ts +0 -427
  407. package/test/server/project-init-git.test.ts +0 -113
  408. package/test/server/proxy-util.test.ts +0 -113
  409. package/test/server/session-actions.test.ts +0 -49
  410. package/test/server/session-list.test.ts +0 -238
  411. package/test/server/session-messages.test.ts +0 -167
  412. package/test/server/session-select.test.ts +0 -100
  413. package/test/server/trace-attributes.test.ts +0 -76
  414. package/test/server/workspace-proxy.test.ts +0 -165
  415. package/test/server/workspace-routing.test.ts +0 -85
  416. package/test/session/compaction.test.ts +0 -2420
  417. package/test/session/instruction.test.ts +0 -247
  418. package/test/session/llm.test.ts +0 -1273
  419. package/test/session/message-v2.test.ts +0 -1291
  420. package/test/session/messages-pagination.test.ts +0 -1173
  421. package/test/session/network.test.ts +0 -249
  422. package/test/session/processor-effect.test.ts +0 -847
  423. package/test/session/prompt.test.ts +0 -2131
  424. package/test/session/retry.test.ts +0 -340
  425. package/test/session/revert-compact.test.ts +0 -639
  426. package/test/session/schema-decoding.test.ts +0 -311
  427. package/test/session/session-entry-stepper.test.ts +0 -917
  428. package/test/session/session-schema.test.ts +0 -76
  429. package/test/session/snapshot-tool-race.test.ts +0 -257
  430. package/test/session/structured-output-integration.test.ts +0 -265
  431. package/test/session/structured-output.test.ts +0 -381
  432. package/test/session/system.test.ts +0 -73
  433. package/test/share/share-next.test.ts +0 -333
  434. package/test/shell/shell.test.ts +0 -99
  435. package/test/skill/discovery.test.ts +0 -116
  436. package/test/skill/skill.test.ts +0 -393
  437. package/test/snapshot/snapshot.test.ts +0 -1531
  438. package/test/storage/db.test.ts +0 -23
  439. package/test/storage/json-migration.test.ts +0 -832
  440. package/test/storage/storage.test.ts +0 -293
  441. package/test/suggestion/suggestion.test.ts +0 -1
  442. package/test/sync/index.test.ts +0 -256
  443. package/test/tool/__snapshots__/parameters.test.ts.snap +0 -500
  444. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  445. package/test/tool/apply_patch.test.ts +0 -614
  446. package/test/tool/bash.test.ts +0 -1225
  447. package/test/tool/diagnostics-filter.test.ts +0 -55
  448. package/test/tool/edit.test.ts +0 -754
  449. package/test/tool/external-directory.test.ts +0 -169
  450. package/test/tool/fixtures/large-image.png +0 -0
  451. package/test/tool/fixtures/models-api.json +0 -65179
  452. package/test/tool/glob.test.ts +0 -107
  453. package/test/tool/grep.test.ts +0 -114
  454. package/test/tool/lsp.test.ts +0 -187
  455. package/test/tool/parameters.test.ts +0 -243
  456. package/test/tool/question.test.ts +0 -129
  457. package/test/tool/read.test.ts +0 -500
  458. package/test/tool/recall.test.ts +0 -151
  459. package/test/tool/registry.test.ts +0 -203
  460. package/test/tool/skill.test.ts +0 -135
  461. package/test/tool/suggest.test.ts +0 -1
  462. package/test/tool/task.test.ts +0 -612
  463. package/test/tool/tool-define.test.ts +0 -99
  464. package/test/tool/truncation.test.ts +0 -260
  465. package/test/tool/webfetch.test.ts +0 -103
  466. package/test/tool/write.test.ts +0 -291
  467. package/test/util/data-url.test.ts +0 -14
  468. package/test/util/effect-zod.test.ts +0 -754
  469. package/test/util/error.test.ts +0 -38
  470. package/test/util/filesystem.test.ts +0 -656
  471. package/test/util/format.test.ts +0 -59
  472. package/test/util/glob.test.ts +0 -164
  473. package/test/util/iife.test.ts +0 -36
  474. package/test/util/lazy.test.ts +0 -50
  475. package/test/util/lock.test.ts +0 -72
  476. package/test/util/log.test.ts +0 -86
  477. package/test/util/module.test.ts +0 -59
  478. package/test/util/process.test.ts +0 -128
  479. package/test/util/timeout.test.ts +0 -21
  480. package/test/util/which.test.ts +0 -100
  481. package/test/util/wildcard.test.ts +0 -90
  482. package/test/workspace/workspace-restore.test.ts +0 -296
  483. package/tsconfig.json +0 -19
@@ -1,309 +0,0 @@
1
- # Instance context migration
2
-
3
- Practical plan for retiring the promise-backed / ALS-backed `Instance` helper in `src/project/instance.ts` and moving instance selection fully into Effect-provided scope.
4
-
5
- ## Goal
6
-
7
- End state:
8
-
9
- - request, CLI, TUI, and tool entrypoints shift into an instance through Effect, not `Instance.provide(...)`
10
- - Effect code reads the current instance from `InstanceRef` or its eventual replacement, not from ALS-backed sync getters
11
- - per-directory boot, caching, and disposal are scoped Effect resources, not a module-level `Map<string, Promise<InstanceContext>>`
12
- - ALS remains only as a temporary bridge for native callback APIs that fire outside the Effect fiber tree
13
-
14
- ## Current split
15
-
16
- Today `src/project/instance.ts` still owns two separate concerns:
17
-
18
- - ambient current-instance context through `LocalContext` / `AsyncLocalStorage`
19
- - per-directory boot and deduplication through `cache: Map<string, Promise<InstanceContext>>`
20
-
21
- At the same time, the Effect side already exists:
22
-
23
- - `src/effect/instance-ref.ts` provides `InstanceRef` and `WorkspaceRef`
24
- - `src/effect/run-service.ts` already attaches those refs when a runtime starts inside an active instance ALS context
25
- - `src/effect/instance-state.ts` already prefers `InstanceRef` and only falls back to ALS when needed
26
-
27
- That means the migration is not "invent instance context in Effect". The migration is "stop relying on the legacy helper as the primary source of truth".
28
-
29
- ## End state shape
30
-
31
- Near-term target shape:
32
-
33
- ```ts
34
- InstanceScope.with({ directory, workspaceID }, effect)
35
- ```
36
-
37
- Responsibilities of `InstanceScope.with(...)`:
38
-
39
- - resolve `directory`, `project`, and `worktree`
40
- - acquire or reuse the scoped per-directory instance environment
41
- - provide `InstanceRef` and `WorkspaceRef`
42
- - run the caller's Effect inside that environment
43
-
44
- Code inside the boundary should then do one of these:
45
-
46
- ```ts
47
- const ctx = yield * InstanceState.context
48
- const dir = yield * InstanceState.directory
49
- ```
50
-
51
- Long-term, once `InstanceState` itself is replaced by keyed layers / `LayerMap`, those reads can move to an `InstanceContext` service without changing the outer migration order.
52
-
53
- ## Migration phases
54
-
55
- ### Phase 1: stop expanding the legacy surface
56
-
57
- Rules for all new code:
58
-
59
- - do not add new `Instance.directory`, `Instance.worktree`, `Instance.project`, or `Instance.current` reads inside Effect code
60
- - do not add new `Instance.provide(...)` boundaries unless there is no Effect-native seam yet
61
- - use `InstanceState.context`, `InstanceState.directory`, or an explicit `ctx` parameter inside Effect code
62
-
63
- Success condition:
64
-
65
- - the file inventory below only shrinks from here
66
-
67
- ### Phase 2: remove direct sync getter reads from Effect services
68
-
69
- Convert Effect services first, before replacing the top-level boundary. These modules already run inside Effect and mostly need `yield* InstanceState.context` or a yielded `ctx` instead of ambient sync access.
70
-
71
- Primary batch, highest payoff:
72
-
73
- - `src/file/index.ts`
74
- - `src/lsp/server.ts`
75
- - `src/worktree/index.ts`
76
- - `src/file/watcher.ts`
77
- - `src/format/formatter.ts`
78
- - `src/session/index.ts`
79
- - `src/project/vcs.ts`
80
-
81
- Mechanical replacement rule:
82
-
83
- - `Instance.directory` -> `ctx.directory` or `yield* InstanceState.directory`
84
- - `Instance.worktree` -> `ctx.worktree`
85
- - `Instance.project` -> `ctx.project`
86
-
87
- Do not thread strings manually through every public method if the service already has access to Effect context.
88
-
89
- ### Phase 3: convert entry boundaries to provide instance refs directly
90
-
91
- After the service bodies stop assuming ALS, move the top-level boundaries to shift into Effect explicitly.
92
-
93
- Main boundaries:
94
-
95
- - HTTP server middleware and experimental `HttpApi` entrypoints
96
- - CLI commands
97
- - TUI worker / attach / thread entrypoints
98
- - tool execution entrypoints
99
-
100
- These boundaries should become Effect-native wrappers that:
101
-
102
- - decode directory / workspace inputs
103
- - resolve the instance context once
104
- - provide `InstanceRef` and `WorkspaceRef`
105
- - run the requested Effect
106
-
107
- At that point `Instance.provide(...)` becomes a legacy adapter instead of the normal code path.
108
-
109
- ### Phase 4: replace promise boot cache with scoped instance runtime
110
-
111
- Once boundaries and services both rely on Effect context, replace the module-level promise cache in `src/project/instance.ts`.
112
-
113
- Target replacement:
114
-
115
- - keyed scoped runtime or keyed layer acquisition for each directory
116
- - reuse via `ScopedCache`, `LayerMap`, or another keyed Effect resource manager
117
- - cleanup performed by scope finalizers instead of `disposeAll()` iterating a Promise map
118
-
119
- This phase should absorb the current responsibilities of:
120
-
121
- - `cache` in `src/project/instance.ts`
122
- - `boot(...)`
123
- - most of `disposeInstance(...)`
124
- - manual `reload(...)` / `disposeAll()` fan-out logic
125
-
126
- ### Phase 5: shrink ALS to callback bridges only
127
-
128
- Keep ALS only where a library invokes callbacks outside the Effect fiber tree and we still need to call code that reads instance context synchronously.
129
-
130
- Known bridge cases today:
131
-
132
- - `src/file/watcher.ts`
133
- - `src/session/llm.ts`
134
- - some LSP and plugin callback paths
135
-
136
- If those libraries become fully wrapped in Effect services, the remaining `Instance.bind(...)` uses can disappear too.
137
-
138
- ### Phase 6: delete the legacy sync API
139
-
140
- Only after earlier phases land:
141
-
142
- - remove broad use of `Instance.current`, `Instance.directory`, `Instance.worktree`, `Instance.project`
143
- - reduce `src/project/instance.ts` to a thin compatibility shim or delete it entirely
144
- - remove the ALS fallback from `InstanceState.context`
145
-
146
- ## Inventory of direct legacy usage
147
-
148
- Direct legacy usage means any source file that still calls one of:
149
-
150
- - `Instance.current`
151
- - `Instance.directory`
152
- - `Instance.worktree`
153
- - `Instance.project`
154
- - `Instance.provide(...)`
155
- - `Instance.bind(...)`
156
- - `Instance.restore(...)`
157
- - `Instance.reload(...)`
158
- - `Instance.dispose()` / `Instance.disposeAll()`
159
-
160
- Current total: `56` files in `packages/saeeol/src`.
161
-
162
- ### Core bridge and plumbing
163
-
164
- These files define or adapt the current bridge. They should change last, after callers have moved.
165
-
166
- - `src/project/instance.ts`
167
- - `src/effect/run-service.ts`
168
- - `src/effect/instance-state.ts`
169
- - `src/project/bootstrap.ts`
170
- - `src/config/config.ts`
171
-
172
- Migration rule:
173
-
174
- - keep these as compatibility glue until the outer boundaries and inner services stop depending on ALS
175
-
176
- ### HTTP and server boundaries
177
-
178
- These are the current request-entry seams that still create or consume instance context through the legacy helper.
179
-
180
- - `src/server/routes/instance/middleware.ts`
181
- - `src/server/routes/instance/index.ts`
182
- - `src/server/routes/instance/project.ts`
183
- - `src/server/routes/control/workspace.ts`
184
- - `src/server/routes/instance/file.ts`
185
- - `src/server/routes/instance/experimental.ts`
186
- - `src/server/routes/global.ts`
187
-
188
- Migration rule:
189
-
190
- - move these to explicit Effect entrypoints that provide `InstanceRef` / `WorkspaceRef`
191
- - do not move these first; first reduce the number of downstream handlers and services that still expect ambient ALS
192
-
193
- ### CLI and TUI boundaries
194
-
195
- These commands still enter an instance through `Instance.provide(...)` or read sync getters directly.
196
-
197
- - `src/cli/bootstrap.ts`
198
- - `src/cli/cmd/agent.ts`
199
- - `src/cli/cmd/debug/agent.ts`
200
- - `src/cli/cmd/debug/ripgrep.ts`
201
- - `src/cli/cmd/github.ts`
202
- - `src/cli/cmd/import.ts`
203
- - `src/cli/cmd/mcp.ts`
204
- - `src/cli/cmd/models.ts`
205
- - `src/cli/cmd/plug.ts`
206
- - `src/cli/cmd/pr.ts`
207
- - `src/cli/cmd/providers.ts`
208
- - `src/cli/cmd/stats.ts`
209
- - `src/cli/cmd/tui/attach.ts`
210
- - `src/cli/cmd/tui/plugin/runtime.ts`
211
- - `src/cli/cmd/tui/thread.ts`
212
- - `src/cli/cmd/tui/worker.ts`
213
-
214
- Migration rule:
215
-
216
- - converge these on one shared `withInstance(...)` Effect entry helper instead of open-coded `Instance.provide(...)`
217
- - after that helper is proven, inline the legacy implementation behind an Effect-native scope provider
218
-
219
- ### Tool boundary code
220
-
221
- These tools mostly use direct getters for path resolution and repo-relative display logic.
222
-
223
- - `src/tool/apply_patch.ts`
224
- - `src/tool/bash.ts`
225
- - `src/tool/edit.ts`
226
- - `src/tool/lsp.ts`
227
- - `src/tool/plan.ts`
228
- - `src/tool/read.ts`
229
- - `src/tool/write.ts`
230
-
231
- Migration rule:
232
-
233
- - expose the current instance as an explicit Effect dependency for tool execution
234
- - keep path logic local; avoid introducing another global singleton for tool state
235
-
236
- ### Effect services still reading ambient instance state
237
-
238
- These modules are already the best near-term migration targets because they are in Effect code but still read sync getters from the legacy helper.
239
-
240
- - `src/agent/agent.ts`
241
- - `src/cli/cmd/tui/config/tui-migrate.ts`
242
- - `src/file/index.ts`
243
- - `src/file/watcher.ts`
244
- - `src/format/formatter.ts`
245
- - `src/lsp/client.ts`
246
- - `src/lsp/index.ts`
247
- - `src/lsp/server.ts`
248
- - `src/mcp/index.ts`
249
- - `src/project/vcs.ts`
250
- - `src/provider/provider.ts`
251
- - `src/pty/index.ts`
252
- - `src/session/session.ts`
253
- - `src/session/instruction.ts`
254
- - `src/session/llm.ts`
255
- - `src/session/system.ts`
256
- - `src/sync/index.ts`
257
- - `src/worktree/index.ts`
258
-
259
- Migration rule:
260
-
261
- - replace direct getter reads with `yield* InstanceState.context` or a yielded `ctx`
262
- - isolate `Instance.bind(...)` callers and convert only the truly callback-driven edges to bridge mode
263
-
264
- ### Highest-churn hotspots
265
-
266
- Current highest direct-usage counts by file:
267
-
268
- - `src/file/index.ts` - `18`
269
- - `src/lsp/server.ts` - `14`
270
- - `src/worktree/index.ts` - `12`
271
- - `src/file/watcher.ts` - `9`
272
- - `src/cli/cmd/mcp.ts` - `8`
273
- - `src/format/formatter.ts` - `8`
274
- - `src/tool/apply_patch.ts` - `8`
275
- - `src/cli/cmd/github.ts` - `7`
276
-
277
- These files should drive the first measurable burn-down.
278
-
279
- ## Recommended implementation order
280
-
281
- 1. Migrate direct getter reads inside Effect services, starting with `file`, `lsp`, `worktree`, `format`, and `session`.
282
- 2. Add one shared Effect-native boundary helper for CLI / tool / HTTP entrypoints so we stop open-coding `Instance.provide(...)`.
283
- 3. Move experimental `HttpApi` entrypoints to that helper so the new server stack proves the pattern.
284
- 4. Convert remaining CLI and tool boundaries.
285
- 5. Replace the promise cache with a keyed scoped runtime or keyed layer map.
286
- 6. Delete ALS fallback paths once only callback bridges still depend on them.
287
-
288
- ## Definition of done
289
-
290
- This migration is done when all of the following are true:
291
-
292
- - new requests and commands enter an instance by providing Effect context, not ALS
293
- - Effect services no longer read `Instance.directory`, `Instance.worktree`, `Instance.project`, or `Instance.current`
294
- - `Instance.provide(...)` is gone from normal request / CLI / tool execution
295
- - per-directory boot and disposal are handled by scoped Effect resources
296
- - `Instance.bind(...)` is either gone or confined to a tiny set of native callback adapters
297
-
298
- ## Tracker and worktree
299
-
300
- Active tracker items:
301
-
302
- - `lh7l73` - overall `HttpApi` migration
303
- - `yobwlk` - remove direct `Instance.*` reads inside Effect services
304
- - `7irl1e` - replace `InstanceState` / legacy instance caching with keyed Effect layers
305
-
306
- Dedicated worktree for this transition:
307
-
308
- - path: `/Users/kit/code/open-source/saeeol-worktrees/instance-effect-shift`
309
- - branch: `kit/instance-effect-shift`
@@ -1,34 +0,0 @@
1
- # Effect loose ends
2
-
3
- Small follow-ups that do not fit neatly into the main facade, route, tool, or schema migration checklists.
4
-
5
- ## Config / TUI
6
-
7
- - [ ] `cli/cmd/tui/config/tui.ts` - finish the internal Effect migration.
8
- Keep the current precedence and migration semantics intact while converting the remaining internal async helpers (`loadState`, `mergeFile`, `loadFile`, `load`) to `Effect.gen(...)` / `Effect.fn(...)`.
9
- - [ ] `cli/cmd/tui/config/tui.ts` callers - once the internal service is stable, migrate plain async callers to use `TuiConfig.Service` directly where that actually simplifies the code.
10
- Likely first callers: `cli/cmd/tui/attach.ts`, `cli/cmd/tui/thread.ts`, `cli/cmd/tui/plugin/runtime.ts`.
11
- - [x] `env/index.ts` - already uses `InstanceState.make(...)`.
12
-
13
- ## ConfigPaths
14
-
15
- - [ ] `config/paths.ts` - split pure helpers from effectful helpers.
16
- Keep `fileInDirectory(...)` as a plain function.
17
- - [ ] `config/paths.ts` - add a `ConfigPaths.Service` for the effectful operations so callers do not inherit `AppFileSystem.Service` directly.
18
- Initial service surface should cover:
19
- - `projectFiles(...)`
20
- - `directories(...)`
21
- - `readFile(...)`
22
- - `parseText(...)`
23
- - [ ] `config/config.ts` - switch internal config loading from `Effect.promise(() => ConfigPaths.*(...))` to `yield* paths.*(...)` once the service exists.
24
- - [ ] `cli/cmd/tui/config/tui.ts` - switch TUI config loading from async `ConfigPaths.*` wrappers to the `ConfigPaths.Service` once that service exists.
25
- - [ ] `cli/cmd/tui/config/tui-migrate.ts` - decide whether to leave this as a plain async module using wrapper functions or effectify it fully after `ConfigPaths.Service` lands.
26
-
27
- ## Instance cleanup
28
-
29
- - [ ] `project/instance.ts` - keep shrinking the legacy ALS / Promise cache after the remaining `Instance.*` callers move over.
30
-
31
- ## Notes
32
-
33
- - Prefer small, semantics-preserving config migrations. Config precedence, legacy key migration, and plugin origin tracking are easy to break accidentally.
34
- - When changing config loading internals, rerun the config and TUI suites first before broad package sweeps.
@@ -1,299 +0,0 @@
1
- # Effect patterns
2
-
3
- Practical reference for new and migrated Effect code in `packages/saeeol`.
4
-
5
- ## Choose scope
6
-
7
- Use `InstanceState` (from `src/effect/instance-state.ts`) for services that need per-directory state, per-instance cleanup, or project-bound background work. InstanceState uses a `ScopedCache` keyed by directory, so each open project gets its own copy of the state that is automatically cleaned up on disposal.
8
-
9
- Use `makeRuntime` (from `src/effect/run-service.ts`) to create a per-service `ManagedRuntime` that lazily initializes and shares layers via a global `memoMap`. Returns `{ runPromise, runFork, runCallback }`.
10
-
11
- - Global services (no per-directory state): Account, Auth, AppFileSystem, Installation, Truncate, Worktree
12
- - Instance-scoped (per-directory state via InstanceState): Agent, Bus, Command, Config, File, FileWatcher, Format, LSP, MCP, Permission, Plugin, ProviderAuth, Pty, Question, SessionStatus, Skill, Snapshot, ToolRegistry, Vcs
13
-
14
- Rule of thumb: if two open directories should not share one copy of the service, it needs `InstanceState`.
15
-
16
- ## Instance context transition
17
-
18
- See `instance-context.md` for the phased plan to remove the legacy ALS / promise-backed `Instance` helper and move request / CLI / tool boundaries onto Effect-provided instance scope.
19
-
20
- ## Service shape
21
-
22
- Every service follows the same pattern: one module, flat top-level exports, traced Effect methods, and a self-reexport at the bottom when the file is the public module.
23
-
24
- ```ts
25
- export interface Interface {
26
- readonly get: (id: FooID) => Effect.Effect<FooInfo, FooError>
27
- }
28
-
29
- export class Service extends Context.Service<Service, Interface>()("@saeeol/Foo") {}
30
-
31
- export const layer = Layer.effect(
32
- Service,
33
- Effect.gen(function* () {
34
- const state = yield* InstanceState.make<State>(
35
- Effect.fn("Foo.state")(() => Effect.succeed({ ... })),
36
- )
37
-
38
- const get = Effect.fn("Foo.get")(function* (id: FooID) {
39
- const s = yield* InstanceState.get(state)
40
- // ...
41
- })
42
-
43
- return Service.of({ get })
44
- }),
45
- )
46
-
47
- export const defaultLayer = layer.pipe(Layer.provide(FooDep.layer))
48
-
49
- export * as Foo from "."
50
- ```
51
-
52
- Rules:
53
-
54
- - Keep the service surface in one module; prefer flat top-level exports over `export namespace Foo { ... }`
55
- - Use `Effect.fn("Foo.method")` for Effect methods
56
- - Use a self-reexport (`export * as Foo from "."` or `"./foo"`) for the public namespace projection
57
- - Avoid service-local `makeRuntime(...)` facades unless a file is still intentionally in the older migration phase
58
- - No `Layer.fresh` for normal per-directory isolation; use `InstanceState`
59
-
60
- ## Schema → Zod interop
61
-
62
- When a service uses Effect Schema internally but needs Zod schemas for the HTTP layer, derive Zod from Schema using the `zod()` helper from `@/util/effect-zod`:
63
-
64
- ```ts
65
- import { zod } from "@/util/effect-zod"
66
-
67
- export const ZodInfo = zod(Info) // derives z.ZodType from Schema.Union
68
- ```
69
-
70
- See `Auth.ZodInfo` for the canonical example.
71
-
72
- ## InstanceState init patterns
73
-
74
- The `InstanceState.make` init callback receives a `Scope`, so you can use `Effect.acquireRelease`, `Effect.addFinalizer`, and `Effect.forkScoped` inside it. Resources acquired this way are automatically cleaned up when the instance is disposed or invalidated by `ScopedCache`. This makes it the right place for:
75
-
76
- - **Subscriptions**: Yield `Bus.Service` at the layer level, then use `Stream` + `forkScoped` inside the init closure. The fiber is automatically interrupted when the instance scope closes:
77
-
78
- ```ts
79
- const bus = yield * Bus.Service
80
-
81
- const cache =
82
- yield *
83
- InstanceState.make<State>(
84
- Effect.fn("Foo.state")(function* (ctx) {
85
- // ... load state ...
86
-
87
- yield* bus.subscribeAll().pipe(
88
- Stream.runForEach((event) =>
89
- Effect.sync(() => {
90
- /* handle */
91
- }),
92
- ),
93
- Effect.forkScoped,
94
- )
95
-
96
- return {
97
- /* state */
98
- }
99
- }),
100
- )
101
- ```
102
-
103
- - **Resource cleanup**: Use `Effect.acquireRelease` or `Effect.addFinalizer` for resources that need teardown (native watchers, process handles, etc.):
104
-
105
- ```ts
106
- yield *
107
- Effect.acquireRelease(
108
- Effect.sync(() => nativeAddon.watch(dir)),
109
- (watcher) => Effect.sync(() => watcher.close()),
110
- )
111
- ```
112
-
113
- - **Background fibers**: Use `Effect.forkScoped` — the fiber is interrupted on disposal.
114
- - **Side effects at init**: Config notification, event wiring, etc. all belong in the init closure. Callers just do `InstanceState.get(cache)` to trigger everything, and `ScopedCache` deduplicates automatically.
115
-
116
- The key insight: don't split init into a separate method with a `started` flag. Put everything in the `InstanceState.make` closure and let `ScopedCache` handle the run-once semantics.
117
-
118
- ## Effect.cached for deduplication
119
-
120
- Use `Effect.cached` when multiple concurrent callers should share a single in-flight computation. It memoizes the result and deduplicates concurrent fibers — second caller joins the first caller's fiber instead of starting a new one.
121
-
122
- ```ts
123
- // Inside the layer — yield* to initialize the memo
124
- let cached = yield * Effect.cached(loadExpensive())
125
-
126
- const get = Effect.fn("Foo.get")(function* () {
127
- return yield* cached // concurrent callers share the same fiber
128
- })
129
-
130
- // To invalidate: swap in a fresh memo
131
- const invalidate = Effect.fn("Foo.invalidate")(function* () {
132
- cached = yield* Effect.cached(loadExpensive())
133
- })
134
- ```
135
-
136
- Prefer `Effect.cached` over these patterns:
137
-
138
- - Storing a `Fiber.Fiber | undefined` with manual check-and-fork (e.g. `file/index.ts` `ensure`)
139
- - Storing a `Promise<void>` task for deduplication (e.g. `skill/index.ts` `ensure`)
140
- - `let cached: X | undefined` with check-and-load (races when two callers see `undefined` before either resolves)
141
-
142
- `Effect.cached` handles the run-once + concurrent-join semantics automatically. For invalidatable caches, reassign with `yield* Effect.cached(...)` — the old memo is discarded.
143
-
144
- ## Scheduled Tasks
145
-
146
- For loops or periodic work, use `Effect.repeat` or `Effect.schedule` with `Effect.forkScoped` in the layer definition.
147
-
148
- ## Preferred Effect services
149
-
150
- In effectified services, prefer yielding existing Effect services over dropping down to ad hoc platform APIs.
151
-
152
- Prefer these first:
153
-
154
- - `FileSystem.FileSystem` instead of raw `fs/promises` for effectful file I/O
155
- - `ChildProcessSpawner.ChildProcessSpawner` with `ChildProcess.make(...)` instead of custom process wrappers
156
- - `HttpClient.HttpClient` instead of raw `fetch`
157
- - `Path.Path` instead of mixing path helpers into service code when you already need a path service
158
- - `Config` for effect-native configuration reads
159
- - `Clock` / `DateTime` for time reads inside effects
160
-
161
- ## Child processes
162
-
163
- For child process work in services, yield `ChildProcessSpawner.ChildProcessSpawner` in the layer and use `ChildProcess.make(...)`.
164
-
165
- Keep shelling-out code inside the service, not in callers.
166
-
167
- ## Shared leaf models
168
-
169
- Shared schema or model files can stay outside the service namespace when lower layers also depend on them.
170
-
171
- That is fine for leaf files like `schema.ts`. Keep the service surface in the owning namespace.
172
-
173
- ## Migration checklist
174
-
175
- Service-shape migrated (single namespace, traced methods, `InstanceState` where needed).
176
-
177
- This checklist is only about the service shape migration. Many of these services still keep `makeRuntime(...)` plus async facade exports; that facade-removal phase is tracked separately in `facades.md`.
178
-
179
- - [x] `Account` — `account/index.ts`
180
- - [x] `Agent` — `agent/agent.ts`
181
- - [x] `AppFileSystem` — `filesystem/index.ts`
182
- - [x] `Auth` — `auth/index.ts` (uses `zod()` helper for Schema→Zod interop)
183
- - [x] `Bus` — `bus/index.ts`
184
- - [x] `Command` — `command/index.ts`
185
- - [x] `Config` — `config/config.ts`
186
- - [x] `Discovery` — `skill/discovery.ts` (dependency-only layer, no standalone runtime)
187
- - [x] `File` — `file/index.ts`
188
- - [x] `FileWatcher` — `file/watcher.ts`
189
- - [x] `Format` — `format/index.ts`
190
- - [x] `Installation` — `installation/index.ts`
191
- - [x] `LSP` — `lsp/index.ts`
192
- - [x] `MCP` — `mcp/index.ts`
193
- - [x] `McpAuth` — `mcp/auth.ts`
194
- - [x] `Permission` — `permission/index.ts`
195
- - [x] `Plugin` — `plugin/index.ts`
196
- - [x] `Project` — `project/project.ts`
197
- - [x] `ProviderAuth` — `provider/auth.ts`
198
- - [x] `Pty` — `pty/index.ts`
199
- - [x] `Question` — `question/index.ts`
200
- - [x] `SessionStatus` — `session/status.ts`
201
- - [x] `Skill` — `skill/index.ts`
202
- - [x] `Snapshot` — `snapshot/index.ts`
203
- - [x] `ToolRegistry` — `tool/registry.ts`
204
- - [x] `Truncate` — `tool/truncate.ts`
205
- - [x] `Vcs` — `project/vcs.ts`
206
- - [x] `Worktree` — `worktree/index.ts`
207
-
208
- - [x] `Session` — `session/index.ts`
209
- - [x] `SessionProcessor` — `session/processor.ts`
210
- - [x] `SessionPrompt` — `session/prompt.ts`
211
- - [x] `SessionCompaction` — `session/compaction.ts`
212
- - [x] `SessionSummary` — `session/summary.ts`
213
- - [x] `SessionRevert` — `session/revert.ts`
214
- - [x] `Instruction` — `session/instruction.ts`
215
- - [x] `SystemPrompt` — `session/system.ts`
216
- - [x] `Provider` — `provider/provider.ts`
217
- - [x] `Storage` — `storage/storage.ts`
218
- - [x] `ShareNext` — `share/share-next.ts`
219
- - [x] `SessionTodo` — `session/todo.ts`
220
-
221
- Still open at the service-shape level:
222
-
223
- - [ ] `SyncEvent` — `sync/index.ts` (deferred pending sync with James)
224
- - [ ] `Workspace` — `control-plane/workspace.ts` (deferred pending sync with James)
225
-
226
- ## Tool migration
227
-
228
- Tool-specific migration guidance and checklist live in `tools.md`.
229
-
230
- ## Effect service adoption in already-migrated code
231
-
232
- Some already-effectified areas still use raw `Filesystem.*` or `Process.spawn` in their implementation or helper modules. These are low-hanging fruit — the layers already exist, they just need the dependency swap.
233
-
234
- ### `Filesystem.*` → `AppFileSystem.Service` (yield in layer)
235
-
236
- - [x] `config/config.ts` — `installDependencies()` now uses `AppFileSystem`
237
- - [x] `provider/provider.ts` — recent model state now reads via `AppFileSystem.Service`
238
-
239
- ### `Process.spawn` → `ChildProcessSpawner` (yield in layer)
240
-
241
- - [x] `format/formatter.ts` — direct `Process.spawn()` checks removed (`air`, `uv`)
242
- - [ ] `lsp/server.ts` — multiple `Process.spawn()` installs/download helpers
243
-
244
- ## Filesystem consolidation
245
-
246
- `util/filesystem.ts` is still used widely across `src/`, and raw `fs` / `fs/promises` imports still exist in multiple tooling and infrastructure files. As services and tools are effectified, they should switch from `Filesystem.*` to yielding `AppFileSystem.Service` where possible — this should happen naturally during each migration, not as a separate sweep.
247
-
248
- Tool-specific filesystem cleanup notes live in `tools.md`.
249
-
250
- ## Primitives & utilities
251
-
252
- - [ ] `util/lock.ts` — reader-writer lock → Effect Semaphore/Permit
253
- - [ ] `util/flock.ts` — file-based distributed lock with heartbeat → Effect.repeat + addFinalizer
254
- - [ ] `util/process.ts` — child process spawn wrapper → return Effect instead of Promise
255
- - [ ] `util/lazy.ts` — replace uses in Effect code with Effect.cached; keep for sync-only code
256
-
257
- ## Destroying the facades
258
-
259
- This phase is no longer broadly open. There are 5 `makeRuntime(...)` call sites under `src/`, and only a small subset are still ordinary facade-removal targets. The live checklist now lives in `facades.md`.
260
-
261
- These facades exist because cyclic imports used to force each service to build its own independent runtime. Now that the layer DAG is acyclic and `AppRuntime` (`src/effect/app-runtime.ts`) composes everything into one `ManagedRuntime`, we're removing them.
262
-
263
- ### Process
264
-
265
- For each service, the migration is roughly:
266
-
267
- 1. **Find callers.** `grep -n "Namespace\.(methodA|methodB|...)"` across `src/` and `test/`. Skip the service file itself.
268
- 2. **Migrate production callers.** For each effectful caller that does `Effect.tryPromise(() => Namespace.method(...))`:
269
- - Add the service to the caller's layer R type (`Layer.Layer<Self, never, ... | Namespace.Service>`)
270
- - Yield it at the top of the layer: `const ns = yield* Namespace.Service`
271
- - Replace `Effect.tryPromise(() => Namespace.method(...))` with `yield* ns.method(...)` (or `ns.method(...).pipe(Effect.orElseSucceed(...))` for the common fallback case)
272
- - Add `Layer.provide(Namespace.defaultLayer)` to the caller's own `defaultLayer` chain
273
- 3. **Fix tests that used the caller's raw `.layer`.** Any test that composes `Caller.layer` (not `defaultLayer`) needs to also provide the newly-required service tag. The fastest fix is usually switching to `Caller.defaultLayer` since it now pulls in the new dependency.
274
- 4. **Migrate test callers of the facade.** Tests calling `Namespace.method(...)` directly get converted to full effectful style using `testEffect(Namespace.defaultLayer)` + `it.live` / `it.effect` + `yield* svc.method(...)`. Don't wrap the test body in `Effect.promise(async () => {...})` — do the whole thing in `Effect.gen` and use `AppFileSystem.Service` / `tmpdirScoped` / `Effect.addFinalizer` for what used to be raw `fs` / `Bun.write` / `try/finally`.
275
- 5. **Delete the facades.** Once `grep` shows zero callers, remove the `export async function` block AND the `makeRuntime(...)` line from the service namespace. Also remove the now-unused `import { makeRuntime }`.
276
-
277
- ### Pitfalls
278
-
279
- - **Layer caching inside tests.** `testEffect(layer)` constructs the Storage (or whatever) service once and memoizes it. If a test then tries `inner.pipe(Effect.provide(customStorage))` to swap in a differently-configured Storage, the outer cached one wins and the inner provision is a no-op. Fix: wrap the overriding layer in `Layer.fresh(...)`, which forces a new instance to be built instead of hitting the memoMap cache. This lets a single `testEffect(...)` serve both simple and per-test-customized cases.
280
- - **`Effect.tryPromise` → `yield*` drops the Promise layer.** The old code was `Effect.tryPromise(() => Storage.read(...))` — a `tryPromise` wrapper because the facade returned a Promise. The new code is `yield* storage.read(...)` directly — the service method already returns an Effect, so no wrapper is needed. Don't reach for `Effect.promise` or `Effect.tryPromise` during migration; if you're using them on a service method call, you're doing it wrong.
281
- - **Raw `.layer` test callers break silently in the type checker.** When you add a new R requirement to a service's `.layer`, any test that composes it raw (not `defaultLayer`) becomes under-specified. `tsgo` will flag this — the error looks like `Type 'Storage.Service' is not assignable to type '... | Service | TestConsole'`. Usually the fix is to switch that composition to `defaultLayer`, or add `Layer.provide(NewDep.defaultLayer)` to the custom composition.
282
- - **Tests that do async setup with `fs`, `Bun.write`, `tmpdir`.** Convert these to `AppFileSystem.Service` calls inside `Effect.gen`, and use `tmpdirScoped()` instead of `tmpdir()` so cleanup happens via the scope finalizer. For file operations on the actual filesystem (not via a service), a small helper like `const writeJson = Effect.fnUntraced(function* (file, value) { const fs = yield* AppFileSystem.Service; yield* fs.makeDirectory(path.dirname(file), { recursive: true }); yield* fs.writeFileString(file, JSON.stringify(value, null, 2)) })` keeps the migration tests clean.
283
-
284
- ### Migration log
285
-
286
- - `SessionStatus` — migrated 2026-04-11. Replaced the last route and retry-policy callers with `AppRuntime.runPromise(SessionStatus.Service.use(...))` and removed the `makeRuntime(...)` facade.
287
- - `ShareNext` — migrated 2026-04-11. Swapped remaining async callers to `AppRuntime.runPromise(ShareNext.Service.use(...))`, removed the `makeRuntime(...)` facade, and kept instance bootstrap on the shared app runtime.
288
- - `SessionTodo` — migrated 2026-04-10. Already matched the target service shape in `session/todo.ts`: single namespace, traced Effect methods, and no `makeRuntime(...)` facade remained; checklist updated to reflect the completed migration.
289
- - `Storage` — migrated 2026-04-10. One production caller (`Session.diff`) and all storage.test.ts tests converted to effectful style. Facades and `makeRuntime` removed.
290
- - `SessionRunState` — migrated 2026-04-11. Single caller in `server/routes/instance/session.ts` converted; facade removed.
291
- - `Account` — migrated 2026-04-11. Callers in `server/routes/instance/experimental.ts` and `cli/cmd/account.ts` converted; facade removed.
292
- - `Instruction` — migrated 2026-04-11. Test-only callers converted; facade removed.
293
- - `FileWatcher` — migrated 2026-04-11. Callers in `project/bootstrap.ts` and test converted; facade removed.
294
- - `Question` — migrated 2026-04-11. Callers in `server/routes/instance/question.ts` and test converted; facade removed.
295
- - `Truncate` — migrated 2026-04-11. Caller in `tool/tool.ts` and test converted; facade removed.
296
-
297
- ## Route handler effectification
298
-
299
- Route-handler migration guidance and checklist live in `routes.md`.