innocode 1.0.0 → 1.0.229

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 (433) hide show
  1. package/LICENSE +21 -0
  2. package/package.json +17 -118
  3. package/AGENTS.md +0 -27
  4. package/Dockerfile +0 -18
  5. package/README.md +0 -15
  6. package/bunfig.toml +0 -5
  7. package/parsers-config.ts +0 -253
  8. package/script/build.ts +0 -198
  9. package/script/publish.ts +0 -186
  10. package/script/schema.ts +0 -47
  11. package/script/seed-e2e.ts +0 -50
  12. package/src/acp/README.md +0 -164
  13. package/src/acp/agent.ts +0 -1676
  14. package/src/acp/session.ts +0 -117
  15. package/src/acp/types.ts +0 -23
  16. package/src/agent/agent.ts +0 -338
  17. package/src/agent/generate.txt +0 -75
  18. package/src/agent/prompt/compaction.txt +0 -14
  19. package/src/agent/prompt/explore.txt +0 -18
  20. package/src/agent/prompt/summary.txt +0 -11
  21. package/src/agent/prompt/title.txt +0 -44
  22. package/src/auth/index.ts +0 -70
  23. package/src/bun/index.ts +0 -137
  24. package/src/bun/registry.ts +0 -48
  25. package/src/bus/bus-event.ts +0 -43
  26. package/src/bus/global.ts +0 -10
  27. package/src/bus/index.ts +0 -105
  28. package/src/cli/bootstrap.ts +0 -17
  29. package/src/cli/cmd/acp.ts +0 -70
  30. package/src/cli/cmd/agent.ts +0 -257
  31. package/src/cli/cmd/auth.ts +0 -400
  32. package/src/cli/cmd/cmd.ts +0 -7
  33. package/src/cli/cmd/debug/agent.ts +0 -167
  34. package/src/cli/cmd/debug/config.ts +0 -16
  35. package/src/cli/cmd/debug/file.ts +0 -97
  36. package/src/cli/cmd/debug/index.ts +0 -48
  37. package/src/cli/cmd/debug/lsp.ts +0 -52
  38. package/src/cli/cmd/debug/ripgrep.ts +0 -87
  39. package/src/cli/cmd/debug/scrap.ts +0 -16
  40. package/src/cli/cmd/debug/skill.ts +0 -16
  41. package/src/cli/cmd/debug/snapshot.ts +0 -52
  42. package/src/cli/cmd/export.ts +0 -88
  43. package/src/cli/cmd/generate.ts +0 -38
  44. package/src/cli/cmd/github.ts +0 -1540
  45. package/src/cli/cmd/import.ts +0 -147
  46. package/src/cli/cmd/mcp.ts +0 -765
  47. package/src/cli/cmd/models.ts +0 -77
  48. package/src/cli/cmd/pr.ts +0 -113
  49. package/src/cli/cmd/run.ts +0 -598
  50. package/src/cli/cmd/serve.ts +0 -20
  51. package/src/cli/cmd/session.ts +0 -135
  52. package/src/cli/cmd/stats.ts +0 -426
  53. package/src/cli/cmd/tui/app.tsx +0 -812
  54. package/src/cli/cmd/tui/attach.ts +0 -60
  55. package/src/cli/cmd/tui/component/border.tsx +0 -21
  56. package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
  57. package/src/cli/cmd/tui/component/dialog-command.tsx +0 -148
  58. package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
  59. package/src/cli/cmd/tui/component/dialog-model.tsx +0 -165
  60. package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -243
  61. package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -108
  62. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
  63. package/src/cli/cmd/tui/component/dialog-skill.tsx +0 -36
  64. package/src/cli/cmd/tui/component/dialog-stash.tsx +0 -87
  65. package/src/cli/cmd/tui/component/dialog-status.tsx +0 -167
  66. package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
  67. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
  68. package/src/cli/cmd/tui/component/logo.tsx +0 -85
  69. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -666
  70. package/src/cli/cmd/tui/component/prompt/frecency.tsx +0 -89
  71. package/src/cli/cmd/tui/component/prompt/history.tsx +0 -108
  72. package/src/cli/cmd/tui/component/prompt/index.tsx +0 -1153
  73. package/src/cli/cmd/tui/component/prompt/stash.tsx +0 -101
  74. package/src/cli/cmd/tui/component/spinner.tsx +0 -24
  75. package/src/cli/cmd/tui/component/textarea-keybindings.ts +0 -73
  76. package/src/cli/cmd/tui/component/tips.tsx +0 -153
  77. package/src/cli/cmd/tui/component/todo-item.tsx +0 -32
  78. package/src/cli/cmd/tui/context/args.tsx +0 -15
  79. package/src/cli/cmd/tui/context/directory.ts +0 -13
  80. package/src/cli/cmd/tui/context/exit.tsx +0 -54
  81. package/src/cli/cmd/tui/context/helper.tsx +0 -25
  82. package/src/cli/cmd/tui/context/keybind.tsx +0 -100
  83. package/src/cli/cmd/tui/context/kv.tsx +0 -52
  84. package/src/cli/cmd/tui/context/local.tsx +0 -409
  85. package/src/cli/cmd/tui/context/prompt.tsx +0 -18
  86. package/src/cli/cmd/tui/context/route.tsx +0 -46
  87. package/src/cli/cmd/tui/context/sdk.tsx +0 -101
  88. package/src/cli/cmd/tui/context/sync.tsx +0 -470
  89. package/src/cli/cmd/tui/context/theme/aura.json +0 -69
  90. package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
  91. package/src/cli/cmd/tui/context/theme/carbonfox.json +0 -248
  92. package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +0 -233
  93. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -233
  94. package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
  95. package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -228
  96. package/src/cli/cmd/tui/context/theme/cursor.json +0 -249
  97. package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
  98. package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
  99. package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
  100. package/src/cli/cmd/tui/context/theme/github.json +0 -233
  101. package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -242
  102. package/src/cli/cmd/tui/context/theme/innocode.json +0 -245
  103. package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
  104. package/src/cli/cmd/tui/context/theme/lucent-orng.json +0 -237
  105. package/src/cli/cmd/tui/context/theme/material.json +0 -235
  106. package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
  107. package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
  108. package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
  109. package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
  110. package/src/cli/cmd/tui/context/theme/nord.json +0 -223
  111. package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
  112. package/src/cli/cmd/tui/context/theme/orng.json +0 -249
  113. package/src/cli/cmd/tui/context/theme/osaka-jade.json +0 -93
  114. package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
  115. package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
  116. package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
  117. package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
  118. package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
  119. package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
  120. package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
  121. package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
  122. package/src/cli/cmd/tui/context/theme.tsx +0 -1154
  123. package/src/cli/cmd/tui/event.ts +0 -48
  124. package/src/cli/cmd/tui/routes/home.tsx +0 -145
  125. package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +0 -64
  126. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -109
  127. package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +0 -26
  128. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -47
  129. package/src/cli/cmd/tui/routes/session/footer.tsx +0 -91
  130. package/src/cli/cmd/tui/routes/session/header.tsx +0 -135
  131. package/src/cli/cmd/tui/routes/session/index.tsx +0 -2139
  132. package/src/cli/cmd/tui/routes/session/permission.tsx +0 -508
  133. package/src/cli/cmd/tui/routes/session/question.tsx +0 -466
  134. package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -313
  135. package/src/cli/cmd/tui/thread.ts +0 -188
  136. package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -59
  137. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -85
  138. package/src/cli/cmd/tui/ui/dialog-export-options.tsx +0 -207
  139. package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -40
  140. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -80
  141. package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -401
  142. package/src/cli/cmd/tui/ui/dialog.tsx +0 -167
  143. package/src/cli/cmd/tui/ui/link.tsx +0 -28
  144. package/src/cli/cmd/tui/ui/spinner.ts +0 -368
  145. package/src/cli/cmd/tui/ui/toast.tsx +0 -100
  146. package/src/cli/cmd/tui/util/clipboard.ts +0 -159
  147. package/src/cli/cmd/tui/util/editor.ts +0 -32
  148. package/src/cli/cmd/tui/util/signal.ts +0 -7
  149. package/src/cli/cmd/tui/util/terminal.ts +0 -114
  150. package/src/cli/cmd/tui/util/transcript.ts +0 -98
  151. package/src/cli/cmd/tui/win32.ts +0 -129
  152. package/src/cli/cmd/tui/worker.ts +0 -152
  153. package/src/cli/cmd/uninstall.ts +0 -363
  154. package/src/cli/cmd/upgrade.ts +0 -73
  155. package/src/cli/cmd/web.ts +0 -81
  156. package/src/cli/error.ts +0 -57
  157. package/src/cli/logo.ts +0 -6
  158. package/src/cli/network.ts +0 -60
  159. package/src/cli/ui.ts +0 -113
  160. package/src/cli/upgrade.ts +0 -25
  161. package/src/command/index.ts +0 -150
  162. package/src/command/template/initialize.txt +0 -10
  163. package/src/command/template/review.txt +0 -101
  164. package/src/config/config.ts +0 -1517
  165. package/src/config/markdown.ts +0 -98
  166. package/src/env/index.ts +0 -28
  167. package/src/file/ignore.ts +0 -83
  168. package/src/file/index.ts +0 -583
  169. package/src/file/ripgrep.ts +0 -375
  170. package/src/file/time.ts +0 -69
  171. package/src/file/watcher.ts +0 -127
  172. package/src/flag/flag.ts +0 -148
  173. package/src/format/formatter.ts +0 -366
  174. package/src/format/index.ts +0 -137
  175. package/src/global/index.ts +0 -80
  176. package/src/id/id.ts +0 -83
  177. package/src/ide/index.ts +0 -76
  178. package/src/index.ts +0 -160
  179. package/src/installation/index.ts +0 -268
  180. package/src/lsp/client.ts +0 -252
  181. package/src/lsp/index.ts +0 -485
  182. package/src/lsp/language.ts +0 -119
  183. package/src/lsp/server.ts +0 -2046
  184. package/src/mcp/auth.ts +0 -132
  185. package/src/mcp/index.ts +0 -937
  186. package/src/mcp/oauth-callback.ts +0 -200
  187. package/src/mcp/oauth-provider.ts +0 -154
  188. package/src/patch/index.ts +0 -680
  189. package/src/permission/arity.ts +0 -163
  190. package/src/permission/index.ts +0 -210
  191. package/src/permission/next.ts +0 -280
  192. package/src/plugin/codex.ts +0 -624
  193. package/src/plugin/copilot.ts +0 -327
  194. package/src/plugin/index.ts +0 -138
  195. package/src/project/bootstrap.ts +0 -35
  196. package/src/project/instance.ts +0 -114
  197. package/src/project/project.ts +0 -371
  198. package/src/project/state.ts +0 -70
  199. package/src/project/vcs.ts +0 -76
  200. package/src/provider/auth.ts +0 -147
  201. package/src/provider/error.ts +0 -189
  202. package/src/provider/models.ts +0 -133
  203. package/src/provider/provider.ts +0 -1370
  204. package/src/provider/sdk/copilot/README.md +0 -5
  205. package/src/provider/sdk/copilot/chat/convert-to-openai-compatible-chat-messages.ts +0 -164
  206. package/src/provider/sdk/copilot/chat/get-response-metadata.ts +0 -15
  207. package/src/provider/sdk/copilot/chat/map-openai-compatible-finish-reason.ts +0 -17
  208. package/src/provider/sdk/copilot/chat/openai-compatible-api-types.ts +0 -64
  209. package/src/provider/sdk/copilot/chat/openai-compatible-chat-language-model.ts +0 -780
  210. package/src/provider/sdk/copilot/chat/openai-compatible-chat-options.ts +0 -28
  211. package/src/provider/sdk/copilot/chat/openai-compatible-metadata-extractor.ts +0 -44
  212. package/src/provider/sdk/copilot/chat/openai-compatible-prepare-tools.ts +0 -87
  213. package/src/provider/sdk/copilot/copilot-provider.ts +0 -100
  214. package/src/provider/sdk/copilot/index.ts +0 -2
  215. package/src/provider/sdk/copilot/openai-compatible-error.ts +0 -27
  216. package/src/provider/sdk/copilot/responses/convert-to-openai-responses-input.ts +0 -303
  217. package/src/provider/sdk/copilot/responses/map-openai-responses-finish-reason.ts +0 -22
  218. package/src/provider/sdk/copilot/responses/openai-config.ts +0 -18
  219. package/src/provider/sdk/copilot/responses/openai-error.ts +0 -22
  220. package/src/provider/sdk/copilot/responses/openai-responses-api-types.ts +0 -207
  221. package/src/provider/sdk/copilot/responses/openai-responses-language-model.ts +0 -1732
  222. package/src/provider/sdk/copilot/responses/openai-responses-prepare-tools.ts +0 -177
  223. package/src/provider/sdk/copilot/responses/openai-responses-settings.ts +0 -1
  224. package/src/provider/sdk/copilot/responses/tool/code-interpreter.ts +0 -88
  225. package/src/provider/sdk/copilot/responses/tool/file-search.ts +0 -128
  226. package/src/provider/sdk/copilot/responses/tool/image-generation.ts +0 -115
  227. package/src/provider/sdk/copilot/responses/tool/local-shell.ts +0 -65
  228. package/src/provider/sdk/copilot/responses/tool/web-search-preview.ts +0 -104
  229. package/src/provider/sdk/copilot/responses/tool/web-search.ts +0 -103
  230. package/src/provider/transform.ts +0 -806
  231. package/src/pty/index.ts +0 -286
  232. package/src/question/index.ts +0 -171
  233. package/src/scheduler/index.ts +0 -61
  234. package/src/server/error.ts +0 -36
  235. package/src/server/event.ts +0 -7
  236. package/src/server/mdns.ts +0 -60
  237. package/src/server/routes/config.ts +0 -92
  238. package/src/server/routes/experimental.ts +0 -208
  239. package/src/server/routes/file.ts +0 -197
  240. package/src/server/routes/global.ts +0 -183
  241. package/src/server/routes/mcp.ts +0 -225
  242. package/src/server/routes/permission.ts +0 -68
  243. package/src/server/routes/project.ts +0 -82
  244. package/src/server/routes/provider.ts +0 -179
  245. package/src/server/routes/pty.ts +0 -176
  246. package/src/server/routes/question.ts +0 -98
  247. package/src/server/routes/session.ts +0 -939
  248. package/src/server/routes/tui.ts +0 -379
  249. package/src/server/server.ts +0 -621
  250. package/src/session/compaction.ts +0 -261
  251. package/src/session/index.ts +0 -543
  252. package/src/session/instruction.ts +0 -197
  253. package/src/session/llm.ts +0 -283
  254. package/src/session/message-v2.ts +0 -841
  255. package/src/session/message.ts +0 -189
  256. package/src/session/processor.ts +0 -410
  257. package/src/session/prompt/anthropic-20250930.txt +0 -166
  258. package/src/session/prompt/anthropic.txt +0 -105
  259. package/src/session/prompt/beast.txt +0 -147
  260. package/src/session/prompt/build-switch.txt +0 -5
  261. package/src/session/prompt/codex_header.txt +0 -79
  262. package/src/session/prompt/copilot-gpt-5.txt +0 -143
  263. package/src/session/prompt/gemini.txt +0 -155
  264. package/src/session/prompt/max-steps.txt +0 -16
  265. package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
  266. package/src/session/prompt/plan.txt +0 -26
  267. package/src/session/prompt/qwen.txt +0 -109
  268. package/src/session/prompt/trinity.txt +0 -97
  269. package/src/session/prompt.ts +0 -1964
  270. package/src/session/retry.ts +0 -101
  271. package/src/session/revert.ts +0 -121
  272. package/src/session/status.ts +0 -76
  273. package/src/session/summary.ts +0 -203
  274. package/src/session/system.ts +0 -54
  275. package/src/session/todo.ts +0 -37
  276. package/src/share/share-next.ts +0 -200
  277. package/src/share/share.ts +0 -92
  278. package/src/shell/shell.ts +0 -67
  279. package/src/skill/discovery.ts +0 -97
  280. package/src/skill/index.ts +0 -1
  281. package/src/skill/skill.ts +0 -188
  282. package/src/snapshot/index.ts +0 -255
  283. package/src/storage/storage.ts +0 -227
  284. package/src/tool/apply_patch.ts +0 -281
  285. package/src/tool/apply_patch.txt +0 -33
  286. package/src/tool/bash.ts +0 -269
  287. package/src/tool/bash.txt +0 -115
  288. package/src/tool/batch.ts +0 -175
  289. package/src/tool/batch.txt +0 -24
  290. package/src/tool/codesearch.ts +0 -132
  291. package/src/tool/codesearch.txt +0 -12
  292. package/src/tool/edit.ts +0 -655
  293. package/src/tool/edit.txt +0 -10
  294. package/src/tool/external-directory.ts +0 -32
  295. package/src/tool/glob.ts +0 -80
  296. package/src/tool/glob.txt +0 -6
  297. package/src/tool/grep.ts +0 -150
  298. package/src/tool/grep.txt +0 -8
  299. package/src/tool/invalid.ts +0 -17
  300. package/src/tool/ls.ts +0 -121
  301. package/src/tool/ls.txt +0 -1
  302. package/src/tool/lsp.ts +0 -96
  303. package/src/tool/lsp.txt +0 -19
  304. package/src/tool/multiedit.ts +0 -46
  305. package/src/tool/multiedit.txt +0 -41
  306. package/src/tool/plan-enter.txt +0 -14
  307. package/src/tool/plan-exit.txt +0 -13
  308. package/src/tool/plan.ts +0 -130
  309. package/src/tool/question.ts +0 -33
  310. package/src/tool/question.txt +0 -10
  311. package/src/tool/read.ts +0 -261
  312. package/src/tool/read.txt +0 -14
  313. package/src/tool/registry.ts +0 -160
  314. package/src/tool/skill.ts +0 -123
  315. package/src/tool/task.ts +0 -165
  316. package/src/tool/task.txt +0 -60
  317. package/src/tool/todo.ts +0 -53
  318. package/src/tool/todoread.txt +0 -14
  319. package/src/tool/todowrite.txt +0 -167
  320. package/src/tool/tool.ts +0 -89
  321. package/src/tool/truncation.ts +0 -106
  322. package/src/tool/webfetch.ts +0 -186
  323. package/src/tool/webfetch.txt +0 -13
  324. package/src/tool/websearch.ts +0 -150
  325. package/src/tool/websearch.txt +0 -14
  326. package/src/tool/write.ts +0 -85
  327. package/src/tool/write.txt +0 -8
  328. package/src/util/abort.ts +0 -35
  329. package/src/util/archive.ts +0 -16
  330. package/src/util/color.ts +0 -19
  331. package/src/util/context.ts +0 -25
  332. package/src/util/defer.ts +0 -12
  333. package/src/util/eventloop.ts +0 -20
  334. package/src/util/filesystem.ts +0 -93
  335. package/src/util/fn.ts +0 -11
  336. package/src/util/format.ts +0 -20
  337. package/src/util/iife.ts +0 -3
  338. package/src/util/keybind.ts +0 -103
  339. package/src/util/lazy.ts +0 -18
  340. package/src/util/locale.ts +0 -81
  341. package/src/util/lock.ts +0 -98
  342. package/src/util/log.ts +0 -180
  343. package/src/util/proxied.ts +0 -3
  344. package/src/util/queue.ts +0 -32
  345. package/src/util/rpc.ts +0 -66
  346. package/src/util/scrap.ts +0 -10
  347. package/src/util/signal.ts +0 -12
  348. package/src/util/timeout.ts +0 -14
  349. package/src/util/token.ts +0 -7
  350. package/src/util/wildcard.ts +0 -56
  351. package/src/worktree/index.ts +0 -612
  352. package/sst-env.d.ts +0 -9
  353. package/test/acp/agent-interface.test.ts +0 -51
  354. package/test/acp/event-subscription.test.ts +0 -436
  355. package/test/agent/agent.test.ts +0 -675
  356. package/test/bun.test.ts +0 -53
  357. package/test/cli/github-action.test.ts +0 -161
  358. package/test/cli/github-remote.test.ts +0 -80
  359. package/test/cli/import.test.ts +0 -38
  360. package/test/cli/tui/transcript.test.ts +0 -322
  361. package/test/config/agent-color.test.ts +0 -71
  362. package/test/config/config.test.ts +0 -1802
  363. package/test/config/fixtures/empty-frontmatter.md +0 -4
  364. package/test/config/fixtures/frontmatter.md +0 -28
  365. package/test/config/fixtures/markdown-header.md +0 -11
  366. package/test/config/fixtures/no-frontmatter.md +0 -1
  367. package/test/config/fixtures/weird-model-id.md +0 -13
  368. package/test/config/markdown.test.ts +0 -228
  369. package/test/file/ignore.test.ts +0 -10
  370. package/test/file/path-traversal.test.ts +0 -198
  371. package/test/file/ripgrep.test.ts +0 -39
  372. package/test/fixture/fixture.ts +0 -45
  373. package/test/fixture/lsp/fake-lsp-server.js +0 -77
  374. package/test/ide/ide.test.ts +0 -82
  375. package/test/keybind.test.ts +0 -421
  376. package/test/lsp/client.test.ts +0 -95
  377. package/test/mcp/headers.test.ts +0 -153
  378. package/test/mcp/oauth-browser.test.ts +0 -249
  379. package/test/memory/abort-leak.test.ts +0 -136
  380. package/test/patch/patch.test.ts +0 -348
  381. package/test/permission/arity.test.ts +0 -33
  382. package/test/permission/next.test.ts +0 -690
  383. package/test/permission-task.test.ts +0 -319
  384. package/test/plugin/auth-override.test.ts +0 -44
  385. package/test/plugin/codex.test.ts +0 -123
  386. package/test/preload.ts +0 -63
  387. package/test/project/project.test.ts +0 -120
  388. package/test/provider/amazon-bedrock.test.ts +0 -445
  389. package/test/provider/copilot/convert-to-copilot-messages.test.ts +0 -523
  390. package/test/provider/copilot/copilot-chat-model.test.ts +0 -592
  391. package/test/provider/gitlab-duo.test.ts +0 -262
  392. package/test/provider/provider.test.ts +0 -2129
  393. package/test/provider/transform.test.ts +0 -1928
  394. package/test/question/question.test.ts +0 -300
  395. package/test/scheduler.test.ts +0 -73
  396. package/test/server/session-list.test.ts +0 -39
  397. package/test/server/session-select.test.ts +0 -78
  398. package/test/session/compaction.test.ts +0 -423
  399. package/test/session/instruction.test.ts +0 -170
  400. package/test/session/llm.test.ts +0 -667
  401. package/test/session/message-v2.test.ts +0 -924
  402. package/test/session/prompt-missing-file.test.ts +0 -53
  403. package/test/session/prompt-special-chars.test.ts +0 -56
  404. package/test/session/prompt-variant.test.ts +0 -68
  405. package/test/session/retry.test.ts +0 -188
  406. package/test/session/revert-compact.test.ts +0 -285
  407. package/test/session/session.test.ts +0 -71
  408. package/test/session/structured-output-integration.test.ts +0 -233
  409. package/test/session/structured-output.test.ts +0 -385
  410. package/test/skill/discovery.test.ts +0 -60
  411. package/test/skill/skill.test.ts +0 -388
  412. package/test/snapshot/snapshot.test.ts +0 -1040
  413. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  414. package/test/tool/apply_patch.test.ts +0 -559
  415. package/test/tool/bash.test.ts +0 -399
  416. package/test/tool/external-directory.test.ts +0 -127
  417. package/test/tool/fixtures/large-image.png +0 -0
  418. package/test/tool/fixtures/models-api.json +0 -38413
  419. package/test/tool/grep.test.ts +0 -110
  420. package/test/tool/question.test.ts +0 -107
  421. package/test/tool/read.test.ts +0 -421
  422. package/test/tool/registry.test.ts +0 -122
  423. package/test/tool/skill.test.ts +0 -112
  424. package/test/tool/truncation.test.ts +0 -159
  425. package/test/util/filesystem.test.ts +0 -39
  426. package/test/util/format.test.ts +0 -59
  427. package/test/util/iife.test.ts +0 -36
  428. package/test/util/lazy.test.ts +0 -50
  429. package/test/util/lock.test.ts +0 -72
  430. package/test/util/timeout.test.ts +0 -21
  431. package/test/util/wildcard.test.ts +0 -75
  432. package/tsconfig.json +0 -16
  433. /package/{script/postinstall.mjs → postinstall.mjs} +0 -0
