onlycode 1.18.0 → 1.19.0

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 (417) hide show
  1. package/package.json +11 -146
  2. package/src/account/account.ts +0 -463
  3. package/src/account/repo.ts +0 -173
  4. package/src/account/schema.ts +0 -99
  5. package/src/account/url.ts +0 -8
  6. package/src/acp/agent.ts +0 -95
  7. package/src/acp/config-option.ts +0 -203
  8. package/src/acp/content.ts +0 -250
  9. package/src/acp/directory.ts +0 -210
  10. package/src/acp/error.ts +0 -90
  11. package/src/acp/event.ts +0 -342
  12. package/src/acp/permission.ts +0 -124
  13. package/src/acp/profile.ts +0 -42
  14. package/src/acp/service.ts +0 -1048
  15. package/src/acp/session.ts +0 -231
  16. package/src/acp/tool.ts +0 -367
  17. package/src/acp/usage.ts +0 -232
  18. package/src/agent/agent.ts +0 -459
  19. package/src/agent/generate.txt +0 -75
  20. package/src/agent/prompt/compaction.txt +0 -9
  21. package/src/agent/prompt/explore.txt +0 -18
  22. package/src/agent/prompt/summary.txt +0 -11
  23. package/src/agent/prompt/title.txt +0 -44
  24. package/src/agent/subagent-permissions.ts +0 -27
  25. package/src/audio.d.ts +0 -14
  26. package/src/auth/index.ts +0 -99
  27. package/src/background/job.ts +0 -39
  28. package/src/bus/global.ts +0 -22
  29. package/src/cli/bootstrap.ts +0 -11
  30. package/src/cli/cmd/account.ts +0 -264
  31. package/src/cli/cmd/acp.ts +0 -73
  32. package/src/cli/cmd/agent.ts +0 -259
  33. package/src/cli/cmd/attach.ts +0 -97
  34. package/src/cli/cmd/cmd.ts +0 -7
  35. package/src/cli/cmd/db.ts +0 -62
  36. package/src/cli/cmd/debug/agent.handler.ts +0 -193
  37. package/src/cli/cmd/debug/agent.ts +0 -27
  38. package/src/cli/cmd/debug/config.ts +0 -14
  39. package/src/cli/cmd/debug/file.ts +0 -73
  40. package/src/cli/cmd/debug/index.ts +0 -87
  41. package/src/cli/cmd/debug/lsp.ts +0 -50
  42. package/src/cli/cmd/debug/ripgrep.ts +0 -79
  43. package/src/cli/cmd/debug/scrap.ts +0 -15
  44. package/src/cli/cmd/debug/skill.ts +0 -15
  45. package/src/cli/cmd/debug/snapshot.ts +0 -50
  46. package/src/cli/cmd/debug/startup.ts +0 -11
  47. package/src/cli/cmd/debug/v2.ts +0 -44
  48. package/src/cli/cmd/export.ts +0 -292
  49. package/src/cli/cmd/generate.ts +0 -54
  50. package/src/cli/cmd/github.handler.ts +0 -1593
  51. package/src/cli/cmd/github.shared.ts +0 -30
  52. package/src/cli/cmd/github.ts +0 -42
  53. package/src/cli/cmd/import.ts +0 -224
  54. package/src/cli/cmd/mcp.ts +0 -849
  55. package/src/cli/cmd/models.ts +0 -66
  56. package/src/cli/cmd/plug.ts +0 -230
  57. package/src/cli/cmd/pr.ts +0 -115
  58. package/src/cli/cmd/prompt-display.ts +0 -1
  59. package/src/cli/cmd/providers.ts +0 -534
  60. package/src/cli/cmd/run/demo.ts +0 -1274
  61. package/src/cli/cmd/run/entry.body.ts +0 -205
  62. package/src/cli/cmd/run/footer.command.tsx +0 -1064
  63. package/src/cli/cmd/run/footer.menu.tsx +0 -351
  64. package/src/cli/cmd/run/footer.permission.tsx +0 -472
  65. package/src/cli/cmd/run/footer.prompt.tsx +0 -1306
  66. package/src/cli/cmd/run/footer.question.tsx +0 -573
  67. package/src/cli/cmd/run/footer.subagent.tsx +0 -173
  68. package/src/cli/cmd/run/footer.ts +0 -1129
  69. package/src/cli/cmd/run/footer.view.tsx +0 -943
  70. package/src/cli/cmd/run/footer.width.ts +0 -27
  71. package/src/cli/cmd/run/permission.shared.ts +0 -256
  72. package/src/cli/cmd/run/prompt.editor.ts +0 -157
  73. package/src/cli/cmd/run/prompt.shared.ts +0 -153
  74. package/src/cli/cmd/run/question.shared.ts +0 -340
  75. package/src/cli/cmd/run/runtime.boot.ts +0 -202
  76. package/src/cli/cmd/run/runtime.lifecycle.ts +0 -406
  77. package/src/cli/cmd/run/runtime.queue.ts +0 -349
  78. package/src/cli/cmd/run/runtime.shared.ts +0 -17
  79. package/src/cli/cmd/run/runtime.stdin.ts +0 -37
  80. package/src/cli/cmd/run/runtime.ts +0 -814
  81. package/src/cli/cmd/run/scrollback.shared.ts +0 -92
  82. package/src/cli/cmd/run/scrollback.surface.ts +0 -431
  83. package/src/cli/cmd/run/scrollback.writer.tsx +0 -352
  84. package/src/cli/cmd/run/session-data.ts +0 -1113
  85. package/src/cli/cmd/run/session-replay.ts +0 -374
  86. package/src/cli/cmd/run/session.shared.ts +0 -196
  87. package/src/cli/cmd/run/splash.ts +0 -275
  88. package/src/cli/cmd/run/stream.transport.ts +0 -1462
  89. package/src/cli/cmd/run/stream.ts +0 -175
  90. package/src/cli/cmd/run/subagent-data.ts +0 -876
  91. package/src/cli/cmd/run/theme.ts +0 -690
  92. package/src/cli/cmd/run/tool.ts +0 -1489
  93. package/src/cli/cmd/run/trace.ts +0 -94
  94. package/src/cli/cmd/run/turn-summary.ts +0 -47
  95. package/src/cli/cmd/run/types.ts +0 -350
  96. package/src/cli/cmd/run/variant.shared.ts +0 -215
  97. package/src/cli/cmd/run.ts +0 -894
  98. package/src/cli/cmd/serve.ts +0 -24
  99. package/src/cli/cmd/session.ts +0 -147
  100. package/src/cli/cmd/stats.ts +0 -393
  101. package/src/cli/cmd/tui.ts +0 -224
  102. package/src/cli/cmd/uninstall.ts +0 -353
  103. package/src/cli/cmd/upgrade.ts +0 -74
  104. package/src/cli/cmd/web.ts +0 -84
  105. package/src/cli/effect/prompt.ts +0 -37
  106. package/src/cli/effect-cmd.ts +0 -96
  107. package/src/cli/error.ts +0 -130
  108. package/src/cli/heap.ts +0 -45
  109. package/src/cli/logo-pixel.ts +0 -35
  110. package/src/cli/logo.ts +0 -1
  111. package/src/cli/network.ts +0 -64
  112. package/src/cli/tui/layer.ts +0 -7
  113. package/src/cli/tui/validate-session.ts +0 -29
  114. package/src/cli/tui/worker.ts +0 -71
  115. package/src/cli/ui.ts +0 -148
  116. package/src/cli/upgrade.ts +0 -53
  117. package/src/command/index.ts +0 -184
  118. package/src/command/template/initialize.txt +0 -66
  119. package/src/command/template/review.txt +0 -101
  120. package/src/config/agent.ts +0 -59
  121. package/src/config/command.ts +0 -39
  122. package/src/config/config.ts +0 -686
  123. package/src/config/entry-name.ts +0 -19
  124. package/src/config/managed.ts +0 -69
  125. package/src/config/markdown.ts +0 -36
  126. package/src/config/parse.ts +0 -79
  127. package/src/config/paths.ts +0 -45
  128. package/src/config/plugin.ts +0 -79
  129. package/src/config/tui-cwd.ts +0 -5
  130. package/src/config/tui-host-attention.ts +0 -21
  131. package/src/config/tui-migrate.ts +0 -132
  132. package/src/config/tui.ts +0 -274
  133. package/src/config/variable.ts +0 -91
  134. package/src/control-plane/adapters/index.ts +0 -41
  135. package/src/control-plane/adapters/worktree.ts +0 -96
  136. package/src/control-plane/dev/README.md +0 -19
  137. package/src/control-plane/dev/debug-workspace-plugin.ts +0 -73
  138. package/src/control-plane/types.ts +0 -59
  139. package/src/control-plane/util.ts +0 -39
  140. package/src/control-plane/workspace-adapter-runtime.ts +0 -51
  141. package/src/control-plane/workspace-context.ts +0 -26
  142. package/src/control-plane/workspace.ts +0 -989
  143. package/src/effect/app-runtime.ts +0 -132
  144. package/src/effect/bootstrap-runtime.ts +0 -23
  145. package/src/effect/bridge.ts +0 -84
  146. package/src/effect/config-service.ts +0 -67
  147. package/src/effect/instance-ref.ts +0 -11
  148. package/src/effect/instance-registry.ts +0 -12
  149. package/src/effect/instance-state.ts +0 -69
  150. package/src/effect/promise.ts +0 -17
  151. package/src/effect/run-service.ts +0 -47
  152. package/src/effect/runner.ts +0 -217
  153. package/src/effect/runtime-flags.ts +0 -79
  154. package/src/env/index.ts +0 -43
  155. package/src/event-v2-bridge.ts +0 -79
  156. package/src/format/formatter.ts +0 -404
  157. package/src/format/index.ts +0 -205
  158. package/src/git/index.ts +0 -350
  159. package/src/id/id.ts +0 -80
  160. package/src/ide/index.ts +0 -61
  161. package/src/image/image.ts +0 -174
  162. package/src/index.ts +0 -142
  163. package/src/installation/index.ts +0 -350
  164. package/src/lsp/client.ts +0 -650
  165. package/src/lsp/diagnostic.ts +0 -29
  166. package/src/lsp/language.ts +0 -121
  167. package/src/lsp/launch.ts +0 -21
  168. package/src/lsp/lsp.ts +0 -511
  169. package/src/lsp/server.ts +0 -1983
  170. package/src/markdown.d.ts +0 -4
  171. package/src/mcp/auth.ts +0 -174
  172. package/src/mcp/catalog.ts +0 -153
  173. package/src/mcp/index.ts +0 -953
  174. package/src/mcp/oauth-callback.ts +0 -233
  175. package/src/mcp/oauth-provider.ts +0 -206
  176. package/src/node.ts +0 -4
  177. package/src/patch/index.ts +0 -686
  178. package/src/permission/arity.ts +0 -163
  179. package/src/permission/evaluate.ts +0 -1
  180. package/src/permission/index.ts +0 -230
  181. package/src/plugin/azure.ts +0 -26
  182. package/src/plugin/cloudflare.ts +0 -76
  183. package/src/plugin/digitalocean.ts +0 -383
  184. package/src/plugin/github-copilot/copilot.ts +0 -414
  185. package/src/plugin/github-copilot/models.ts +0 -246
  186. package/src/plugin/index.ts +0 -316
  187. package/src/plugin/install.ts +0 -439
  188. package/src/plugin/loader.ts +0 -237
  189. package/src/plugin/meta.ts +0 -188
  190. package/src/plugin/openai/README.md +0 -31
  191. package/src/plugin/openai/codex.ts +0 -641
  192. package/src/plugin/openai/ws-pool.ts +0 -270
  193. package/src/plugin/openai/ws.ts +0 -381
  194. package/src/plugin/pty-environment.ts +0 -24
  195. package/src/plugin/shared.ts +0 -323
  196. package/src/plugin/snowflake-cortex.ts +0 -529
  197. package/src/plugin/tui/internal.ts +0 -10
  198. package/src/plugin/tui/runtime.ts +0 -1130
  199. package/src/plugin/xai.ts +0 -716
  200. package/src/project/bootstrap-service.ts +0 -9
  201. package/src/project/bootstrap.ts +0 -76
  202. package/src/project/instance-context.ts +0 -24
  203. package/src/project/instance-layer.ts +0 -11
  204. package/src/project/instance-runtime.ts +0 -16
  205. package/src/project/instance-store.ts +0 -209
  206. package/src/project/project.ts +0 -519
  207. package/src/project/vcs.ts +0 -431
  208. package/src/provider/auth.ts +0 -233
  209. package/src/provider/error.ts +0 -188
  210. package/src/provider/model-status.ts +0 -8
  211. package/src/provider/provider.ts +0 -1975
  212. package/src/provider/transform.ts +0 -1543
  213. package/src/question/index.ts +0 -229
  214. package/src/question/schema.ts +0 -10
  215. package/src/server/auth.ts +0 -48
  216. package/src/server/event.ts +0 -13
  217. package/src/server/global-lifecycle.ts +0 -28
  218. package/src/server/init-projectors.ts +0 -3
  219. package/src/server/mdns.ts +0 -47
  220. package/src/server/projectors.ts +0 -1
  221. package/src/server/proxy-util.ts +0 -48
  222. package/src/server/routes/instance/httpapi/AGENTS.md +0 -39
  223. package/src/server/routes/instance/httpapi/api.ts +0 -78
  224. package/src/server/routes/instance/httpapi/errors.ts +0 -193
  225. package/src/server/routes/instance/httpapi/groups/config.ts +0 -65
  226. package/src/server/routes/instance/httpapi/groups/control-plane.ts +0 -35
  227. package/src/server/routes/instance/httpapi/groups/control.ts +0 -76
  228. package/src/server/routes/instance/httpapi/groups/event.ts +0 -29
  229. package/src/server/routes/instance/httpapi/groups/experimental.ts +0 -275
  230. package/src/server/routes/instance/httpapi/groups/file.ts +0 -185
  231. package/src/server/routes/instance/httpapi/groups/global.ts +0 -138
  232. package/src/server/routes/instance/httpapi/groups/instance.ts +0 -206
  233. package/src/server/routes/instance/httpapi/groups/mcp.ts +0 -156
  234. package/src/server/routes/instance/httpapi/groups/metadata.ts +0 -18
  235. package/src/server/routes/instance/httpapi/groups/permission.ts +0 -61
  236. package/src/server/routes/instance/httpapi/groups/project-copy.ts +0 -32
  237. package/src/server/routes/instance/httpapi/groups/project.ts +0 -93
  238. package/src/server/routes/instance/httpapi/groups/provider.ts +0 -101
  239. package/src/server/routes/instance/httpapi/groups/pty.ts +0 -172
  240. package/src/server/routes/instance/httpapi/groups/query.ts +0 -12
  241. package/src/server/routes/instance/httpapi/groups/question.ts +0 -74
  242. package/src/server/routes/instance/httpapi/groups/session.ts +0 -462
  243. package/src/server/routes/instance/httpapi/groups/sync.ts +0 -113
  244. package/src/server/routes/instance/httpapi/groups/tui.ts +0 -208
  245. package/src/server/routes/instance/httpapi/groups/workspace.ts +0 -141
  246. package/src/server/routes/instance/httpapi/handlers/config.ts +0 -34
  247. package/src/server/routes/instance/httpapi/handlers/control-plane.ts +0 -37
  248. package/src/server/routes/instance/httpapi/handlers/control.ts +0 -43
  249. package/src/server/routes/instance/httpapi/handlers/event.ts +0 -99
  250. package/src/server/routes/instance/httpapi/handlers/experimental.ts +0 -192
  251. package/src/server/routes/instance/httpapi/handlers/file.ts +0 -139
  252. package/src/server/routes/instance/httpapi/handlers/global.ts +0 -156
  253. package/src/server/routes/instance/httpapi/handlers/instance.ts +0 -110
  254. package/src/server/routes/instance/httpapi/handlers/mcp.ts +0 -111
  255. package/src/server/routes/instance/httpapi/handlers/permission.ts +0 -41
  256. package/src/server/routes/instance/httpapi/handlers/project-copy.ts +0 -83
  257. package/src/server/routes/instance/httpapi/handlers/project.ts +0 -63
  258. package/src/server/routes/instance/httpapi/handlers/provider.ts +0 -113
  259. package/src/server/routes/instance/httpapi/handlers/pty.ts +0 -273
  260. package/src/server/routes/instance/httpapi/handlers/question.ts +0 -54
  261. package/src/server/routes/instance/httpapi/handlers/session-errors.ts +0 -21
  262. package/src/server/routes/instance/httpapi/handlers/session.ts +0 -440
  263. package/src/server/routes/instance/httpapi/handlers/sync.ts +0 -89
  264. package/src/server/routes/instance/httpapi/handlers/tui.ts +0 -131
  265. package/src/server/routes/instance/httpapi/handlers/workspace.ts +0 -102
  266. package/src/server/routes/instance/httpapi/lifecycle.ts +0 -54
  267. package/src/server/routes/instance/httpapi/middleware/authorization.ts +0 -150
  268. package/src/server/routes/instance/httpapi/middleware/compression.ts +0 -64
  269. package/src/server/routes/instance/httpapi/middleware/cors-vary.ts +0 -29
  270. package/src/server/routes/instance/httpapi/middleware/error.ts +0 -43
  271. package/src/server/routes/instance/httpapi/middleware/fence.ts +0 -25
  272. package/src/server/routes/instance/httpapi/middleware/instance-context.ts +0 -43
  273. package/src/server/routes/instance/httpapi/middleware/proxy.ts +0 -108
  274. package/src/server/routes/instance/httpapi/middleware/schema-error.ts +0 -41
  275. package/src/server/routes/instance/httpapi/middleware/workspace-routing.ts +0 -250
  276. package/src/server/routes/instance/httpapi/public.ts +0 -535
  277. package/src/server/routes/instance/httpapi/server.ts +0 -298
  278. package/src/server/routes/instance/httpapi/websocket-tracker.ts +0 -57
  279. package/src/server/server.ts +0 -225
  280. package/src/server/shared/fence.ts +0 -60
  281. package/src/server/shared/pty-ticket.ts +0 -15
  282. package/src/server/shared/public-ui.ts +0 -12
  283. package/src/server/shared/tui-control.ts +0 -28
  284. package/src/server/shared/ui.ts +0 -108
  285. package/src/server/shared/workspace-routing.ts +0 -38
  286. package/src/server/tui-event.ts +0 -53
  287. package/src/session/compaction.ts +0 -620
  288. package/src/session/instruction.ts +0 -241
  289. package/src/session/llm/AGENTS.md +0 -90
  290. package/src/session/llm/ai-sdk.ts +0 -288
  291. package/src/session/llm/native-request.ts +0 -196
  292. package/src/session/llm/native-runtime.ts +0 -195
  293. package/src/session/llm/request.ts +0 -216
  294. package/src/session/llm.ts +0 -415
  295. package/src/session/message-error.ts +0 -14
  296. package/src/session/message-v2.ts +0 -747
  297. package/src/session/message.ts +0 -148
  298. package/src/session/overflow.ts +0 -34
  299. package/src/session/processor.ts +0 -1084
  300. package/src/session/prompt/anthropic.txt +0 -109
  301. package/src/session/prompt/beast.txt +0 -151
  302. package/src/session/prompt/build-switch.txt +0 -9
  303. package/src/session/prompt/codex.txt +0 -83
  304. package/src/session/prompt/copilot-gpt-5.txt +0 -147
  305. package/src/session/prompt/default.txt +0 -99
  306. package/src/session/prompt/gemini.txt +0 -159
  307. package/src/session/prompt/gpt.txt +0 -111
  308. package/src/session/prompt/kimi.txt +0 -99
  309. package/src/session/prompt/plan-mode.txt +0 -74
  310. package/src/session/prompt/plan-reminder-anthropic.txt +0 -71
  311. package/src/session/prompt/plan.txt +0 -30
  312. package/src/session/prompt/trinity.txt +0 -101
  313. package/src/session/prompt.ts +0 -1707
  314. package/src/session/reminders.ts +0 -92
  315. package/src/session/retry.ts +0 -201
  316. package/src/session/revert.ts +0 -160
  317. package/src/session/run-state.ts +0 -156
  318. package/src/session/schema.ts +0 -26
  319. package/src/session/session.ts +0 -1119
  320. package/src/session/status.ts +0 -97
  321. package/src/session/summary.ts +0 -165
  322. package/src/session/system.ts +0 -117
  323. package/src/session/todo.ts +0 -90
  324. package/src/session/tools.ts +0 -207
  325. package/src/share/session.ts +0 -61
  326. package/src/share/share-next.ts +0 -385
  327. package/src/skill/discovery.ts +0 -109
  328. package/src/skill/index.ts +0 -366
  329. package/src/snapshot/index.ts +0 -808
  330. package/src/sql.d.ts +0 -4
  331. package/src/storage/schema.ts +0 -5
  332. package/src/storage/storage.ts +0 -329
  333. package/src/sync/README.md +0 -179
  334. package/src/sync/schema.ts +0 -11
  335. package/src/temporary.ts +0 -31
  336. package/src/tool/apply_patch.ts +0 -315
  337. package/src/tool/apply_patch.txt +0 -33
  338. package/src/tool/apply_patch.zh.txt +0 -33
  339. package/src/tool/description.ts +0 -100
  340. package/src/tool/edit.ts +0 -739
  341. package/src/tool/edit.txt +0 -10
  342. package/src/tool/edit.zh.txt +0 -10
  343. package/src/tool/external-directory.ts +0 -49
  344. package/src/tool/glob.ts +0 -78
  345. package/src/tool/glob.txt +0 -6
  346. package/src/tool/glob.zh.txt +0 -6
  347. package/src/tool/grep.ts +0 -114
  348. package/src/tool/grep.txt +0 -8
  349. package/src/tool/grep.zh.txt +0 -8
  350. package/src/tool/invalid.ts +0 -21
  351. package/src/tool/json-schema.ts +0 -164
  352. package/src/tool/lsp.ts +0 -115
  353. package/src/tool/lsp.txt +0 -24
  354. package/src/tool/lsp.zh.txt +0 -24
  355. package/src/tool/mcp-websearch.ts +0 -96
  356. package/src/tool/plan-enter.txt +0 -14
  357. package/src/tool/plan-enter.zh.txt +0 -14
  358. package/src/tool/plan-exit.txt +0 -13
  359. package/src/tool/plan-exit.zh.txt +0 -13
  360. package/src/tool/plan.ts +0 -81
  361. package/src/tool/question.ts +0 -46
  362. package/src/tool/question.txt +0 -10
  363. package/src/tool/question.zh.txt +0 -10
  364. package/src/tool/read.ts +0 -388
  365. package/src/tool/read.txt +0 -14
  366. package/src/tool/read.zh.txt +0 -14
  367. package/src/tool/registry.ts +0 -440
  368. package/src/tool/schema.ts +0 -14
  369. package/src/tool/shell/id.ts +0 -19
  370. package/src/tool/shell/prompt.ts +0 -307
  371. package/src/tool/shell/shell.txt +0 -21
  372. package/src/tool/shell.ts +0 -657
  373. package/src/tool/skill.ts +0 -73
  374. package/src/tool/skill.txt +0 -5
  375. package/src/tool/skill.zh.txt +0 -5
  376. package/src/tool/task.ts +0 -348
  377. package/src/tool/task.txt +0 -19
  378. package/src/tool/task.zh.txt +0 -19
  379. package/src/tool/todo.ts +0 -59
  380. package/src/tool/todowrite.txt +0 -44
  381. package/src/tool/todowrite.zh.txt +0 -44
  382. package/src/tool/tool.ts +0 -183
  383. package/src/tool/truncate.ts +0 -158
  384. package/src/tool/truncation-dir.ts +0 -4
  385. package/src/tool/webfetch.ts +0 -194
  386. package/src/tool/webfetch.txt +0 -13
  387. package/src/tool/webfetch.zh.txt +0 -13
  388. package/src/tool/websearch.ts +0 -145
  389. package/src/tool/websearch.txt +0 -14
  390. package/src/tool/websearch.zh.txt +0 -14
  391. package/src/tool/write.ts +0 -106
  392. package/src/tool/write.txt +0 -8
  393. package/src/tool/write.zh.txt +0 -8
  394. package/src/util/archive.ts +0 -17
  395. package/src/util/bom.ts +0 -27
  396. package/src/util/data-url.ts +0 -9
  397. package/src/util/defer.ts +0 -10
  398. package/src/util/effect-http-client.ts +0 -11
  399. package/src/util/error.ts +0 -1
  400. package/src/util/filesystem.ts +0 -251
  401. package/src/util/html.ts +0 -8
  402. package/src/util/iife.ts +0 -3
  403. package/src/util/lazy.ts +0 -20
  404. package/src/util/local-context.ts +0 -25
  405. package/src/util/locale.ts +0 -2
  406. package/src/util/media.ts +0 -26
  407. package/src/util/process.ts +0 -177
  408. package/src/util/proxy-env.ts +0 -72
  409. package/src/util/queue.ts +0 -32
  410. package/src/util/record.ts +0 -1
  411. package/src/util/repository.ts +0 -232
  412. package/src/util/rpc.ts +0 -66
  413. package/src/util/signal.ts +0 -12
  414. package/src/util/timeout.ts +0 -13
  415. package/src/util/token.ts +0 -1
  416. package/src/util/wildcard.ts +0 -59
  417. package/src/worktree/index.ts +0 -654
