cerebras-cli 1.0.1 → 1.0.3

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 (313) hide show
  1. package/cerebras-cli-1.0.0.tgz +0 -0
  2. package/package.json +7 -88
  3. package/AGENTS.md +0 -27
  4. package/Dockerfile +0 -10
  5. package/bunfig.toml +0 -4
  6. package/parsers-config.ts +0 -239
  7. package/script/build.ts +0 -151
  8. package/script/postinstall.mjs +0 -122
  9. package/script/publish.ts +0 -256
  10. package/script/schema.ts +0 -47
  11. package/src/acp/README.md +0 -164
  12. package/src/acp/agent.ts +0 -812
  13. package/src/acp/session.ts +0 -70
  14. package/src/acp/types.ts +0 -22
  15. package/src/agent/agent.ts +0 -310
  16. package/src/agent/generate.txt +0 -75
  17. package/src/auth/index.ts +0 -70
  18. package/src/bun/index.ts +0 -152
  19. package/src/bus/global.ts +0 -10
  20. package/src/bus/index.ts +0 -142
  21. package/src/cli/bootstrap.ts +0 -17
  22. package/src/cli/cmd/acp.ts +0 -88
  23. package/src/cli/cmd/agent.ts +0 -165
  24. package/src/cli/cmd/auth.ts +0 -369
  25. package/src/cli/cmd/cmd.ts +0 -7
  26. package/src/cli/cmd/debug/config.ts +0 -15
  27. package/src/cli/cmd/debug/file.ts +0 -91
  28. package/src/cli/cmd/debug/index.ts +0 -41
  29. package/src/cli/cmd/debug/lsp.ts +0 -47
  30. package/src/cli/cmd/debug/ripgrep.ts +0 -83
  31. package/src/cli/cmd/debug/scrap.ts +0 -15
  32. package/src/cli/cmd/debug/snapshot.ts +0 -48
  33. package/src/cli/cmd/export.ts +0 -88
  34. package/src/cli/cmd/generate.ts +0 -38
  35. package/src/cli/cmd/github.ts +0 -1200
  36. package/src/cli/cmd/import.ts +0 -98
  37. package/src/cli/cmd/mcp.ts +0 -400
  38. package/src/cli/cmd/models.ts +0 -77
  39. package/src/cli/cmd/pr.ts +0 -112
  40. package/src/cli/cmd/run.ts +0 -342
  41. package/src/cli/cmd/serve.ts +0 -31
  42. package/src/cli/cmd/session.ts +0 -106
  43. package/src/cli/cmd/stats.ts +0 -298
  44. package/src/cli/cmd/tui/app.tsx +0 -732
  45. package/src/cli/cmd/tui/attach.ts +0 -25
  46. package/src/cli/cmd/tui/component/border.tsx +0 -21
  47. package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
  48. package/src/cli/cmd/tui/component/dialog-command.tsx +0 -124
  49. package/src/cli/cmd/tui/component/dialog-feedback.tsx +0 -160
  50. package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
  51. package/src/cli/cmd/tui/component/dialog-model.tsx +0 -223
  52. package/src/cli/cmd/tui/component/dialog-notification.tsx +0 -78
  53. package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -222
  54. package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -97
  55. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
  56. package/src/cli/cmd/tui/component/dialog-status.tsx +0 -114
  57. package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
  58. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
  59. package/src/cli/cmd/tui/component/logo.tsx +0 -37
  60. package/src/cli/cmd/tui/component/notification-banner.tsx +0 -58
  61. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -530
  62. package/src/cli/cmd/tui/component/prompt/history.tsx +0 -107
  63. package/src/cli/cmd/tui/component/prompt/index.tsx +0 -931
  64. package/src/cli/cmd/tui/context/args.tsx +0 -14
  65. package/src/cli/cmd/tui/context/directory.ts +0 -12
  66. package/src/cli/cmd/tui/context/exit.tsx +0 -23
  67. package/src/cli/cmd/tui/context/helper.tsx +0 -25
  68. package/src/cli/cmd/tui/context/keybind.tsx +0 -111
  69. package/src/cli/cmd/tui/context/kv.tsx +0 -49
  70. package/src/cli/cmd/tui/context/local.tsx +0 -339
  71. package/src/cli/cmd/tui/context/prompt.tsx +0 -18
  72. package/src/cli/cmd/tui/context/route.tsx +0 -45
  73. package/src/cli/cmd/tui/context/sdk.tsx +0 -75
  74. package/src/cli/cmd/tui/context/sync.tsx +0 -374
  75. package/src/cli/cmd/tui/context/theme/aura.json +0 -69
  76. package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
  77. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -233
  78. package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
  79. package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -228
  80. package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
  81. package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
  82. package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
  83. package/src/cli/cmd/tui/context/theme/github.json +0 -233
  84. package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -95
  85. package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
  86. package/src/cli/cmd/tui/context/theme/material.json +0 -235
  87. package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
  88. package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
  89. package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
  90. package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
  91. package/src/cli/cmd/tui/context/theme/nord.json +0 -223
  92. package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
  93. package/src/cli/cmd/tui/context/theme/orng.json +0 -245
  94. package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
  95. package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
  96. package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
  97. package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
  98. package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
  99. package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
  100. package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
  101. package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
  102. package/src/cli/cmd/tui/context/theme.tsx +0 -1077
  103. package/src/cli/cmd/tui/event.ts +0 -39
  104. package/src/cli/cmd/tui/routes/home.tsx +0 -104
  105. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -93
  106. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -37
  107. package/src/cli/cmd/tui/routes/session/footer.tsx +0 -76
  108. package/src/cli/cmd/tui/routes/session/header.tsx +0 -183
  109. package/src/cli/cmd/tui/routes/session/index.tsx +0 -1703
  110. package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -586
  111. package/src/cli/cmd/tui/spawn.ts +0 -60
  112. package/src/cli/cmd/tui/thread.ts +0 -120
  113. package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -55
  114. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -81
  115. package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -36
  116. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -75
  117. package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -317
  118. package/src/cli/cmd/tui/ui/dialog.tsx +0 -170
  119. package/src/cli/cmd/tui/ui/spinner.ts +0 -368
  120. package/src/cli/cmd/tui/ui/toast.tsx +0 -100
  121. package/src/cli/cmd/tui/util/clipboard.ts +0 -127
  122. package/src/cli/cmd/tui/util/editor.ts +0 -32
  123. package/src/cli/cmd/tui/util/terminal.ts +0 -114
  124. package/src/cli/cmd/tui/worker.ts +0 -63
  125. package/src/cli/cmd/uninstall.ts +0 -344
  126. package/src/cli/cmd/upgrade.ts +0 -67
  127. package/src/cli/cmd/web.ts +0 -84
  128. package/src/cli/error.ts +0 -55
  129. package/src/cli/ui.ts +0 -84
  130. package/src/cli/upgrade.ts +0 -25
  131. package/src/command/index.ts +0 -79
  132. package/src/command/template/initialize.txt +0 -10
  133. package/src/command/template/review.txt +0 -73
  134. package/src/config/config.ts +0 -886
  135. package/src/config/markdown.ts +0 -41
  136. package/src/env/index.ts +0 -26
  137. package/src/file/fzf.ts +0 -124
  138. package/src/file/ignore.ts +0 -83
  139. package/src/file/index.ts +0 -326
  140. package/src/file/ripgrep.ts +0 -391
  141. package/src/file/time.ts +0 -38
  142. package/src/file/watcher.ts +0 -89
  143. package/src/flag/flag.ts +0 -28
  144. package/src/format/formatter.ts +0 -277
  145. package/src/format/index.ts +0 -137
  146. package/src/global/index.ts +0 -52
  147. package/src/id/id.ts +0 -73
  148. package/src/ide/index.ts +0 -75
  149. package/src/index.ts +0 -158
  150. package/src/installation/index.ts +0 -194
  151. package/src/lsp/client.ts +0 -215
  152. package/src/lsp/index.ts +0 -370
  153. package/src/lsp/language.ts +0 -111
  154. package/src/lsp/server.ts +0 -1327
  155. package/src/mcp/auth.ts +0 -82
  156. package/src/mcp/index.ts +0 -576
  157. package/src/mcp/oauth-callback.ts +0 -203
  158. package/src/mcp/oauth-provider.ts +0 -132
  159. package/src/notification/index.ts +0 -101
  160. package/src/patch/index.ts +0 -622
  161. package/src/permission/index.ts +0 -198
  162. package/src/plugin/index.ts +0 -95
  163. package/src/project/bootstrap.ts +0 -31
  164. package/src/project/instance.ts +0 -68
  165. package/src/project/project.ts +0 -133
  166. package/src/project/state.ts +0 -65
  167. package/src/project/vcs.ts +0 -77
  168. package/src/provider/auth.ts +0 -143
  169. package/src/provider/models-macro.ts +0 -11
  170. package/src/provider/models.ts +0 -93
  171. package/src/provider/provider.ts +0 -996
  172. package/src/provider/sdk/openai-compatible/src/README.md +0 -5
  173. package/src/provider/sdk/openai-compatible/src/index.ts +0 -2
  174. package/src/provider/sdk/openai-compatible/src/openai-compatible-provider.ts +0 -100
  175. package/src/provider/sdk/openai-compatible/src/responses/convert-to-openai-responses-input.ts +0 -303
  176. package/src/provider/sdk/openai-compatible/src/responses/map-openai-responses-finish-reason.ts +0 -27
  177. package/src/provider/sdk/openai-compatible/src/responses/openai-config.ts +0 -18
  178. package/src/provider/sdk/openai-compatible/src/responses/openai-error.ts +0 -22
  179. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-api-types.ts +0 -207
  180. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-language-model.ts +0 -1713
  181. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-prepare-tools.ts +0 -177
  182. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-settings.ts +0 -1
  183. package/src/provider/sdk/openai-compatible/src/responses/tool/code-interpreter.ts +0 -88
  184. package/src/provider/sdk/openai-compatible/src/responses/tool/file-search.ts +0 -128
  185. package/src/provider/sdk/openai-compatible/src/responses/tool/image-generation.ts +0 -115
  186. package/src/provider/sdk/openai-compatible/src/responses/tool/local-shell.ts +0 -65
  187. package/src/provider/sdk/openai-compatible/src/responses/tool/web-search-preview.ts +0 -104
  188. package/src/provider/sdk/openai-compatible/src/responses/tool/web-search.ts +0 -103
  189. package/src/provider/transform.ts +0 -406
  190. package/src/pty/index.ts +0 -226
  191. package/src/ratelimit/index.ts +0 -185
  192. package/src/server/error.ts +0 -36
  193. package/src/server/project.ts +0 -50
  194. package/src/server/server.ts +0 -2463
  195. package/src/server/tui.ts +0 -71
  196. package/src/session/compaction.ts +0 -257
  197. package/src/session/index.ts +0 -470
  198. package/src/session/message-v2.ts +0 -641
  199. package/src/session/message.ts +0 -189
  200. package/src/session/processor.ts +0 -443
  201. package/src/session/prompt/anthropic-20250930.txt +0 -166
  202. package/src/session/prompt/anthropic.txt +0 -105
  203. package/src/session/prompt/anthropic_spoof.txt +0 -1
  204. package/src/session/prompt/beast.txt +0 -147
  205. package/src/session/prompt/build-switch.txt +0 -5
  206. package/src/session/prompt/codex.txt +0 -318
  207. package/src/session/prompt/compaction.txt +0 -12
  208. package/src/session/prompt/copilot-gpt-5.txt +0 -143
  209. package/src/session/prompt/gemini.txt +0 -155
  210. package/src/session/prompt/max-steps.txt +0 -16
  211. package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
  212. package/src/session/prompt/plan.txt +0 -26
  213. package/src/session/prompt/polaris.txt +0 -107
  214. package/src/session/prompt/qwen.txt +0 -109
  215. package/src/session/prompt/summarize.txt +0 -4
  216. package/src/session/prompt/title.txt +0 -36
  217. package/src/session/prompt.ts +0 -1541
  218. package/src/session/retry.ts +0 -82
  219. package/src/session/revert.ts +0 -108
  220. package/src/session/status.ts +0 -75
  221. package/src/session/summary.ts +0 -203
  222. package/src/session/system.ts +0 -148
  223. package/src/session/todo.ts +0 -36
  224. package/src/share/share-next.ts +0 -195
  225. package/src/share/share.ts +0 -87
  226. package/src/snapshot/index.ts +0 -197
  227. package/src/storage/storage.ts +0 -226
  228. package/src/telemetry/index.ts +0 -232
  229. package/src/tool/bash.ts +0 -365
  230. package/src/tool/bash.txt +0 -128
  231. package/src/tool/batch.ts +0 -173
  232. package/src/tool/batch.txt +0 -28
  233. package/src/tool/codesearch.ts +0 -138
  234. package/src/tool/codesearch.txt +0 -12
  235. package/src/tool/edit.ts +0 -674
  236. package/src/tool/edit.txt +0 -10
  237. package/src/tool/glob.ts +0 -65
  238. package/src/tool/glob.txt +0 -6
  239. package/src/tool/grep.ts +0 -120
  240. package/src/tool/grep.txt +0 -8
  241. package/src/tool/invalid.ts +0 -17
  242. package/src/tool/ls.ts +0 -110
  243. package/src/tool/ls.txt +0 -1
  244. package/src/tool/lsp-diagnostics.ts +0 -26
  245. package/src/tool/lsp-diagnostics.txt +0 -1
  246. package/src/tool/lsp-hover.ts +0 -31
  247. package/src/tool/lsp-hover.txt +0 -1
  248. package/src/tool/multiedit.ts +0 -46
  249. package/src/tool/multiedit.txt +0 -41
  250. package/src/tool/patch.ts +0 -233
  251. package/src/tool/patch.txt +0 -1
  252. package/src/tool/read.ts +0 -217
  253. package/src/tool/read.txt +0 -12
  254. package/src/tool/registry.ts +0 -148
  255. package/src/tool/task.ts +0 -135
  256. package/src/tool/task.txt +0 -60
  257. package/src/tool/todo.ts +0 -39
  258. package/src/tool/todoread.txt +0 -14
  259. package/src/tool/todowrite.txt +0 -167
  260. package/src/tool/tool.ts +0 -66
  261. package/src/tool/webfetch.ts +0 -187
  262. package/src/tool/webfetch.txt +0 -14
  263. package/src/tool/websearch.ts +0 -150
  264. package/src/tool/websearch.txt +0 -11
  265. package/src/tool/write.ts +0 -99
  266. package/src/tool/write.txt +0 -8
  267. package/src/types/shims.d.ts +0 -3
  268. package/src/util/color.ts +0 -19
  269. package/src/util/context.ts +0 -25
  270. package/src/util/defer.ts +0 -12
  271. package/src/util/eventloop.ts +0 -20
  272. package/src/util/filesystem.ts +0 -69
  273. package/src/util/fn.ts +0 -11
  274. package/src/util/iife.ts +0 -3
  275. package/src/util/keybind.ts +0 -79
  276. package/src/util/lazy.ts +0 -11
  277. package/src/util/locale.ts +0 -81
  278. package/src/util/lock.ts +0 -98
  279. package/src/util/log.ts +0 -177
  280. package/src/util/queue.ts +0 -32
  281. package/src/util/rpc.ts +0 -42
  282. package/src/util/scrap.ts +0 -10
  283. package/src/util/signal.ts +0 -12
  284. package/src/util/timeout.ts +0 -14
  285. package/src/util/token.ts +0 -7
  286. package/src/util/wildcard.ts +0 -54
  287. package/sst-env.d.ts +0 -9
  288. package/test/bun.test.ts +0 -53
  289. package/test/config/agent-color.test.ts +0 -66
  290. package/test/config/config.test.ts +0 -503
  291. package/test/config/markdown.test.ts +0 -89
  292. package/test/file/ignore.test.ts +0 -10
  293. package/test/fixture/fixture.ts +0 -28
  294. package/test/fixture/lsp/fake-lsp-server.js +0 -77
  295. package/test/ide/ide.test.ts +0 -82
  296. package/test/keybind.test.ts +0 -317
  297. package/test/lsp/client.test.ts +0 -95
  298. package/test/patch/patch.test.ts +0 -348
  299. package/test/preload.ts +0 -38
  300. package/test/project/project.test.ts +0 -42
  301. package/test/provider/provider.test.ts +0 -1809
  302. package/test/provider/transform.test.ts +0 -305
  303. package/test/session/retry.test.ts +0 -61
  304. package/test/session/session.test.ts +0 -71
  305. package/test/snapshot/snapshot.test.ts +0 -939
  306. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  307. package/test/tool/bash.test.ts +0 -55
  308. package/test/tool/patch.test.ts +0 -259
  309. package/test/util/iife.test.ts +0 -36
  310. package/test/util/lazy.test.ts +0 -50
  311. package/test/util/timeout.test.ts +0 -21
  312. package/test/util/wildcard.test.ts +0 -55
  313. package/tsconfig.json +0 -17