@@ -1,4 +0,0 @@
1
- ---
2
- ---
3
-
4
- Content
@@ -1,28 +0,0 @@
1
- ---
2
- description: "This is a description wrapped in quotes"
3
- # field: this is a commented out field that should be ignored
4
- occupation: This man has the following occupation: Software Engineer
5
- title: 'Hello World'
6
- name: John "Doe"
7
-
8
- family: He has no 'family'
9
- summary: >
10
- This is a summary
11
- url: https://example.com:8080/path?query=value
12
- time: The time is 12:30:00 PM
13
- nested: First: Second: Third: Fourth
14
- quoted_colon: "Already quoted: no change needed"
15
- single_quoted_colon: 'Single quoted: also fine'
16
- mixed: He said "hello: world" and then left
17
- empty:
18
- dollar: Use $' and $& for special patterns
19
- ---
20
-
21
- Content that should not be parsed:
22
-
23
- fake_field: this is not yaml
24
- another: neither is this
25
- time: 10:30:00 AM
26
- url: https://should-not-be-parsed.com:3000
27
-
28
- The above lines look like YAML but are just content.
@@ -1,11 +0,0 @@
1
- # Response Formatting Requirements
2
-
3
- Always structure your responses using clear markdown formatting:
4
-
5
- - By default don't put information into tables for questions (but do put information into tables when creating or updating files)
6
- - Use headings (##, ###) to organise sections, always
7
- - Use bullet points or numbered lists for multiple items
8
- - Use code blocks with language tags for any code
9
- - Use **bold** for key terms and emphasis
10
- - Use tables when comparing options or listing structured data
11
- - Break long responses into logical sections with headings
@@ -1 +0,0 @@
1
- Content
@@ -1,13 +0,0 @@
1
- ---
2
- description: General coding and planning agent
3
- mode: subagent
4
- model: synthetic/hf:zai-org/GLM-4.7
5
- tools:
6
- write: true
7
- read: true
8
- edit: true
9
- stuff: >
10
- This is some stuff
11
- ---
12
-
13
- Strictly follow da rules
@@ -1,228 +0,0 @@
1
- import { expect, test, describe } from "bun:test"
2
- import { ConfigMarkdown } from "../../src/config/markdown"
3
-
4
- describe("ConfigMarkdown: normal template", () => {
5
- const template = `This is a @valid/path/to/a/file and it should also match at
6
- the beginning of a line:
7
-
8
- @another-valid/path/to/a/file
9
-
10
- but this is not:
11
-
12
- - Adds a "Co-authored-by:" footer which clarifies which AI agent
13
- helped create this commit, using an appropriate \`noreply@...\`
14
- or \`noreply@anthropic.com\` email address.
15
-
16
- We also need to deal with files followed by @commas, ones
17
- with @file-extensions.md, even @multiple.extensions.bak,
18
- hidden directories like @.config/ or files like @.bashrc
19
- and ones at the end of a sentence like @foo.md.
20
-
21
- Also shouldn't forget @/absolute/paths.txt with and @/without/extensions,
22
- as well as @~/home-files and @~/paths/under/home.txt.
23
-
24
- If the reference is \`@quoted/in/backticks\` then it shouldn't match at all.`
25
-
26
- const matches = ConfigMarkdown.files(template)
27
-
28
- test("should extract exactly 12 file references", () => {
29
- expect(matches.length).toBe(12)
30
- })
31
-
32
- test("should extract valid/path/to/a/file", () => {
33
- expect(matches[0][1]).toBe("valid/path/to/a/file")
34
- })
35
-
36
- test("should extract another-valid/path/to/a/file", () => {
37
- expect(matches[1][1]).toBe("another-valid/path/to/a/file")
38
- })
39
-
40
- test("should extract paths ignoring comma after", () => {
41
- expect(matches[2][1]).toBe("commas")
42
- })
43
-
44
- test("should extract a path with a file extension and comma after", () => {
45
- expect(matches[3][1]).toBe("file-extensions.md")
46
- })
47
-
48
- test("should extract a path with multiple dots and comma after", () => {
49
- expect(matches[4][1]).toBe("multiple.extensions.bak")
50
- })
51
-
52
- test("should extract hidden directory", () => {
53
- expect(matches[5][1]).toBe(".config/")
54
- })
55
-
56
- test("should extract hidden file", () => {
57
- expect(matches[6][1]).toBe(".bashrc")
58
- })
59
-
60
- test("should extract a file ignoring period at end of sentence", () => {
61
- expect(matches[7][1]).toBe("foo.md")
62
- })
63
-
64
- test("should extract an absolute path with an extension", () => {
65
- expect(matches[8][1]).toBe("/absolute/paths.txt")
66
- })
67
-
68
- test("should extract an absolute path without an extension", () => {
69
- expect(matches[9][1]).toBe("/without/extensions")
70
- })
71
-
72
- test("should extract an absolute path in home directory", () => {
73
- expect(matches[10][1]).toBe("~/home-files")
74
- })
75
-
76
- test("should extract an absolute path under home directory", () => {
77
- expect(matches[11][1]).toBe("~/paths/under/home.txt")
78
- })
79
-
80
- test("should not match when preceded by backtick", () => {
81
- const backtickTest = "This `@should/not/match` should be ignored"
82
- const backtickMatches = ConfigMarkdown.files(backtickTest)
83
- expect(backtickMatches.length).toBe(0)
84
- })
85
-
86
- test("should not match email addresses", () => {
87
- const emailTest = "Contact user@example.com for help"
88
- const emailMatches = ConfigMarkdown.files(emailTest)
89
- expect(emailMatches.length).toBe(0)
90
- })
91
- })
92
-
93
- describe("ConfigMarkdown: frontmatter parsing", async () => {
94
- const parsed = await ConfigMarkdown.parse(import.meta.dir + "/fixtures/frontmatter.md")
95
-
96
- test("should parse without throwing", () => {
97
- expect(parsed).toBeDefined()
98
- expect(parsed.data).toBeDefined()
99
- expect(parsed.content).toBeDefined()
100
- })
101
-
102
- test("should extract description field", () => {
103
- expect(parsed.data.description).toBe("This is a description wrapped in quotes")
104
- })
105
-
106
- test("should extract occupation field with colon in value", () => {
107
- expect(parsed.data.occupation).toBe("This man has the following occupation: Software Engineer")
108
- })
109
-
110
- test("should extract title field with single quotes", () => {
111
- expect(parsed.data.title).toBe("Hello World")
112
- })
113
-
114
- test("should extract name field with embedded quotes", () => {
115
- expect(parsed.data.name).toBe('John "Doe"')
116
- })
117
-
118
- test("should extract family field with embedded single quotes", () => {
119
- expect(parsed.data.family).toBe("He has no 'family'")
120
- })
121
-
122
- test("should extract multiline summary field", () => {
123
- expect(parsed.data.summary).toBe("This is a summary\n")
124
- })
125
-
126
- test("should not include commented fields in data", () => {
127
- expect(parsed.data.field).toBeUndefined()
128
- })
129
-
130
- test("should extract URL with port", () => {
131
- expect(parsed.data.url).toBe("https://example.com:8080/path?query=value")
132
- })
133
-
134
- test("should extract time with colons", () => {
135
- expect(parsed.data.time).toBe("The time is 12:30:00 PM")
136
- })
137
-
138
- test("should extract value with multiple colons", () => {
139
- expect(parsed.data.nested).toBe("First: Second: Third: Fourth")
140
- })
141
-
142
- test("should preserve already double-quoted values with colons", () => {
143
- expect(parsed.data.quoted_colon).toBe("Already quoted: no change needed")
144
- })
145
-
146
- test("should preserve already single-quoted values with colons", () => {
147
- expect(parsed.data.single_quoted_colon).toBe("Single quoted: also fine")
148
- })
149
-
150
- test("should extract value with quotes and colons mixed", () => {
151
- expect(parsed.data.mixed).toBe('He said "hello: world" and then left')
152
- })
153
-
154
- test("should handle empty values", () => {
155
- expect(parsed.data.empty).toBeNull()
156
- })
157
-
158
- test("should handle dollar sign replacement patterns literally", () => {
159
- expect(parsed.data.dollar).toBe("Use $' and $& for special patterns")
160
- })
161
-
162
- test("should not parse fake yaml from content", () => {
163
- expect(parsed.data.fake_field).toBeUndefined()
164
- expect(parsed.data.another).toBeUndefined()
165
- })
166
-
167
- test("should extract content after frontmatter without modification", () => {
168
- expect(parsed.content).toContain("Content that should not be parsed:")
169
- expect(parsed.content).toContain("fake_field: this is not yaml")
170
- expect(parsed.content).toContain("url: https://should-not-be-parsed.com:3000")
171
- })
172
- })
173
-
174
- describe("ConfigMarkdown: frontmatter parsing w/ empty frontmatter", async () => {
175
- const result = await ConfigMarkdown.parse(import.meta.dir + "/fixtures/empty-frontmatter.md")
176
-
177
- test("should parse without throwing", () => {
178
- expect(result).toBeDefined()
179
- expect(result.data).toEqual({})
180
- expect(result.content.trim()).toBe("Content")
181
- })
182
- })
183
-
184
- describe("ConfigMarkdown: frontmatter parsing w/ no frontmatter", async () => {
185
- const result = await ConfigMarkdown.parse(import.meta.dir + "/fixtures/no-frontmatter.md")
186
-
187
- test("should parse without throwing", () => {
188
- expect(result).toBeDefined()
189
- expect(result.data).toEqual({})
190
- expect(result.content.trim()).toBe("Content")
191
- })
192
- })
193
-
194
- describe("ConfigMarkdown: frontmatter parsing w/ Markdown header", async () => {
195
- const result = await ConfigMarkdown.parse(import.meta.dir + "/fixtures/markdown-header.md")
196
-
197
- test("should parse and match", () => {
198
- expect(result).toBeDefined()
199
- expect(result.data).toEqual({})
200
- expect(result.content.trim()).toBe(`# Response Formatting Requirements
201
-
202
- Always structure your responses using clear markdown formatting:
203
-
204
- - By default don't put information into tables for questions (but do put information into tables when creating or updating files)
205
- - Use headings (##, ###) to organise sections, always
206
- - Use bullet points or numbered lists for multiple items
207
- - Use code blocks with language tags for any code
208
- - Use **bold** for key terms and emphasis
209
- - Use tables when comparing options or listing structured data
210
- - Break long responses into logical sections with headings`)
211
- })
212
- })
213
-
214
- describe("ConfigMarkdown: frontmatter has weird model id", async () => {
215
- const result = await ConfigMarkdown.parse(import.meta.dir + "/fixtures/weird-model-id.md")
216
-
217
- test("should parse and match", () => {
218
- expect(result).toBeDefined()
219
- expect(result.data["description"]).toEqual("General coding and planning agent")
220
- expect(result.data["mode"]).toEqual("subagent")
221
- expect(result.data["model"]).toEqual("synthetic/hf:zai-org/GLM-4.7")
222
- expect(result.data["tools"]["write"]).toBeTrue()
223
- expect(result.data["tools"]["read"]).toBeTrue()
224
- expect(result.data["stuff"]).toBe("This is some stuff\n")
225
-
226
- expect(result.content.trim()).toBe("Strictly follow da rules")
227
- })
228
- })
@@ -1,10 +0,0 @@
1
- import { test, expect } from "bun:test"
2
- import { FileIgnore } from "../../src/file/ignore"
3
-
4
- test("match nested and non-nested", () => {
5
- expect(FileIgnore.match("node_modules/index.js")).toBe(true)
6
- expect(FileIgnore.match("node_modules")).toBe(true)
7
- expect(FileIgnore.match("node_modules/")).toBe(true)
8
- expect(FileIgnore.match("node_modules/bar")).toBe(true)
9
- expect(FileIgnore.match("node_modules/bar/")).toBe(true)
10
- })
@@ -1,198 +0,0 @@
1
- import { test, expect, describe } from "bun:test"
2
- import path from "path"
3
- import fs from "fs/promises"
4
- import { Filesystem } from "../../src/util/filesystem"
5
- import { File } from "../../src/file"
6
- import { Instance } from "../../src/project/instance"
7
- import { tmpdir } from "../fixture/fixture"
8
-
9
- describe("Filesystem.contains", () => {
10
- test("allows paths within project", () => {
11
- expect(Filesystem.contains("/project", "/project/src")).toBe(true)
12
- expect(Filesystem.contains("/project", "/project/src/file.ts")).toBe(true)
13
- expect(Filesystem.contains("/project", "/project")).toBe(true)
14
- })
15
-
16
- test("blocks ../ traversal", () => {
17
- expect(Filesystem.contains("/project", "/project/../etc")).toBe(false)
18
- expect(Filesystem.contains("/project", "/project/src/../../etc")).toBe(false)
19
- expect(Filesystem.contains("/project", "/etc/passwd")).toBe(false)
20
- })
21
-
22
- test("blocks absolute paths outside project", () => {
23
- expect(Filesystem.contains("/project", "/etc/passwd")).toBe(false)
24
- expect(Filesystem.contains("/project", "/tmp/file")).toBe(false)
25
- expect(Filesystem.contains("/home/user/project", "/home/user/other")).toBe(false)
26
- })
27
-
28
- test("handles prefix collision edge cases", () => {
29
- expect(Filesystem.contains("/project", "/project-other/file")).toBe(false)
30
- expect(Filesystem.contains("/project", "/projectfile")).toBe(false)
31
- })
32
- })
33
-
34
- /*
35
- * Integration tests for File.read() and File.list() path traversal protection.
36
- *
37
- * These tests verify the HTTP API code path is protected. The HTTP endpoints
38
- * in server.ts (GET /file/content, GET /file) call File.read()/File.list()
39
- * directly - they do NOT go through ReadTool or the agent permission layer.
40
- *
41
- * This is a SEPARATE code path from ReadTool, which has its own checks.
42
- */
43
- describe("File.read path traversal protection", () => {
44
- test("rejects ../ traversal attempting to read /etc/passwd", async () => {
45
- await using tmp = await tmpdir({
46
- init: async (dir) => {
47
- await Bun.write(path.join(dir, "allowed.txt"), "allowed content")
48
- },
49
- })
50
-
51
- await Instance.provide({
52
- directory: tmp.path,
53
- fn: async () => {
54
- await expect(File.read("../../../etc/passwd")).rejects.toThrow("Access denied: path escapes project directory")
55
- },
56
- })
57
- })
58
-
59
- test("rejects deeply nested traversal", async () => {
60
- await using tmp = await tmpdir()
61
-
62
- await Instance.provide({
63
- directory: tmp.path,
64
- fn: async () => {
65
- await expect(File.read("src/nested/../../../../../../../etc/passwd")).rejects.toThrow(
66
- "Access denied: path escapes project directory",
67
- )
68
- },
69
- })
70
- })
71
-
72
- test("allows valid paths within project", async () => {
73
- await using tmp = await tmpdir({
74
- init: async (dir) => {
75
- await Bun.write(path.join(dir, "valid.txt"), "valid content")
76
- },
77
- })
78
-
79
- await Instance.provide({
80
- directory: tmp.path,
81
- fn: async () => {
82
- const result = await File.read("valid.txt")
83
- expect(result.content).toBe("valid content")
84
- },
85
- })
86
- })
87
- })
88
-
89
- describe("File.list path traversal protection", () => {
90
- test("rejects ../ traversal attempting to list /etc", async () => {
91
- await using tmp = await tmpdir()
92
-
93
- await Instance.provide({
94
- directory: tmp.path,
95
- fn: async () => {
96
- await expect(File.list("../../../etc")).rejects.toThrow("Access denied: path escapes project directory")
97
- },
98
- })
99
- })
100
-
101
- test("allows valid subdirectory listing", async () => {
102
- await using tmp = await tmpdir({
103
- init: async (dir) => {
104
- await Bun.write(path.join(dir, "subdir", "file.txt"), "content")
105
- },
106
- })
107
-
108
- await Instance.provide({
109
- directory: tmp.path,
110
- fn: async () => {
111
- const result = await File.list("subdir")
112
- expect(Array.isArray(result)).toBe(true)
113
- },
114
- })
115
- })
116
- })
117
-
118
- describe("Instance.containsPath", () => {
119
- test("returns true for path inside directory", async () => {
120
- await using tmp = await tmpdir({ git: true })
121
-
122
- await Instance.provide({
123
- directory: tmp.path,
124
- fn: () => {
125
- expect(Instance.containsPath(path.join(tmp.path, "foo.txt"))).toBe(true)
126
- expect(Instance.containsPath(path.join(tmp.path, "src", "file.ts"))).toBe(true)
127
- },
128
- })
129
- })
130
-
131
- test("returns true for path inside worktree but outside directory (monorepo subdirectory scenario)", async () => {
132
- await using tmp = await tmpdir({ git: true })
133
- const subdir = path.join(tmp.path, "packages", "lib")
134
- await fs.mkdir(subdir, { recursive: true })
135
-
136
- await Instance.provide({
137
- directory: subdir,
138
- fn: () => {
139
- // .opencode at worktree root, but we're running from packages/lib
140
- expect(Instance.containsPath(path.join(tmp.path, ".opencode", "state"))).toBe(true)
141
- // sibling package should also be accessible
142
- expect(Instance.containsPath(path.join(tmp.path, "packages", "other", "file.ts"))).toBe(true)
143
- // worktree root itself
144
- expect(Instance.containsPath(tmp.path)).toBe(true)
145
- },
146
- })
147
- })
148
-
149
- test("returns false for path outside both directory and worktree", async () => {
150
- await using tmp = await tmpdir({ git: true })
151
-
152
- await Instance.provide({
153
- directory: tmp.path,
154
- fn: () => {
155
- expect(Instance.containsPath("/etc/passwd")).toBe(false)
156
- expect(Instance.containsPath("/tmp/other-project")).toBe(false)
157
- },
158
- })
159
- })
160
-
161
- test("returns false for path with .. escaping worktree", async () => {
162
- await using tmp = await tmpdir({ git: true })
163
-
164
- await Instance.provide({
165
- directory: tmp.path,
166
- fn: () => {
167
- expect(Instance.containsPath(path.join(tmp.path, "..", "escape.txt"))).toBe(false)
168
- },
169
- })
170
- })
171
-
172
- test("handles directory === worktree (running from repo root)", async () => {
173
- await using tmp = await tmpdir({ git: true })
174
-
175
- await Instance.provide({
176
- directory: tmp.path,
177
- fn: () => {
178
- expect(Instance.directory).toBe(Instance.worktree)
179
- expect(Instance.containsPath(path.join(tmp.path, "file.txt"))).toBe(true)
180
- expect(Instance.containsPath("/etc/passwd")).toBe(false)
181
- },
182
- })
183
- })
184
-
185
- test("non-git project does not allow arbitrary paths via worktree='/'", async () => {
186
- await using tmp = await tmpdir() // no git: true
187
-
188
- await Instance.provide({
189
- directory: tmp.path,
190
- fn: () => {
191
- // worktree is "/" for non-git projects, but containsPath should NOT allow all paths
192
- expect(Instance.containsPath(path.join(tmp.path, "file.txt"))).toBe(true)
193
- expect(Instance.containsPath("/etc/passwd")).toBe(false)
194
- expect(Instance.containsPath("/tmp/other")).toBe(false)
195
- },
196
- })
197
- })
198
- })
@@ -1,39 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import fs from "fs/promises"
3
- import path from "path"
4
- import { tmpdir } from "../fixture/fixture"
5
- import { Ripgrep } from "../../src/file/ripgrep"
6
-
7
- describe("file.ripgrep", () => {
8
- test("defaults to include hidden", async () => {
9
- await using tmp = await tmpdir({
10
- init: async (dir) => {
11
- await Bun.write(path.join(dir, "visible.txt"), "hello")
12
- await fs.mkdir(path.join(dir, ".opencode"), { recursive: true })
13
- await Bun.write(path.join(dir, ".opencode", "thing.json"), "{}")
14
- },
15
- })
16
-
17
- const files = await Array.fromAsync(Ripgrep.files({ cwd: tmp.path }))
18
- const hasVisible = files.includes("visible.txt")
19
- const hasHidden = files.includes(path.join(".opencode", "thing.json"))
20
- expect(hasVisible).toBe(true)
21
- expect(hasHidden).toBe(true)
22
- })
23
-
24
- test("hidden false excludes hidden", async () => {
25
- await using tmp = await tmpdir({
26
- init: async (dir) => {
27
- await Bun.write(path.join(dir, "visible.txt"), "hello")
28
- await fs.mkdir(path.join(dir, ".opencode"), { recursive: true })
29
- await Bun.write(path.join(dir, ".opencode", "thing.json"), "{}")
30
- },
31
- })
32
-
33
- const files = await Array.fromAsync(Ripgrep.files({ cwd: tmp.path, hidden: false }))
34
- const hasVisible = files.includes("visible.txt")
35
- const hasHidden = files.includes(path.join(".opencode", "thing.json"))
36
- expect(hasVisible).toBe(true)
37
- expect(hasHidden).toBe(false)
38
- })
39
- })
@@ -1,45 +0,0 @@
1
- import { $ } from "bun"
2
- import * as fs from "fs/promises"
3
- import os from "os"
4
- import path from "path"
5
- import type { Config } from "../../src/config/config"
6
-
7
- // Strip null bytes from paths (defensive fix for CI environment issues)
8
- function sanitizePath(p: string): string {
9
- return p.replace(/\0/g, "")
10
- }
11
-
12
- type TmpDirOptions<T> = {
13
- git?: boolean
14
- config?: Partial<Config.Info>
15
- init?: (dir: string) => Promise<T>
16
- dispose?: (dir: string) => Promise<T>
17
- }
18
- export async function tmpdir<T>(options?: TmpDirOptions<T>) {
19
- const dirpath = sanitizePath(path.join(os.tmpdir(), "opencode-test-" + Math.random().toString(36).slice(2)))
20
- await fs.mkdir(dirpath, { recursive: true })
21
- if (options?.git) {
22
- await $`git init`.cwd(dirpath).quiet()
23
- await $`git commit --allow-empty -m "root commit ${dirpath}"`.cwd(dirpath).quiet()
24
- }
25
- if (options?.config) {
26
- await Bun.write(
27
- path.join(dirpath, "opencode.json"),
28
- JSON.stringify({
29
- $schema: "https://opencode.ai/config.json",
30
- ...options.config,
31
- }),
32
- )
33
- }
34
- const extra = await options?.init?.(dirpath)
35
- const realpath = sanitizePath(await fs.realpath(dirpath))
36
- const result = {
37
- [Symbol.asyncDispose]: async () => {
38
- await options?.dispose?.(dirpath)
39
- // await fs.rm(dirpath, { recursive: true, force: true })
40
- },
41
- path: realpath,
42
- extra: extra as T,
43
- }
44
- return result
45
- }
@@ -1,77 +0,0 @@
1
- // Simple JSON-RPC 2.0 LSP-like fake server over stdio
2
- // Implements a minimal LSP handshake and triggers a request upon notification
3
-
4
- const net = require("net")
5
-
6
- let nextId = 1
7
-
8
- function encode(message) {
9
- const json = JSON.stringify(message)
10
- const header = `Content-Length: ${Buffer.byteLength(json, "utf8")}\r\n\r\n`
11
- return Buffer.concat([Buffer.from(header, "utf8"), Buffer.from(json, "utf8")])
12
- }
13
-
14
- function decodeFrames(buffer) {
15
- const results = []
16
- let idx
17
- while ((idx = buffer.indexOf("\r\n\r\n")) !== -1) {
18
- const header = buffer.slice(0, idx).toString("utf8")
19
- const m = /Content-Length:\s*(\d+)/i.exec(header)
20
- const len = m ? parseInt(m[1], 10) : 0
21
- const bodyStart = idx + 4
22
- const bodyEnd = bodyStart + len
23
- if (buffer.length < bodyEnd) break
24
- const body = buffer.slice(bodyStart, bodyEnd).toString("utf8")
25
- results.push(body)
26
- buffer = buffer.slice(bodyEnd)
27
- }
28
- return { messages: results, rest: buffer }
29
- }
30
-
31
- let readBuffer = Buffer.alloc(0)
32
-
33
- process.stdin.on("data", (chunk) => {
34
- readBuffer = Buffer.concat([readBuffer, chunk])
35
- const { messages, rest } = decodeFrames(readBuffer)
36
- readBuffer = rest
37
- for (const m of messages) handle(m)
38
- })
39
-
40
- function send(msg) {
41
- process.stdout.write(encode(msg))
42
- }
43
-
44
- function sendRequest(method, params) {
45
- const id = nextId++
46
- send({ jsonrpc: "2.0", id, method, params })
47
- return id
48
- }
49
-
50
- function handle(raw) {
51
- let data
52
- try {
53
- data = JSON.parse(raw)
54
- } catch {
55
- return
56
- }
57
- if (data.method === "initialize") {
58
- send({ jsonrpc: "2.0", id: data.id, result: { capabilities: {} } })
59
- return
60
- }
61
- if (data.method === "initialized") {
62
- return
63
- }
64
- if (data.method === "workspace/didChangeConfiguration") {
65
- return
66
- }
67
- if (data.method === "test/trigger") {
68
- const method = data.params && data.params.method
69
- if (method) sendRequest(method, {})
70
- return
71
- }
72
- if (typeof data.id !== "undefined") {
73
- // Respond OK to any request from client to keep transport flowing
74
- send({ jsonrpc: "2.0", id: data.id, result: null })
75
- return
76
- }
77
- }