package/src/lsp/client.ts DELETED
@@ -1,650 +0,0 @@
1
- import path from "path"
2
- import { pathToFileURL, fileURLToPath } from "url"
3
- import { createMessageConnection, StreamMessageReader, StreamMessageWriter } from "vscode-jsonrpc/node"
4
- import type { Diagnostic as VSCodeDiagnostic } from "vscode-languageserver-types"
5
- import { Process } from "@/util/process"
6
- import { LANGUAGE_EXTENSIONS } from "./language"
7
- import { Effect, Schema } from "effect"
8
- import type * as LSPServer from "./server"
9
- import { withTimeout } from "../util/timeout"
10
- import { Filesystem } from "@/util/filesystem"
11
- import type { InstanceContext } from "@/project/instance-context"
12
-
13
- const DIAGNOSTICS_DEBOUNCE_MS = 150
14
- const DIAGNOSTICS_DOCUMENT_WAIT_TIMEOUT_MS = 5_000
15
- const DIAGNOSTICS_FULL_WAIT_TIMEOUT_MS = 10_000
16
- const DIAGNOSTICS_REQUEST_TIMEOUT_MS = 3_000
17
-
18
- const INITIALIZE_TIMEOUT_MS = 45_000
19
-
20
- // LSP spec constants
21
- const FILE_CHANGE_CREATED = 1
22
- const FILE_CHANGE_CHANGED = 2
23
- const TEXT_DOCUMENT_SYNC_INCREMENTAL = 2
24
-
25
- export type Info = NonNullable<Awaited<ReturnType<typeof create>>>
26
-
27
- export type Diagnostic = VSCodeDiagnostic
28
-
29
- export class InitializeError extends Schema.TaggedErrorClass<InitializeError>()("LSPInitializeError", {
30
- serverID: Schema.String,
31
- cause: Schema.optional(Schema.Defect()),
32
- }) {}
33
-
34
- type DocumentDiagnosticReport = {
35
- items?: Diagnostic[]
36
- relatedDocuments?: Record<string, DocumentDiagnosticReport>
37
- }
38
-
39
- type WorkspaceDiagnosticReport = {
40
- items?: {
41
- uri?: string
42
- items?: Diagnostic[]
43
- }[]
44
- }
45
-
46
- type DiagnosticRequestResult = {
47
- handled: boolean
48
- matched: boolean
49
- byFile: Map<string, Diagnostic[]>
50
- }
51
-
52
- type CapabilityRegistration = {
53
- id: string
54
- method: string
55
- registerOptions?: {
56
- identifier?: string
57
- workspaceDiagnostics?: boolean
58
- }
59
- }
60
-
61
- type ServerCapabilities = {
62
- textDocumentSync?:
63
- | number
64
- | {
65
- change?: number
66
- }
67
- diagnosticProvider?: unknown
68
- [key: string]: unknown
69
- }
70
-
71
- function getFilePath(uri: string) {
72
- if (!uri.startsWith("file://")) return
73
- return Filesystem.normalizePath(fileURLToPath(uri))
74
- }
75
-
76
- function getSyncKind(capabilities?: ServerCapabilities) {
77
- if (!capabilities) return
78
- const sync = capabilities.textDocumentSync
79
- if (typeof sync === "number") return sync
80
- return sync?.change
81
- }
82
-
83
- function endPosition(text: string) {
84
- const lines = text.split(/\r\n|\r|\n/)
85
- return {
86
- line: lines.length - 1,
87
- character: lines.at(-1)?.length ?? 0,
88
- }
89
- }
90
-
91
- function dedupeDiagnostics(items: Diagnostic[]) {
92
- const seen = new Set<string>()
93
- return items.filter((item) => {
94
- const key = JSON.stringify({
95
- code: item.code,
96
- severity: item.severity,
97
- message: item.message,
98
- source: item.source,
99
- range: item.range,
100
- })
101
- if (seen.has(key)) return false
102
- seen.add(key)
103
- return true
104
- })
105
- }
106
-
107
- function configurationValue(settings: unknown, section?: string) {
108
- if (!section) return settings ?? null
109
- const result = section.split(".").reduce<unknown>((acc, key) => {
110
- if (!acc || typeof acc !== "object" || !(key in acc)) return undefined
111
- return (acc as Record<string, unknown>)[key]
112
- }, settings)
113
- return result ?? null
114
- }
115
-
116
- // TypeScript's built-in LSP pushes diagnostics aggressively on first open.
117
- // We seed the push cache on the very first publish so waitForFreshPush can
118
- // resolve immediately instead of waiting for a second debounced push.
119
- function shouldSeedDiagnosticsOnFirstPush(serverID: string) {
120
- return serverID === "typescript"
121
- }
122
-
123
- export async function create(input: {
124
- serverID: string
125
- server: LSPServer.Handle
126
- root: string
127
- directory: string
128
- instance: InstanceContext
129
- }) {
130
- const instance = input.instance
131
-
132
- const connection = createMessageConnection(
133
- new StreamMessageReader(input.server.process.stdout as any),
134
- new StreamMessageWriter(input.server.process.stdin as any),
135
- )
136
- input.server.process.stderr?.resume()
137
- // --- Connection state ---
138
-
139
- const pushDiagnostics = new Map<string, Diagnostic[]>()
140
- const pullDiagnostics = new Map<string, Diagnostic[]>()
141
- const published = new Map<string, { at: number; version?: number }>()
142
- const diagnosticRegistrations = new Map<string, CapabilityRegistration>()
143
- const registrationListeners = new Set<() => void>()
144
- const diagnosticListeners = new Set<(input: { path: string; serverID: string }) => void>()
145
- const mergedDiagnostics = (filePath: string) =>
146
- dedupeDiagnostics([...(pushDiagnostics.get(filePath) ?? []), ...(pullDiagnostics.get(filePath) ?? [])])
147
- const updatePushDiagnostics = (filePath: string, next: Diagnostic[]) => {
148
- pushDiagnostics.set(filePath, next)
149
- for (const listener of diagnosticListeners) listener({ path: filePath, serverID: input.serverID })
150
- }
151
- const updatePullDiagnostics = (filePath: string, next: Diagnostic[]) => {
152
- pullDiagnostics.set(filePath, next)
153
- }
154
- const emitRegistrationChange = () => {
155
- for (const listener of [...registrationListeners]) listener()
156
- }
157
-
158
- // --- LSP connection handlers ---
159
-
160
- connection.onNotification("textDocument/publishDiagnostics", (params) => {
161
- const filePath = getFilePath(params.uri)
162
- if (!filePath) return
163
- published.set(filePath, {
164
- at: Date.now(),
165
- version: typeof params.version === "number" ? params.version : undefined,
166
- })
167
- if (shouldSeedDiagnosticsOnFirstPush(input.serverID) && !pushDiagnostics.has(filePath)) {
168
- pushDiagnostics.set(filePath, params.diagnostics)
169
- return
170
- }
171
- updatePushDiagnostics(filePath, params.diagnostics)
172
- })
173
- connection.onRequest("window/workDoneProgress/create", (params) => {
174
- return null
175
- })
176
- connection.onRequest("workspace/configuration", async (params) => {
177
- const items = (params as { items?: { section?: string }[] }).items ?? []
178
- return items.map((item) => configurationValue(input.server.initialization, item.section))
179
- })
180
- connection.onRequest("client/registerCapability", async (params) => {
181
- const registrations = (params as { registrations?: CapabilityRegistration[] }).registrations ?? []
182
- let changed = false
183
- for (const registration of registrations) {
184
- if (registration.method !== "textDocument/diagnostic") continue
185
- diagnosticRegistrations.set(registration.id, registration)
186
- changed = true
187
- }
188
- if (changed) emitRegistrationChange()
189
- })
190
- connection.onRequest("client/unregisterCapability", async (params) => {
191
- const registrations = (params as { unregisterations?: { id: string; method: string }[] }).unregisterations ?? []
192
- let changed = false
193
- for (const registration of registrations) {
194
- if (registration.method !== "textDocument/diagnostic") continue
195
- diagnosticRegistrations.delete(registration.id)
196
- changed = true
197
- }
198
- if (changed) emitRegistrationChange()
199
- })
200
- connection.onRequest("workspace/workspaceFolders", async () => [
201
- {
202
- name: "workspace",
203
- uri: pathToFileURL(input.root).href,
204
- },
205
- ])
206
- connection.onRequest("workspace/diagnostic/refresh", async () => null)
207
- connection.listen()
208
-
209
- // --- Initialize handshake ---
210
-
211
- const initialized = await withTimeout(
212
- connection.sendRequest<{ capabilities?: ServerCapabilities }>("initialize", {
213
- rootUri: pathToFileURL(input.root).href,
214
- processId: input.server.process.pid,
215
- workspaceFolders: [
216
- {
217
- name: "workspace",
218
- uri: pathToFileURL(input.root).href,
219
- },
220
- ],
221
- initializationOptions: {
222
- ...input.server.initialization,
223
- },
224
- capabilities: {
225
- window: {
226
- workDoneProgress: true,
227
- },
228
- workspace: {
229
- configuration: true,
230
- didChangeWatchedFiles: {
231
- dynamicRegistration: true,
232
- },
233
- diagnostics: {
234
- refreshSupport: false,
235
- },
236
- },
237
- textDocument: {
238
- synchronization: {
239
- didOpen: true,
240
- didChange: true,
241
- },
242
- diagnostic: {
243
- dynamicRegistration: true,
244
- relatedDocumentSupport: true,
245
- },
246
- publishDiagnostics: {
247
- versionSupport: false,
248
- },
249
- },
250
- },
251
- }),
252
- INITIALIZE_TIMEOUT_MS,
253
- ).catch((err) => {
254
- throw new InitializeError({ serverID: input.serverID, cause: err })
255
- })
256
-
257
- const syncKind = getSyncKind(initialized.capabilities)
258
- const hasStaticPullDiagnostics = Boolean(initialized.capabilities?.diagnosticProvider)
259
-
260
- await connection.sendNotification("initialized", {})
261
-
262
- if (input.server.initialization) {
263
- await connection.sendNotification("workspace/didChangeConfiguration", {
264
- settings: input.server.initialization,
265
- })
266
- }
267
-
268
- const files: Record<string, { version: number; text: string }> = {}
269
-
270
- // --- Diagnostic helpers ---
271
-
272
- const mergeResults = (filePath: string, results: DiagnosticRequestResult[]) => {
273
- const handled = results.some((result) => result.handled)
274
- const matched = results.some((result) => result.matched)
275
- if (!handled) return { handled: false, matched: false }
276
-
277
- const merged = new Map<string, Diagnostic[]>()
278
- for (const result of results) {
279
- for (const [target, items] of result.byFile.entries()) {
280
- const existing = merged.get(target) ?? []
281
- merged.set(target, existing.concat(items))
282
- }
283
- }
284
-
285
- if (matched && !merged.has(filePath)) merged.set(filePath, [])
286
- for (const [target, items] of merged.entries()) {
287
- updatePullDiagnostics(target, dedupeDiagnostics(items))
288
- }
289
-
290
- return { handled, matched }
291
- }
292
-
293
- async function requestDiagnosticReport(filePath: string, identifier?: string): Promise<DiagnosticRequestResult> {
294
- const report = await withTimeout(
295
- connection.sendRequest<DocumentDiagnosticReport | null>("textDocument/diagnostic", {
296
- ...(identifier ? { identifier } : {}),
297
- textDocument: {
298
- uri: pathToFileURL(filePath).href,
299
- },
300
- }),
301
- DIAGNOSTICS_REQUEST_TIMEOUT_MS,
302
- ).catch(() => null)
303
- if (!report) return { handled: false, matched: false, byFile: new Map<string, Diagnostic[]>() }
304
-
305
- const byFile = new Map<string, Diagnostic[]>()
306
- const push = (target: string, items: Diagnostic[]) => {
307
- const existing = byFile.get(target) ?? []
308
- byFile.set(target, existing.concat(items))
309
- }
310
-
311
- let handled = false
312
- let matched = false
313
- if (Array.isArray(report.items)) {
314
- push(filePath, report.items)
315
- handled = true
316
- matched = true
317
- }
318
- for (const [uri, related] of Object.entries(report.relatedDocuments ?? {})) {
319
- const relatedPath = getFilePath(uri)
320
- if (!relatedPath || !Array.isArray(related.items)) continue
321
- push(relatedPath, related.items)
322
- handled = true
323
- matched = matched || relatedPath === filePath
324
- }
325
-
326
- return { handled, matched, byFile }
327
- }
328
-
329
- async function requestWorkspaceDiagnosticReport(
330
- filePath: string,
331
- identifier?: string,
332
- ): Promise<DiagnosticRequestResult> {
333
- const report = await withTimeout(
334
- connection.sendRequest<WorkspaceDiagnosticReport | null>("workspace/diagnostic", {
335
- ...(identifier ? { identifier } : {}),
336
- previousResultIds: [],
337
- }),
338
- DIAGNOSTICS_REQUEST_TIMEOUT_MS,
339
- ).catch(() => null)
340
- if (!report) return { handled: false, matched: false, byFile: new Map<string, Diagnostic[]>() }
341
-
342
- const byFile = new Map<string, Diagnostic[]>()
343
- let matched = false
344
- for (const item of report.items ?? []) {
345
- const relatedPath = item.uri ? getFilePath(item.uri) : undefined
346
- if (!relatedPath || !Array.isArray(item.items)) continue
347
- const existing = byFile.get(relatedPath) ?? []
348
- byFile.set(relatedPath, existing.concat(item.items))
349
- matched = matched || relatedPath === filePath
350
- }
351
-
352
- return { handled: true, matched, byFile }
353
- }
354
-
355
- function documentPullState() {
356
- const documentRegistrations = [...diagnosticRegistrations.values()].filter(
357
- (registration) => registration.registerOptions?.workspaceDiagnostics !== true,
358
- )
359
- return {
360
- documentIdentifiers: [
361
- ...new Set(documentRegistrations.flatMap((registration) => registration.registerOptions?.identifier ?? [])),
362
- ],
363
- supported: hasStaticPullDiagnostics || documentRegistrations.length > 0,
364
- }
365
- }
366
-
367
- function workspacePullState() {
368
- const workspaceRegistrations = [...diagnosticRegistrations.values()].filter(
369
- (registration) => registration.registerOptions?.workspaceDiagnostics === true,
370
- )
371
- return {
372
- workspaceIdentifiers: [
373
- ...new Set(workspaceRegistrations.flatMap((registration) => registration.registerOptions?.identifier ?? [])),
374
- ],
375
- supported: workspaceRegistrations.length > 0,
376
- }
377
- }
378
-
379
- const hasCurrentFileDiagnostics = (filePath: string, results: DiagnosticRequestResult[]) =>
380
- results.some((result) => (result.byFile.get(filePath)?.length ?? 0) > 0)
381
-
382
- async function requestDiagnostics(
383
- filePath: string,
384
- requests: Promise<DiagnosticRequestResult>[],
385
- done: (results: DiagnosticRequestResult[]) => boolean,
386
- ) {
387
- if (!requests.length) return { handled: false, matched: false }
388
-
389
- const results: DiagnosticRequestResult[] = []
390
- return new Promise<{ handled: boolean; matched: boolean }>((resolve) => {
391
- let pending = requests.length
392
- let resolved = false
393
- const finish = (merged: { handled: boolean; matched: boolean }, force = false) => {
394
- if (resolved) return
395
- if (!force && !done(results)) return
396
- resolved = true
397
- resolve(merged)
398
- }
399
-
400
- for (const request of requests) {
401
- request.then((result) => {
402
- results.push(result)
403
- pending -= 1
404
- const merged = mergeResults(filePath, results)
405
- finish(merged)
406
- if (pending === 0) finish(merged, true)
407
- })
408
- }
409
- })
410
- }
411
-
412
- // LATENCY-CRITICAL: dispatch identifier pulls in parallel and unblock once one
413
- // batch already produced diagnostics for the current file. Let slower pulls keep
414
- // merging in the background; do not sequence identifier-by-identifier, and do
415
- // not add a post-match settle/debounce delay. See PR #23771.
416
- async function requestDocumentDiagnostics(filePath: string) {
417
- const state = documentPullState()
418
- if (!state.supported) return { handled: false, matched: false }
419
- return requestDiagnostics(
420
- filePath,
421
- [
422
- requestDiagnosticReport(filePath),
423
- ...state.documentIdentifiers.map((identifier) => requestDiagnosticReport(filePath, identifier)),
424
- ],
425
- (results) => hasCurrentFileDiagnostics(filePath, results),
426
- )
427
- }
428
-
429
- async function requestFullDiagnostics(filePath: string) {
430
- const documentState = documentPullState()
431
- const workspaceState = workspacePullState()
432
- if (!documentState.supported && !workspaceState.supported) return { handled: false, matched: false }
433
- return mergeResults(
434
- filePath,
435
- await Promise.all([
436
- ...(documentState.supported ? [requestDiagnosticReport(filePath)] : []),
437
- ...documentState.documentIdentifiers.map((identifier) => requestDiagnosticReport(filePath, identifier)),
438
- ...(workspaceState.supported ? [requestWorkspaceDiagnosticReport(filePath)] : []),
439
- ...workspaceState.workspaceIdentifiers.map((identifier) =>
440
- requestWorkspaceDiagnosticReport(filePath, identifier),
441
- ),
442
- ]),
443
- )
444
- }
445
-
446
- function waitForRegistrationChange(timeout: number) {
447
- if (timeout <= 0) return Promise.resolve(false)
448
- return new Promise<boolean>((resolve) => {
449
- let finished = false
450
- let timer: ReturnType<typeof setTimeout> | undefined
451
- const finish = (result: boolean) => {
452
- if (finished) return
453
- finished = true
454
- if (timer) clearTimeout(timer)
455
- registrationListeners.delete(listener)
456
- resolve(result)
457
- }
458
- const listener = () => finish(true)
459
- registrationListeners.add(listener)
460
- timer = setTimeout(() => finish(false), timeout)
461
- })
462
- }
463
-
464
- function waitForFreshPush(request: { path: string; version: number; after: number; timeout: number }) {
465
- if (request.timeout <= 0) return Promise.resolve(false)
466
- return new Promise<boolean>((resolve) => {
467
- let finished = false
468
- let debounceTimer: ReturnType<typeof setTimeout> | undefined
469
- let timeoutTimer: ReturnType<typeof setTimeout> | undefined
470
- let unsub: (() => void) | undefined
471
- const finish = (result: boolean) => {
472
- if (finished) return
473
- finished = true
474
- if (debounceTimer) clearTimeout(debounceTimer)
475
- if (timeoutTimer) clearTimeout(timeoutTimer)
476
- unsub?.()
477
- resolve(result)
478
- }
479
- const schedule = () => {
480
- const hit = published.get(request.path)
481
- if (!hit) return
482
- if (typeof hit.version === "number" && hit.version !== request.version) return
483
- if (hit.at < request.after && hit.version !== request.version) return
484
- if (debounceTimer) clearTimeout(debounceTimer)
485
- debounceTimer = setTimeout(() => finish(true), Math.max(0, DIAGNOSTICS_DEBOUNCE_MS - (Date.now() - hit.at)))
486
- }
487
-
488
- timeoutTimer = setTimeout(() => finish(false), request.timeout)
489
- const listener = (event: { path: string; serverID: string }) => {
490
- if (event.path !== request.path || event.serverID !== input.serverID) return
491
- schedule()
492
- }
493
- diagnosticListeners.add(listener)
494
- unsub = () => diagnosticListeners.delete(listener)
495
- schedule()
496
- })
497
- }
498
-
499
- async function waitForDocumentDiagnostics(request: { path: string; version: number; after?: number }) {
500
- const startedAt = request.after ?? Date.now()
501
- const pushWait = waitForFreshPush({
502
- path: request.path,
503
- version: request.version,
504
- after: startedAt,
505
- timeout: DIAGNOSTICS_DOCUMENT_WAIT_TIMEOUT_MS,
506
- })
507
-
508
- while (Date.now() - startedAt < DIAGNOSTICS_DOCUMENT_WAIT_TIMEOUT_MS) {
509
- const result = await requestDocumentDiagnostics(request.path)
510
- if (result.matched) return
511
- const remaining = DIAGNOSTICS_DOCUMENT_WAIT_TIMEOUT_MS - (Date.now() - startedAt)
512
- if (remaining <= 0) return
513
- const next = await Promise.race([
514
- pushWait.then((ready) => (ready ? "push" : ("timeout" as const))),
515
- waitForRegistrationChange(remaining).then((changed) => (changed ? "registration" : ("timeout" as const))),
516
- ])
517
- if (next !== "registration") return
518
- }
519
- }
520
-
521
- async function waitForFullDiagnostics(request: { path: string; version: number; after?: number }) {
522
- const startedAt = request.after ?? Date.now()
523
- const pushWait = waitForFreshPush({
524
- path: request.path,
525
- version: request.version,
526
- after: startedAt,
527
- timeout: DIAGNOSTICS_FULL_WAIT_TIMEOUT_MS,
528
- })
529
-
530
- while (Date.now() - startedAt < DIAGNOSTICS_FULL_WAIT_TIMEOUT_MS) {
531
- const result = await requestFullDiagnostics(request.path)
532
- if (result.handled || result.matched) return
533
- const remaining = DIAGNOSTICS_FULL_WAIT_TIMEOUT_MS - (Date.now() - startedAt)
534
- if (remaining <= 0) return
535
- const next = await Promise.race([
536
- pushWait.then((ready) => (ready ? "push" : ("timeout" as const))),
537
- waitForRegistrationChange(remaining).then((changed) => (changed ? "registration" : ("timeout" as const))),
538
- ])
539
- if (next !== "registration") return
540
- }
541
- }
542
-
543
- // --- Public API ---
544
-
545
- const result = {
546
- root: input.root,
547
- get serverID() {
548
- return input.serverID
549
- },
550
- get connection() {
551
- return connection
552
- },
553
- notify: {
554
- async open(request: { path: string }) {
555
- request.path = Filesystem.normalizePath(
556
- path.isAbsolute(request.path) ? request.path : path.resolve(input.directory, request.path),
557
- )
558
- const text = await Filesystem.readText(request.path)
559
- const extension = path.extname(request.path)
560
- const languageId = LANGUAGE_EXTENSIONS[extension] ?? "plaintext"
561
-
562
- const document = files[request.path]
563
- if (document !== undefined) {
564
- // Do not wipe diagnostics on didChange. Some servers (e.g. clangd) only
565
- // re-emit diagnostics when the content actually changes, so clearing
566
- // here would lose errors for no-op touchFile calls. Let the server's
567
- // next push/pull overwrite naturally.
568
- await connection.sendNotification("workspace/didChangeWatchedFiles", {
569
- changes: [
570
- {
571
- uri: pathToFileURL(request.path).href,
572
- type: FILE_CHANGE_CHANGED,
573
- },
574
- ],
575
- })
576
-
577
- const next = document.version + 1
578
- files[request.path] = { version: next, text }
579
- await connection.sendNotification("textDocument/didChange", {
580
- textDocument: {
581
- uri: pathToFileURL(request.path).href,
582
- version: next,
583
- },
584
- contentChanges:
585
- syncKind === TEXT_DOCUMENT_SYNC_INCREMENTAL
586
- ? [
587
- {
588
- range: {
589
- start: { line: 0, character: 0 },
590
- end: endPosition(document.text),
591
- },
592
- text,
593
- },
594
- ]
595
- : [{ text }],
596
- })
597
- return next
598
- }
599
-
600
- await connection.sendNotification("workspace/didChangeWatchedFiles", {
601
- changes: [
602
- {
603
- uri: pathToFileURL(request.path).href,
604
- type: FILE_CHANGE_CREATED,
605
- },
606
- ],
607
- })
608
-
609
- pushDiagnostics.delete(request.path)
610
- pullDiagnostics.delete(request.path)
611
- await connection.sendNotification("textDocument/didOpen", {
612
- textDocument: {
613
- uri: pathToFileURL(request.path).href,
614
- languageId,
615
- version: 0,
616
- text,
617
- },
618
- })
619
- files[request.path] = { version: 0, text }
620
- return 0
621
- },
622
- },
623
- get diagnostics() {
624
- const result = new Map<string, Diagnostic[]>()
625
- for (const key of new Set([...pushDiagnostics.keys(), ...pullDiagnostics.keys()])) {
626
- result.set(key, mergedDiagnostics(key))
627
- }
628
- return result
629
- },
630
- async waitForDiagnostics(request: { path: string; version: number; mode?: "document" | "full"; after?: number }) {
631
- const normalizedPath = Filesystem.normalizePath(
632
- path.isAbsolute(request.path) ? request.path : path.resolve(input.directory, request.path),
633
- )
634
- if (request.mode === "document") {
635
- await waitForDocumentDiagnostics({ path: normalizedPath, version: request.version, after: request.after })
636
- return
637
- }
638
- await waitForFullDiagnostics({ path: normalizedPath, version: request.version, after: request.after })
639
- },
640
- async shutdown() {
641
- connection.end()
642
- connection.dispose()
643
- await Process.stop(input.server.process)
644
- },
645
- }
646
-
647
- return result
648
- }
649
-
650
- export * as LSPClient from "./client"
@@ -1,29 +0,0 @@
1
- import * as LSPClient from "./client"
2
-
3
- const MAX_PER_FILE = 20
4
-
5
- export function pretty(diagnostic: LSPClient.Diagnostic) {
6
- const severityMap = {
7
- 1: "ERROR",
8
- 2: "WARN",
9
- 3: "INFO",
10
- 4: "HINT",
11
- }
12
-
13
- const severity = severityMap[diagnostic.severity || 1]
14
- const line = diagnostic.range.start.line + 1
15
- const col = diagnostic.range.start.character + 1
16
-
17
- return `${severity} [${line}:${col}] ${diagnostic.message}`
18
- }
19
-
20
- export function report(file: string, issues: LSPClient.Diagnostic[]) {
21
- const errors = issues.filter((item) => item.severity === 1)
22
- if (errors.length === 0) return ""
23
- const limited = errors.slice(0, MAX_PER_FILE)
24
- const more = errors.length - MAX_PER_FILE
25
- const suffix = more > 0 ? `\n... and ${more} more` : ""
26
- return `<diagnostics file="${file}">\n${limited.map(pretty).join("\n")}${suffix}\n</diagnostics>`
27
- }
28
-
29
- export * as Diagnostic from "./diagnostic"