@@ -1,127 +0,0 @@
1
- import { $ } from "bun"
2
- import { platform, release } from "os"
3
- import clipboardy from "clipboardy"
4
- import { lazy } from "../../../../util/lazy.js"
5
- import { tmpdir } from "os"
6
- import path from "path"
7
-
8
- export namespace Clipboard {
9
- export interface Content {
10
- data: string
11
- mime: string
12
- }
13
-
14
- export async function read(): Promise<Content | undefined> {
15
- const os = platform()
16
-
17
- if (os === "darwin") {
18
- const tmpfile = path.join(tmpdir(), "opencode-clipboard.png")
19
- try {
20
- await $`osascript -e 'set imageData to the clipboard as "PNGf"' -e 'set fileRef to open for access POSIX file "${tmpfile}" with write permission' -e 'set eof fileRef to 0' -e 'write imageData to fileRef' -e 'close access fileRef'`
21
- .nothrow()
22
- .quiet()
23
- const file = Bun.file(tmpfile)
24
- const buffer = await file.arrayBuffer()
25
- return { data: Buffer.from(buffer).toString("base64"), mime: "image/png" }
26
- } catch {
27
- } finally {
28
- await $`rm -f "${tmpfile}"`.nothrow().quiet()
29
- }
30
- }
31
-
32
- if (os === "win32" || release().includes("WSL")) {
33
- const script =
34
- "Add-Type -AssemblyName System.Windows.Forms; $img = [System.Windows.Forms.Clipboard]::GetImage(); if ($img) { $ms = New-Object System.IO.MemoryStream; $img.Save($ms, [System.Drawing.Imaging.ImageFormat]::Png); [System.Convert]::ToBase64String($ms.ToArray()) }"
35
- const base64 = await $`powershell.exe -command "${script}"`.nothrow().text()
36
- if (base64) {
37
- const imageBuffer = Buffer.from(base64.trim(), "base64")
38
- if (imageBuffer.length > 0) {
39
- return { data: imageBuffer.toString("base64"), mime: "image/png" }
40
- }
41
- }
42
- }
43
-
44
- if (os === "linux") {
45
- const wayland = await $`wl-paste -t image/png`.nothrow().arrayBuffer()
46
- if (wayland && wayland.byteLength > 0) {
47
- return { data: Buffer.from(wayland).toString("base64"), mime: "image/png" }
48
- }
49
- const x11 = await $`xclip -selection clipboard -t image/png -o`.nothrow().arrayBuffer()
50
- if (x11 && x11.byteLength > 0) {
51
- return { data: Buffer.from(x11).toString("base64"), mime: "image/png" }
52
- }
53
- }
54
-
55
- const text = await clipboardy.read().catch(() => {})
56
- if (text) {
57
- return { data: text, mime: "text/plain" }
58
- }
59
- }
60
-
61
- const getCopyMethod = lazy(() => {
62
- const os = platform()
63
-
64
- if (os === "darwin" && Bun.which("oascript")) {
65
- console.log("clipboard: using osascript")
66
- return async (text: string) => {
67
- const escaped = text.replace(/\\/g, "\\\\").replace(/"/g, '\\"')
68
- await $`osascript -e 'set the clipboard to "${escaped}"'`.nothrow().quiet()
69
- }
70
- }
71
-
72
- if (os === "linux") {
73
- if (process.env["WAYLAND_DISPLAY"] && Bun.which("wl-copy")) {
74
- console.log("clipboard: using wl-copy")
75
- return async (text: string) => {
76
- const proc = Bun.spawn(["wl-copy"], { stdin: "pipe", stdout: "ignore", stderr: "ignore" })
77
- proc.stdin.write(text)
78
- proc.stdin.end()
79
- await proc.exited.catch(() => {})
80
- }
81
- }
82
- if (Bun.which("xclip")) {
83
- console.log("clipboard: using xclip")
84
- return async (text: string) => {
85
- const proc = Bun.spawn(["xclip", "-selection", "clipboard"], {
86
- stdin: "pipe",
87
- stdout: "ignore",
88
- stderr: "ignore",
89
- })
90
- proc.stdin.write(text)
91
- proc.stdin.end()
92
- await proc.exited.catch(() => {})
93
- }
94
- }
95
- if (Bun.which("xsel")) {
96
- console.log("clipboard: using xsel")
97
- return async (text: string) => {
98
- const proc = Bun.spawn(["xsel", "--clipboard", "--input"], {
99
- stdin: "pipe",
100
- stdout: "ignore",
101
- stderr: "ignore",
102
- })
103
- proc.stdin.write(text)
104
- proc.stdin.end()
105
- await proc.exited.catch(() => {})
106
- }
107
- }
108
- }
109
-
110
- if (os === "win32") {
111
- console.log("clipboard: using powershell")
112
- return async (text: string) => {
113
- const escaped = text.replace(/"/g, '""')
114
- await $`powershell -command "Set-Clipboard -Value \"${escaped}\""`.nothrow().quiet()
115
- }
116
- }
117
-
118
- console.log("clipboard: no native support")
119
- return async (text: string) => {
120
- await clipboardy.write(text).catch(() => {})
121
- }
122
- })
123
-
124
- export async function copy(text: string): Promise<void> {
125
- await getCopyMethod()(text)
126
- }
127
- }
@@ -1,32 +0,0 @@
1
- import { defer } from "@/util/defer"
2
- import { rm } from "node:fs/promises"
3
- import { tmpdir } from "node:os"
4
- import { join } from "node:path"
5
- import { CliRenderer } from "@opentui/core"
6
-
7
- export namespace Editor {
8
- export async function open(opts: { value: string; renderer: CliRenderer }): Promise<string | undefined> {
9
- const editor = process.env["VISUAL"] || process.env["EDITOR"]
10
- if (!editor) return
11
-
12
- const filepath = join(tmpdir(), `${Date.now()}.md`)
13
- await using _ = defer(async () => rm(filepath, { force: true }))
14
-
15
- await Bun.write(filepath, opts.value)
16
- opts.renderer.suspend()
17
- opts.renderer.currentRenderBuffer.clear()
18
- const parts = editor.split(" ")
19
- const proc = Bun.spawn({
20
- cmd: [...parts, filepath],
21
- stdin: "inherit",
22
- stdout: "inherit",
23
- stderr: "inherit",
24
- })
25
- await proc.exited
26
- const content = await Bun.file(filepath).text()
27
- opts.renderer.currentRenderBuffer.clear()
28
- opts.renderer.resume()
29
- opts.renderer.requestRender()
30
- return content || undefined
31
- }
32
- }
@@ -1,114 +0,0 @@
1
- import { RGBA } from "@opentui/core"
2
-
3
- export namespace Terminal {
4
- export type Colors = Awaited<ReturnType<typeof colors>>
5
- /**
6
- * Query terminal colors including background, foreground, and palette (0-15).
7
- * Uses OSC escape sequences to retrieve actual terminal color values.
8
- *
9
- * Note: OSC 4 (palette) queries may not work through tmux as responses are filtered.
10
- * OSC 10/11 (foreground/background) typically work in most environments.
11
- *
12
- * Returns an object with background, foreground, and colors array.
13
- * Any query that fails will be null/empty.
14
- */
15
- export async function colors(): Promise<{
16
- background: RGBA | null
17
- foreground: RGBA | null
18
- colors: RGBA[]
19
- }> {
20
- if (!process.stdin.isTTY) return { background: null, foreground: null, colors: [] }
21
-
22
- return new Promise((resolve) => {
23
- let background: RGBA | null = null
24
- let foreground: RGBA | null = null
25
- const paletteColors: RGBA[] = []
26
- let timeout: NodeJS.Timeout
27
-
28
- const cleanup = () => {
29
- process.stdin.setRawMode(false)
30
- process.stdin.removeListener("data", handler)
31
- clearTimeout(timeout)
32
- }
33
-
34
- const parseColor = (colorStr: string): RGBA | null => {
35
- if (colorStr.startsWith("rgb:")) {
36
- const parts = colorStr.substring(4).split("/")
37
- return RGBA.fromInts(
38
- parseInt(parts[0], 16) >> 8, // Convert 16-bit to 8-bit
39
- parseInt(parts[1], 16) >> 8,
40
- parseInt(parts[2], 16) >> 8,
41
- 255,
42
- )
43
- }
44
- if (colorStr.startsWith("#")) {
45
- return RGBA.fromHex(colorStr)
46
- }
47
- if (colorStr.startsWith("rgb(")) {
48
- const parts = colorStr.substring(4, colorStr.length - 1).split(",")
49
- return RGBA.fromInts(parseInt(parts[0]), parseInt(parts[1]), parseInt(parts[2]), 255)
50
- }
51
- return null
52
- }
53
-
54
- const handler = (data: Buffer) => {
55
- const str = data.toString()
56
-
57
- // Match OSC 11 (background color)
58
- const bgMatch = str.match(/\x1b]11;([^\x07\x1b]+)/)
59
- if (bgMatch) {
60
- background = parseColor(bgMatch[1])
61
- }
62
-
63
- // Match OSC 10 (foreground color)
64
- const fgMatch = str.match(/\x1b]10;([^\x07\x1b]+)/)
65
- if (fgMatch) {
66
- foreground = parseColor(fgMatch[1])
67
- }
68
-
69
- // Match OSC 4 (palette colors)
70
- const paletteMatches = str.matchAll(/\x1b]4;(\d+);([^\x07\x1b]+)/g)
71
- for (const match of paletteMatches) {
72
- const index = parseInt(match[1])
73
- const color = parseColor(match[2])
74
- if (color) paletteColors[index] = color
75
- }
76
-
77
- // Return immediately if we have all 16 palette colors
78
- if (paletteColors.filter((c) => c !== undefined).length === 16) {
79
- cleanup()
80
- resolve({ background, foreground, colors: paletteColors })
81
- }
82
- }
83
-
84
- process.stdin.setRawMode(true)
85
- process.stdin.on("data", handler)
86
-
87
- // Query background (OSC 11)
88
- process.stdout.write("\x1b]11;?\x07")
89
- // Query foreground (OSC 10)
90
- process.stdout.write("\x1b]10;?\x07")
91
- // Query palette colors 0-15 (OSC 4)
92
- for (let i = 0; i < 16; i++) {
93
- process.stdout.write(`\x1b]4;${i};?\x07`)
94
- }
95
-
96
- timeout = setTimeout(() => {
97
- cleanup()
98
- resolve({ background, foreground, colors: paletteColors })
99
- }, 1000)
100
- })
101
- }
102
-
103
- export async function getTerminalBackgroundColor(): Promise<"dark" | "light"> {
104
- const result = await colors()
105
- if (!result.background) return "dark"
106
-
107
- const { r, g, b } = result.background
108
- // Calculate luminance using relative luminance formula
109
- const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255
110
-
111
- // Determine if dark or light based on luminance threshold
112
- return luminance > 0.5 ? "light" : "dark"
113
- }
114
- }
@@ -1,63 +0,0 @@
1
- import { Installation } from "@/installation"
2
- import { Server } from "@/server/server"
3
- import { Log } from "@/util/log"
4
- import { Instance } from "@/project/instance"
5
- import { InstanceBootstrap } from "@/project/bootstrap"
6
- import { Rpc } from "@/util/rpc"
7
- import { upgrade } from "@/cli/upgrade"
8
- import type { BunWebSocketData } from "hono/bun"
9
-
10
- await Log.init({
11
- print: process.argv.includes("--print-logs"),
12
- dev: Installation.isLocal(),
13
- level: (() => {
14
- if (Installation.isLocal()) return "DEBUG"
15
- return "INFO"
16
- })(),
17
- })
18
-
19
- process.on("unhandledRejection", (e) => {
20
- Log.Default.error("rejection", {
21
- e: e instanceof Error ? e.message : e,
22
- })
23
- })
24
-
25
- process.on("uncaughtException", (e) => {
26
- Log.Default.error("exception", {
27
- e: e instanceof Error ? e.message : e,
28
- })
29
- })
30
-
31
- let server: Bun.Server<BunWebSocketData>
32
- export const rpc = {
33
- async server(input: { port: number; hostname: string }) {
34
- if (server) await server.stop(true)
35
- try {
36
- server = Server.listen(input)
37
- return {
38
- url: server.url.toString(),
39
- }
40
- } catch (e) {
41
- console.error(e)
42
- throw e
43
- }
44
- },
45
- async checkUpgrade(input: { directory: string }) {
46
- await Instance.provide({
47
- directory: input.directory,
48
- init: InstanceBootstrap,
49
- fn: async () => {
50
- await upgrade().catch(() => {})
51
- },
52
- })
53
- },
54
- async shutdown() {
55
- Log.Default.info("worker shutting down")
56
- await Instance.disposeAll()
57
- // TODO: this should be awaited, but ws connections are
58
- // causing this to hang, need to revisit this
59
- server.stop(true)
60
- },
61
- }
62
-
63
- Rpc.listen(rpc)
@@ -1,344 +0,0 @@
1
- import type { Argv } from "yargs"
2
- import { UI } from "../ui"
3
- import * as prompts from "@clack/prompts"
4
- import { Installation } from "../../installation"
5
- import { Global } from "../../global"
6
- import { $ } from "bun"
7
- import fs from "fs/promises"
8
- import path from "path"
9
- import os from "os"
10
-
11
- interface UninstallArgs {
12
- keepConfig: boolean
13
- keepData: boolean
14
- dryRun: boolean
15
- force: boolean
16
- }
17
-
18
- interface RemovalTargets {
19
- directories: Array<{ path: string; label: string; keep: boolean }>
20
- shellConfig: string | null
21
- binary: string | null
22
- }
23
-
24
- export const UninstallCommand = {
25
- command: "uninstall",
26
- describe: "uninstall opencode and remove all related files",
27
- builder: (yargs: Argv) =>
28
- yargs
29
- .option("keep-config", {
30
- alias: "c",
31
- type: "boolean",
32
- describe: "keep configuration files",
33
- default: false,
34
- })
35
- .option("keep-data", {
36
- alias: "d",
37
- type: "boolean",
38
- describe: "keep session data and snapshots",
39
- default: false,
40
- })
41
- .option("dry-run", {
42
- type: "boolean",
43
- describe: "show what would be removed without removing",
44
- default: false,
45
- })
46
- .option("force", {
47
- alias: "f",
48
- type: "boolean",
49
- describe: "skip confirmation prompts",
50
- default: false,
51
- }),
52
-
53
- handler: async (args: UninstallArgs) => {
54
- UI.empty()
55
- UI.println(UI.logo(" "))
56
- UI.empty()
57
- prompts.intro("Uninstall OpenCode")
58
-
59
- const method = await Installation.method()
60
- prompts.log.info(`Installation method: ${method}`)
61
-
62
- const targets = await collectRemovalTargets(args, method)
63
-
64
- await showRemovalSummary(targets, method)
65
-
66
- if (!args.force && !args.dryRun) {
67
- const confirm = await prompts.confirm({
68
- message: "Are you sure you want to uninstall?",
69
- initialValue: false,
70
- })
71
- if (!confirm || prompts.isCancel(confirm)) {
72
- prompts.outro("Cancelled")
73
- return
74
- }
75
- }
76
-
77
- if (args.dryRun) {
78
- prompts.log.warn("Dry run - no changes made")
79
- prompts.outro("Done")
80
- return
81
- }
82
-
83
- await executeUninstall(method, targets)
84
-
85
- prompts.outro("Done")
86
- },
87
- }
88
-
89
- async function collectRemovalTargets(args: UninstallArgs, method: Installation.Method): Promise<RemovalTargets> {
90
- const directories: RemovalTargets["directories"] = [
91
- { path: Global.Path.data, label: "Data", keep: args.keepData },
92
- { path: Global.Path.cache, label: "Cache", keep: false },
93
- { path: Global.Path.config, label: "Config", keep: args.keepConfig },
94
- { path: Global.Path.state, label: "State", keep: false },
95
- ]
96
-
97
- const shellConfig = method === "curl" ? await getShellConfigFile() : null
98
- const binary = method === "curl" ? process.execPath : null
99
-
100
- return { directories, shellConfig, binary }
101
- }
102
-
103
- async function showRemovalSummary(targets: RemovalTargets, method: Installation.Method) {
104
- prompts.log.message("The following will be removed:")
105
-
106
- for (const dir of targets.directories) {
107
- const exists = await fs
108
- .access(dir.path)
109
- .then(() => true)
110
- .catch(() => false)
111
- if (!exists) continue
112
-
113
- const size = await getDirectorySize(dir.path)
114
- const sizeStr = formatSize(size)
115
- const status = dir.keep ? UI.Style.TEXT_DIM + "(keeping)" : ""
116
- const prefix = dir.keep ? "○" : "✓"
117
-
118
- prompts.log.info(` ${prefix} ${dir.label}: ${shortenPath(dir.path)} ${UI.Style.TEXT_DIM}(${sizeStr})${status}`)
119
- }
120
-
121
- if (targets.binary) {
122
- prompts.log.info(` ✓ Binary: ${shortenPath(targets.binary)}`)
123
- }
124
-
125
- if (targets.shellConfig) {
126
- prompts.log.info(` ✓ Shell PATH in ${shortenPath(targets.shellConfig)}`)
127
- }
128
-
129
- if (method !== "curl" && method !== "unknown") {
130
- const cmds: Record<string, string> = {
131
- npm: "npm uninstall -g opencode-ai",
132
- pnpm: "pnpm uninstall -g opencode-ai",
133
- bun: "bun remove -g opencode-ai",
134
- yarn: "yarn global remove opencode-ai",
135
- brew: "brew uninstall opencode",
136
- }
137
- prompts.log.info(` ✓ Package: ${cmds[method] || method}`)
138
- }
139
- }
140
-
141
- async function executeUninstall(method: Installation.Method, targets: RemovalTargets) {
142
- const spinner = prompts.spinner()
143
- const errors: string[] = []
144
-
145
- for (const dir of targets.directories) {
146
- if (dir.keep) {
147
- prompts.log.step(`Skipping ${dir.label} (--keep-${dir.label.toLowerCase()})`)
148
- continue
149
- }
150
-
151
- const exists = await fs
152
- .access(dir.path)
153
- .then(() => true)
154
- .catch(() => false)
155
- if (!exists) continue
156
-
157
- spinner.start(`Removing ${dir.label}...`)
158
- const err = await fs.rm(dir.path, { recursive: true, force: true }).catch((e) => e)
159
- if (err) {
160
- spinner.stop(`Failed to remove ${dir.label}`, 1)
161
- errors.push(`${dir.label}: ${err.message}`)
162
- continue
163
- }
164
- spinner.stop(`Removed ${dir.label}`)
165
- }
166
-
167
- if (targets.shellConfig) {
168
- spinner.start("Cleaning shell config...")
169
- const err = await cleanShellConfig(targets.shellConfig).catch((e) => e)
170
- if (err) {
171
- spinner.stop("Failed to clean shell config", 1)
172
- errors.push(`Shell config: ${err.message}`)
173
- } else {
174
- spinner.stop("Cleaned shell config")
175
- }
176
- }
177
-
178
- if (method !== "curl" && method !== "unknown") {
179
- const cmds: Record<string, string[]> = {
180
- npm: ["npm", "uninstall", "-g", "opencode-ai"],
181
- pnpm: ["pnpm", "uninstall", "-g", "opencode-ai"],
182
- bun: ["bun", "remove", "-g", "opencode-ai"],
183
- yarn: ["yarn", "global", "remove", "opencode-ai"],
184
- brew: ["brew", "uninstall", "opencode"],
185
- }
186
-
187
- const cmd = cmds[method]
188
- if (cmd) {
189
- spinner.start(`Running ${cmd.join(" ")}...`)
190
- const result = await $`${cmd}`.quiet().nothrow()
191
- if (result.exitCode !== 0) {
192
- spinner.stop(`Package manager uninstall failed`, 1)
193
- prompts.log.warn(`You may need to run manually: ${cmd.join(" ")}`)
194
- errors.push(`Package manager: exit code ${result.exitCode}`)
195
- } else {
196
- spinner.stop("Package removed")
197
- }
198
- }
199
- }
200
-
201
- if (method === "curl" && targets.binary) {
202
- UI.empty()
203
- prompts.log.message("To finish removing the binary, run:")
204
- prompts.log.info(` rm "${targets.binary}"`)
205
-
206
- const binDir = path.dirname(targets.binary)
207
- if (binDir.includes(".opencode")) {
208
- prompts.log.info(` rmdir "${binDir}" 2>/dev/null`)
209
- }
210
- }
211
-
212
- if (errors.length > 0) {
213
- UI.empty()
214
- prompts.log.warn("Some operations failed:")
215
- for (const err of errors) {
216
- prompts.log.error(` ${err}`)
217
- }
218
- }
219
-
220
- UI.empty()
221
- prompts.log.success("Thank you for using OpenCode!")
222
- }
223
-
224
- async function getShellConfigFile(): Promise<string | null> {
225
- const shell = path.basename(process.env.SHELL || "bash")
226
- const home = os.homedir()
227
- const xdgConfig = process.env.XDG_CONFIG_HOME || path.join(home, ".config")
228
-
229
- const configFiles: Record<string, string[]> = {
230
- fish: [path.join(xdgConfig, "fish", "config.fish")],
231
- zsh: [
232
- path.join(home, ".zshrc"),
233
- path.join(home, ".zshenv"),
234
- path.join(xdgConfig, "zsh", ".zshrc"),
235
- path.join(xdgConfig, "zsh", ".zshenv"),
236
- ],
237
- bash: [
238
- path.join(home, ".bashrc"),
239
- path.join(home, ".bash_profile"),
240
- path.join(home, ".profile"),
241
- path.join(xdgConfig, "bash", ".bashrc"),
242
- path.join(xdgConfig, "bash", ".bash_profile"),
243
- ],
244
- ash: [path.join(home, ".ashrc"), path.join(home, ".profile")],
245
- sh: [path.join(home, ".profile")],
246
- }
247
-
248
- const candidates = configFiles[shell] || configFiles.bash
249
-
250
- for (const file of candidates) {
251
- const exists = await fs
252
- .access(file)
253
- .then(() => true)
254
- .catch(() => false)
255
- if (!exists) continue
256
-
257
- const content = await Bun.file(file)
258
- .text()
259
- .catch(() => "")
260
- if (content.includes("# opencode") || content.includes(".opencode/bin")) {
261
- return file
262
- }
263
- }
264
-
265
- return null
266
- }
267
-
268
- async function cleanShellConfig(file: string) {
269
- const content = await Bun.file(file).text()
270
- const lines = content.split("\n")
271
-
272
- const filtered: string[] = []
273
- let skip = false
274
-
275
- for (const line of lines) {
276
- const trimmed = line.trim()
277
-
278
- if (trimmed === "# opencode") {
279
- skip = true
280
- continue
281
- }
282
-
283
- if (skip) {
284
- skip = false
285
- if (trimmed.includes(".opencode/bin") || trimmed.includes("fish_add_path")) {
286
- continue
287
- }
288
- }
289
-
290
- if (
291
- (trimmed.startsWith("export PATH=") && trimmed.includes(".opencode/bin")) ||
292
- (trimmed.startsWith("fish_add_path") && trimmed.includes(".opencode"))
293
- ) {
294
- continue
295
- }
296
-
297
- filtered.push(line)
298
- }
299
-
300
- while (filtered.length > 0 && filtered[filtered.length - 1].trim() === "") {
301
- filtered.pop()
302
- }
303
-
304
- const output = filtered.join("\n") + "\n"
305
- await Bun.write(file, output)
306
- }
307
-
308
- async function getDirectorySize(dir: string): Promise<number> {
309
- let total = 0
310
-
311
- const walk = async (current: string) => {
312
- const entries = await fs.readdir(current, { withFileTypes: true }).catch(() => [])
313
-
314
- for (const entry of entries) {
315
- const full = path.join(current, entry.name)
316
- if (entry.isDirectory()) {
317
- await walk(full)
318
- continue
319
- }
320
- if (entry.isFile()) {
321
- const stat = await fs.stat(full).catch(() => null)
322
- if (stat) total += stat.size
323
- }
324
- }
325
- }
326
-
327
- await walk(dir)
328
- return total
329
- }
330
-
331
- function formatSize(bytes: number): string {
332
- if (bytes < 1024) return `${bytes} B`
333
- if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} KB`
334
- if (bytes < 1024 * 1024 * 1024) return `${(bytes / (1024 * 1024)).toFixed(1)} MB`
335
- return `${(bytes / (1024 * 1024 * 1024)).toFixed(1)} GB`
336
- }
337
-
338
- function shortenPath(p: string): string {
339
- const home = os.homedir()
340
- if (p.startsWith(home)) {
341
- return p.replace(home, "~")
342
- }
343
- return p
344
- }