@stonerzju/opencode 1.2.16-offline.1 → 1.2.18

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 (262) hide show
  1. package/bin/opencode +29 -157
  2. package/package.json +29 -29
  3. package/src/acp/agent.ts +4 -4
  4. package/src/acp/session.ts +1 -1
  5. package/src/agent/agent.ts +3 -3
  6. package/src/bun/index.ts +2 -2
  7. package/src/cli/cmd/acp.ts +3 -3
  8. package/src/cli/cmd/debug/file.ts +1 -1
  9. package/src/cli/cmd/github.ts +2 -2
  10. package/src/cli/cmd/pr.ts +1 -1
  11. package/src/cli/cmd/tui/app.tsx +24 -24
  12. package/src/cli/cmd/tui/attach.ts +3 -3
  13. package/src/cli/cmd/tui/component/dialog-agent.tsx +3 -3
  14. package/src/cli/cmd/tui/component/dialog-command.tsx +3 -3
  15. package/src/cli/cmd/tui/component/dialog-mcp.tsx +5 -5
  16. package/src/cli/cmd/tui/component/dialog-model.tsx +4 -4
  17. package/src/cli/cmd/tui/component/dialog-provider.tsx +4 -4
  18. package/src/cli/cmd/tui/component/dialog-session-list.tsx +5 -5
  19. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +3 -3
  20. package/src/cli/cmd/tui/component/dialog-skill.tsx +3 -3
  21. package/src/cli/cmd/tui/component/dialog-stash.tsx +3 -3
  22. package/src/cli/cmd/tui/component/dialog-status.tsx +2 -2
  23. package/src/cli/cmd/tui/component/dialog-tag.tsx +3 -3
  24. package/src/cli/cmd/tui/component/logo.tsx +2 -2
  25. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +6 -6
  26. package/src/cli/cmd/tui/component/prompt/frecency.tsx +2 -2
  27. package/src/cli/cmd/tui/component/prompt/history.tsx +2 -2
  28. package/src/cli/cmd/tui/component/prompt/index.tsx +14 -14
  29. package/src/cli/cmd/tui/component/prompt/stash.tsx +2 -2
  30. package/src/cli/cmd/tui/component/textarea-keybindings.ts +1 -1
  31. package/src/cli/cmd/tui/component/tips.tsx +1 -1
  32. package/src/cli/cmd/tui/context/directory.ts +1 -1
  33. package/src/cli/cmd/tui/context/exit.tsx +1 -1
  34. package/src/cli/cmd/tui/context/keybind.tsx +2 -2
  35. package/src/cli/cmd/tui/context/kv.tsx +2 -2
  36. package/src/cli/cmd/tui/context/local.tsx +6 -6
  37. package/src/cli/cmd/tui/context/sync.tsx +4 -4
  38. package/src/cli/cmd/tui/context/theme/opencode.json +245 -0
  39. package/src/cli/cmd/tui/context/theme.tsx +2 -2
  40. package/src/cli/cmd/tui/context/tui-config.tsx +1 -1
  41. package/src/cli/cmd/tui/event.ts +2 -2
  42. package/src/cli/cmd/tui/routes/home.tsx +6 -6
  43. package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +6 -6
  44. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +6 -6
  45. package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +2 -2
  46. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +3 -3
  47. package/src/cli/cmd/tui/routes/session/header.tsx +5 -5
  48. package/src/cli/cmd/tui/routes/session/index.tsx +32 -32
  49. package/src/cli/cmd/tui/routes/session/permission.tsx +4 -4
  50. package/src/cli/cmd/tui/routes/session/sidebar.tsx +4 -4
  51. package/src/cli/cmd/tui/thread.ts +9 -9
  52. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +1 -1
  53. package/src/cli/cmd/tui/ui/dialog-help.tsx +2 -2
  54. package/src/cli/cmd/tui/ui/dialog-select.tsx +5 -5
  55. package/src/cli/cmd/tui/ui/dialog.tsx +3 -3
  56. package/src/cli/cmd/tui/ui/toast.tsx +1 -1
  57. package/src/cli/cmd/tui/util/editor.ts +3 -3
  58. package/src/cli/cmd/tui/util/transcript.ts +1 -1
  59. package/src/cli/cmd/tui/worker.ts +10 -10
  60. package/src/cli/error.ts +1 -1
  61. package/src/cli/ui.ts +1 -1
  62. package/src/cli/upgrade.ts +4 -4
  63. package/src/command/index.ts +1 -1
  64. package/src/config/config.ts +10 -10
  65. package/src/config/markdown.ts +1 -1
  66. package/src/config/migrate-tui-config.ts +5 -5
  67. package/src/config/paths.ts +4 -4
  68. package/src/config/tui.ts +4 -4
  69. package/src/control/control.sql.ts +1 -1
  70. package/src/control/index.ts +1 -1
  71. package/src/control-plane/adaptors/worktree.ts +1 -1
  72. package/src/control-plane/session-proxy-middleware.ts +1 -1
  73. package/src/control-plane/workspace.sql.ts +1 -1
  74. package/src/control-plane/workspace.ts +7 -7
  75. package/src/file/index.ts +1 -1
  76. package/src/file/ripgrep.ts +2 -2
  77. package/src/file/watcher.ts +5 -5
  78. package/src/format/formatter.ts +1 -1
  79. package/src/ide/index.ts +3 -3
  80. package/src/index.ts +1 -1
  81. package/src/installation/index.ts +3 -3
  82. package/src/lsp/client.ts +3 -3
  83. package/src/lsp/index.ts +3 -3
  84. package/src/mcp/index.ts +4 -4
  85. package/src/permission/index.ts +2 -2
  86. package/src/permission/next.ts +10 -10
  87. package/src/plugin/codex.ts +1 -1
  88. package/src/plugin/copilot.ts +2 -2
  89. package/src/plugin/index.ts +1 -1
  90. package/src/project/bootstrap.ts +2 -2
  91. package/src/project/instance.ts +4 -4
  92. package/src/project/project.sql.ts +1 -1
  93. package/src/project/project.ts +5 -5
  94. package/src/project/state.ts +1 -1
  95. package/src/project/vcs.ts +4 -4
  96. package/src/provider/auth.ts +4 -4
  97. package/src/provider/error.ts +1 -1
  98. package/src/provider/models-snapshot.ts +2 -0
  99. package/src/provider/models.ts +1 -1
  100. package/src/provider/provider.ts +2 -2
  101. package/src/provider/transform.ts +2 -2
  102. package/src/pty/index.ts +5 -5
  103. package/src/question/index.ts +5 -5
  104. package/src/server/event.ts +1 -1
  105. package/src/server/mdns.ts +1 -1
  106. package/src/server/routes/global.ts +3 -3
  107. package/src/server/routes/permission.ts +1 -1
  108. package/src/server/routes/pty.ts +1 -1
  109. package/src/server/routes/session.ts +4 -4
  110. package/src/server/routes/tui.ts +1 -1
  111. package/src/server/server.ts +3 -3
  112. package/src/session/compaction.ts +7 -7
  113. package/src/session/index.ts +10 -10
  114. package/src/session/instruction.ts +1 -1
  115. package/src/session/llm.ts +11 -11
  116. package/src/session/message-v2.ts +10 -10
  117. package/src/session/message.ts +1 -1
  118. package/src/session/processor.ts +10 -10
  119. package/src/session/prompt.ts +8 -8
  120. package/src/session/retry.ts +2 -2
  121. package/src/session/revert.ts +1 -1
  122. package/src/session/session.sql.ts +3 -3
  123. package/src/session/status.ts +3 -3
  124. package/src/session/summary.ts +5 -5
  125. package/src/session/system.ts +1 -1
  126. package/src/session/todo.ts +2 -2
  127. package/src/share/share-next.ts +7 -7
  128. package/src/share/share.sql.ts +1 -1
  129. package/src/shell/shell.ts +3 -3
  130. package/src/skill/skill.ts +6 -6
  131. package/src/storage/db.ts +1 -1
  132. package/src/storage/storage.ts +1 -1
  133. package/src/tool/bash.ts +6 -6
  134. package/src/tool/edit.ts +1 -1
  135. package/src/tool/registry.ts +2 -2
  136. package/src/tool/skill.ts +1 -1
  137. package/src/tool/task.ts +3 -3
  138. package/src/util/array.ts +10 -0
  139. package/src/util/binary.ts +41 -0
  140. package/src/util/encode.ts +51 -0
  141. package/src/util/error.ts +54 -0
  142. package/src/util/identifier.ts +48 -0
  143. package/src/util/lazy.ts +4 -16
  144. package/src/util/path.ts +37 -0
  145. package/src/util/retry.ts +41 -0
  146. package/src/util/slug.ts +74 -0
  147. package/src/worktree/index.ts +3 -3
  148. package/AGENTS.md +0 -10
  149. package/BUN_SHELL_MIGRATION_PLAN.md +0 -136
  150. package/Dockerfile +0 -18
  151. package/README.md +0 -15
  152. package/bunfig.toml +0 -7
  153. package/drizzle.config.ts +0 -10
  154. package/package.json.bak +0 -140
  155. package/script/build.ts +0 -224
  156. package/script/check-migrations.ts +0 -16
  157. package/script/postinstall.mjs +0 -131
  158. package/script/publish.ts +0 -181
  159. package/script/schema.ts +0 -63
  160. package/script/seed-e2e.ts +0 -50
  161. package/sst-env.d.ts +0 -10
  162. package/test/AGENTS.md +0 -81
  163. package/test/acp/agent-interface.test.ts +0 -51
  164. package/test/acp/event-subscription.test.ts +0 -683
  165. package/test/agent/agent.test.ts +0 -689
  166. package/test/bun.test.ts +0 -53
  167. package/test/cli/github-action.test.ts +0 -197
  168. package/test/cli/github-remote.test.ts +0 -80
  169. package/test/cli/import.test.ts +0 -38
  170. package/test/cli/plugin-auth-picker.test.ts +0 -120
  171. package/test/cli/tui/transcript.test.ts +0 -322
  172. package/test/config/agent-color.test.ts +0 -71
  173. package/test/config/config.test.ts +0 -1886
  174. package/test/config/fixtures/empty-frontmatter.md +0 -4
  175. package/test/config/fixtures/frontmatter.md +0 -28
  176. package/test/config/fixtures/markdown-header.md +0 -11
  177. package/test/config/fixtures/no-frontmatter.md +0 -1
  178. package/test/config/fixtures/weird-model-id.md +0 -13
  179. package/test/config/markdown.test.ts +0 -228
  180. package/test/config/tui.test.ts +0 -510
  181. package/test/control-plane/session-proxy-middleware.test.ts +0 -147
  182. package/test/control-plane/sse.test.ts +0 -56
  183. package/test/control-plane/workspace-server-sse.test.ts +0 -65
  184. package/test/control-plane/workspace-sync.test.ts +0 -97
  185. package/test/file/ignore.test.ts +0 -10
  186. package/test/file/index.test.ts +0 -394
  187. package/test/file/path-traversal.test.ts +0 -198
  188. package/test/file/ripgrep.test.ts +0 -39
  189. package/test/file/time.test.ts +0 -361
  190. package/test/fixture/db.ts +0 -11
  191. package/test/fixture/fixture.ts +0 -45
  192. package/test/fixture/lsp/fake-lsp-server.js +0 -77
  193. package/test/fixture/skills/agents-sdk/SKILL.md +0 -152
  194. package/test/fixture/skills/agents-sdk/references/callable.md +0 -92
  195. package/test/fixture/skills/cloudflare/SKILL.md +0 -211
  196. package/test/fixture/skills/index.json +0 -6
  197. package/test/ide/ide.test.ts +0 -82
  198. package/test/keybind.test.ts +0 -421
  199. package/test/lsp/client.test.ts +0 -95
  200. package/test/mcp/headers.test.ts +0 -153
  201. package/test/mcp/oauth-browser.test.ts +0 -249
  202. package/test/memory/abort-leak.test.ts +0 -136
  203. package/test/patch/patch.test.ts +0 -348
  204. package/test/permission/arity.test.ts +0 -33
  205. package/test/permission/next.test.ts +0 -689
  206. package/test/permission-task.test.ts +0 -319
  207. package/test/plugin/auth-override.test.ts +0 -44
  208. package/test/plugin/codex.test.ts +0 -123
  209. package/test/preload.ts +0 -80
  210. package/test/project/project.test.ts +0 -348
  211. package/test/project/worktree-remove.test.ts +0 -65
  212. package/test/provider/amazon-bedrock.test.ts +0 -446
  213. package/test/provider/copilot/convert-to-copilot-messages.test.ts +0 -523
  214. package/test/provider/copilot/copilot-chat-model.test.ts +0 -592
  215. package/test/provider/gitlab-duo.test.ts +0 -262
  216. package/test/provider/provider.test.ts +0 -2220
  217. package/test/provider/transform.test.ts +0 -2353
  218. package/test/pty/pty-output-isolation.test.ts +0 -140
  219. package/test/question/question.test.ts +0 -300
  220. package/test/scheduler.test.ts +0 -73
  221. package/test/server/global-session-list.test.ts +0 -89
  222. package/test/server/session-list.test.ts +0 -90
  223. package/test/server/session-select.test.ts +0 -78
  224. package/test/session/compaction.test.ts +0 -423
  225. package/test/session/instruction.test.ts +0 -170
  226. package/test/session/llm.test.ts +0 -667
  227. package/test/session/message-v2.test.ts +0 -924
  228. package/test/session/prompt.test.ts +0 -211
  229. package/test/session/retry.test.ts +0 -188
  230. package/test/session/revert-compact.test.ts +0 -285
  231. package/test/session/session.test.ts +0 -71
  232. package/test/session/structured-output-integration.test.ts +0 -233
  233. package/test/session/structured-output.test.ts +0 -385
  234. package/test/skill/discovery.test.ts +0 -110
  235. package/test/skill/skill.test.ts +0 -388
  236. package/test/snapshot/snapshot.test.ts +0 -1180
  237. package/test/storage/json-migration.test.ts +0 -846
  238. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  239. package/test/tool/apply_patch.test.ts +0 -566
  240. package/test/tool/bash.test.ts +0 -402
  241. package/test/tool/edit.test.ts +0 -496
  242. package/test/tool/external-directory.test.ts +0 -127
  243. package/test/tool/fixtures/large-image.png +0 -0
  244. package/test/tool/fixtures/models-api.json +0 -38413
  245. package/test/tool/grep.test.ts +0 -110
  246. package/test/tool/question.test.ts +0 -107
  247. package/test/tool/read.test.ts +0 -504
  248. package/test/tool/registry.test.ts +0 -122
  249. package/test/tool/skill.test.ts +0 -112
  250. package/test/tool/truncation.test.ts +0 -160
  251. package/test/tool/webfetch.test.ts +0 -100
  252. package/test/tool/write.test.ts +0 -348
  253. package/test/util/filesystem.test.ts +0 -443
  254. package/test/util/format.test.ts +0 -59
  255. package/test/util/glob.test.ts +0 -164
  256. package/test/util/iife.test.ts +0 -36
  257. package/test/util/lazy.test.ts +0 -50
  258. package/test/util/lock.test.ts +0 -72
  259. package/test/util/process.test.ts +0 -59
  260. package/test/util/timeout.test.ts +0 -21
  261. package/test/util/wildcard.test.ts +0 -90
  262. package/tsconfig.json +0 -16
@@ -1,36 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import { iife } from "../../src/util/iife"
3
-
4
- describe("util.iife", () => {
5
- test("should execute function immediately and return result", () => {
6
- let called = false
7
- const result = iife(() => {
8
- called = true
9
- return 42
10
- })
11
-
12
- expect(called).toBe(true)
13
- expect(result).toBe(42)
14
- })
15
-
16
- test("should work with async functions", async () => {
17
- let called = false
18
- const result = await iife(async () => {
19
- called = true
20
- return "async result"
21
- })
22
-
23
- expect(called).toBe(true)
24
- expect(result).toBe("async result")
25
- })
26
-
27
- test("should handle functions with no return value", () => {
28
- let called = false
29
- const result = iife(() => {
30
- called = true
31
- })
32
-
33
- expect(called).toBe(true)
34
- expect(result).toBeUndefined()
35
- })
36
- })
@@ -1,50 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import { lazy } from "../../src/util/lazy"
3
-
4
- describe("util.lazy", () => {
5
- test("should call function only once", () => {
6
- let callCount = 0
7
- const getValue = () => {
8
- callCount++
9
- return "expensive value"
10
- }
11
-
12
- const lazyValue = lazy(getValue)
13
-
14
- expect(callCount).toBe(0)
15
-
16
- const result1 = lazyValue()
17
- expect(result1).toBe("expensive value")
18
- expect(callCount).toBe(1)
19
-
20
- const result2 = lazyValue()
21
- expect(result2).toBe("expensive value")
22
- expect(callCount).toBe(1)
23
- })
24
-
25
- test("should preserve the same reference", () => {
26
- const obj = { value: 42 }
27
- const lazyObj = lazy(() => obj)
28
-
29
- const result1 = lazyObj()
30
- const result2 = lazyObj()
31
-
32
- expect(result1).toBe(obj)
33
- expect(result2).toBe(obj)
34
- expect(result1).toBe(result2)
35
- })
36
-
37
- test("should work with different return types", () => {
38
- const lazyString = lazy(() => "string")
39
- const lazyNumber = lazy(() => 123)
40
- const lazyBoolean = lazy(() => true)
41
- const lazyNull = lazy(() => null)
42
- const lazyUndefined = lazy(() => undefined)
43
-
44
- expect(lazyString()).toBe("string")
45
- expect(lazyNumber()).toBe(123)
46
- expect(lazyBoolean()).toBe(true)
47
- expect(lazyNull()).toBe(null)
48
- expect(lazyUndefined()).toBe(undefined)
49
- })
50
- })
@@ -1,72 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import { Lock } from "../../src/util/lock"
3
-
4
- function tick() {
5
- return new Promise<void>((r) => queueMicrotask(r))
6
- }
7
-
8
- async function flush(n = 5) {
9
- for (let i = 0; i < n; i++) await tick()
10
- }
11
-
12
- describe("util.lock", () => {
13
- test("writer exclusivity: blocks reads and other writes while held", async () => {
14
- const key = "lock:" + Math.random().toString(36).slice(2)
15
-
16
- const state = {
17
- writer2: false,
18
- reader: false,
19
- writers: 0,
20
- }
21
-
22
- // Acquire writer1
23
- using writer1 = await Lock.write(key)
24
- state.writers++
25
- expect(state.writers).toBe(1)
26
-
27
- // Start writer2 candidate (should block)
28
- const writer2Task = (async () => {
29
- const w = await Lock.write(key)
30
- state.writers++
31
- expect(state.writers).toBe(1)
32
- state.writer2 = true
33
- // Hold for a tick so reader cannot slip in
34
- await tick()
35
- return w
36
- })()
37
-
38
- // Start reader candidate (should block)
39
- const readerTask = (async () => {
40
- const r = await Lock.read(key)
41
- state.reader = true
42
- return r
43
- })()
44
-
45
- // Flush microtasks and assert neither acquired
46
- await flush()
47
- expect(state.writer2).toBe(false)
48
- expect(state.reader).toBe(false)
49
-
50
- // Release writer1
51
- writer1[Symbol.dispose]()
52
- state.writers--
53
-
54
- // writer2 should acquire next
55
- const writer2 = await writer2Task
56
- expect(state.writer2).toBe(true)
57
-
58
- // Reader still blocked while writer2 held
59
- await flush()
60
- expect(state.reader).toBe(false)
61
-
62
- // Release writer2
63
- writer2[Symbol.dispose]()
64
- state.writers--
65
-
66
- // Reader should now acquire
67
- const reader = await readerTask
68
- expect(state.reader).toBe(true)
69
-
70
- reader[Symbol.dispose]()
71
- })
72
- })
@@ -1,59 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import { Process } from "../../src/util/process"
3
-
4
- function node(script: string) {
5
- return [process.execPath, "-e", script]
6
- }
7
-
8
- describe("util.process", () => {
9
- test("captures stdout and stderr", async () => {
10
- const out = await Process.run(node('process.stdout.write("out");process.stderr.write("err")'))
11
- expect(out.code).toBe(0)
12
- expect(out.stdout.toString()).toBe("out")
13
- expect(out.stderr.toString()).toBe("err")
14
- })
15
-
16
- test("returns code when nothrow is enabled", async () => {
17
- const out = await Process.run(node("process.exit(7)"), { nothrow: true })
18
- expect(out.code).toBe(7)
19
- })
20
-
21
- test("throws RunFailedError on non-zero exit", async () => {
22
- const err = await Process.run(node('process.stderr.write("bad");process.exit(3)')).catch((error) => error)
23
- expect(err).toBeInstanceOf(Process.RunFailedError)
24
- if (!(err instanceof Process.RunFailedError)) throw err
25
- expect(err.code).toBe(3)
26
- expect(err.stderr.toString()).toBe("bad")
27
- })
28
-
29
- test("aborts a running process", async () => {
30
- const abort = new AbortController()
31
- const started = Date.now()
32
- setTimeout(() => abort.abort(), 25)
33
-
34
- const out = await Process.run(node("setInterval(() => {}, 1000)"), {
35
- abort: abort.signal,
36
- nothrow: true,
37
- })
38
-
39
- expect(out.code).not.toBe(0)
40
- expect(Date.now() - started).toBeLessThan(1000)
41
- }, 3000)
42
-
43
- test("kills after timeout when process ignores terminate signal", async () => {
44
- if (process.platform === "win32") return
45
-
46
- const abort = new AbortController()
47
- const started = Date.now()
48
- setTimeout(() => abort.abort(), 25)
49
-
50
- const out = await Process.run(node('process.on("SIGTERM", () => {}); setInterval(() => {}, 1000)'), {
51
- abort: abort.signal,
52
- nothrow: true,
53
- timeout: 25,
54
- })
55
-
56
- expect(out.code).not.toBe(0)
57
- expect(Date.now() - started).toBeLessThan(1000)
58
- }, 3000)
59
- })
@@ -1,21 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import { withTimeout } from "../../src/util/timeout"
3
-
4
- describe("util.timeout", () => {
5
- test("should resolve when promise completes before timeout", async () => {
6
- const fastPromise = new Promise<string>((resolve) => {
7
- setTimeout(() => resolve("fast"), 10)
8
- })
9
-
10
- const result = await withTimeout(fastPromise, 100)
11
- expect(result).toBe("fast")
12
- })
13
-
14
- test("should reject when promise exceeds timeout", async () => {
15
- const slowPromise = new Promise<string>((resolve) => {
16
- setTimeout(() => resolve("slow"), 200)
17
- })
18
-
19
- await expect(withTimeout(slowPromise, 50)).rejects.toThrow("Operation timed out after 50ms")
20
- })
21
- })
@@ -1,90 +0,0 @@
1
- import { test, expect } from "bun:test"
2
- import { Wildcard } from "../../src/util/wildcard"
3
-
4
- test("match handles glob tokens", () => {
5
- expect(Wildcard.match("file1.txt", "file?.txt")).toBe(true)
6
- expect(Wildcard.match("file12.txt", "file?.txt")).toBe(false)
7
- expect(Wildcard.match("foo+bar", "foo+bar")).toBe(true)
8
- })
9
-
10
- test("match with trailing space+wildcard matches command with or without args", () => {
11
- // "ls *" should match "ls" (no args) and "ls -la" (with args)
12
- expect(Wildcard.match("ls", "ls *")).toBe(true)
13
- expect(Wildcard.match("ls -la", "ls *")).toBe(true)
14
- expect(Wildcard.match("ls foo bar", "ls *")).toBe(true)
15
-
16
- // "ls*" (no space) should NOT match "ls" alone — wait, it should because .* matches empty
17
- // but it WILL match "lstmeval" which is the dangerous case users should avoid
18
- expect(Wildcard.match("ls", "ls*")).toBe(true)
19
- expect(Wildcard.match("lstmeval", "ls*")).toBe(true)
20
-
21
- // "ls *" (with space) should NOT match "lstmeval"
22
- expect(Wildcard.match("lstmeval", "ls *")).toBe(false)
23
-
24
- // multi-word commands
25
- expect(Wildcard.match("git status", "git *")).toBe(true)
26
- expect(Wildcard.match("git", "git *")).toBe(true)
27
- expect(Wildcard.match("git commit -m foo", "git *")).toBe(true)
28
- })
29
-
30
- test("all picks the most specific pattern", () => {
31
- const rules = {
32
- "*": "deny",
33
- "git *": "ask",
34
- "git status": "allow",
35
- }
36
- expect(Wildcard.all("git status", rules)).toBe("allow")
37
- expect(Wildcard.all("git log", rules)).toBe("ask")
38
- expect(Wildcard.all("echo hi", rules)).toBe("deny")
39
- })
40
-
41
- test("allStructured matches command sequences", () => {
42
- const rules = {
43
- "git *": "ask",
44
- "git status*": "allow",
45
- }
46
- expect(Wildcard.allStructured({ head: "git", tail: ["status", "--short"] }, rules)).toBe("allow")
47
- expect(Wildcard.allStructured({ head: "npm", tail: ["run", "build", "--watch"] }, { "npm run *": "allow" })).toBe(
48
- "allow",
49
- )
50
- expect(Wildcard.allStructured({ head: "ls", tail: ["-la"] }, rules)).toBeUndefined()
51
- })
52
-
53
- test("allStructured prioritizes flag-specific patterns", () => {
54
- const rules = {
55
- "find *": "allow",
56
- "find * -delete*": "ask",
57
- "sort*": "allow",
58
- "sort -o *": "ask",
59
- }
60
- expect(Wildcard.allStructured({ head: "find", tail: ["src", "-delete"] }, rules)).toBe("ask")
61
- expect(Wildcard.allStructured({ head: "find", tail: ["src", "-print"] }, rules)).toBe("allow")
62
- expect(Wildcard.allStructured({ head: "sort", tail: ["-o", "out.txt"] }, rules)).toBe("ask")
63
- expect(Wildcard.allStructured({ head: "sort", tail: ["--reverse"] }, rules)).toBe("allow")
64
- })
65
-
66
- test("allStructured handles sed flags", () => {
67
- const rules = {
68
- "sed * -i*": "ask",
69
- "sed -n*": "allow",
70
- }
71
- expect(Wildcard.allStructured({ head: "sed", tail: ["-i", "file"] }, rules)).toBe("ask")
72
- expect(Wildcard.allStructured({ head: "sed", tail: ["-i.bak", "file"] }, rules)).toBe("ask")
73
- expect(Wildcard.allStructured({ head: "sed", tail: ["-n", "1p", "file"] }, rules)).toBe("allow")
74
- expect(Wildcard.allStructured({ head: "sed", tail: ["-i", "-n", "/./p", "myfile.txt"] }, rules)).toBe("ask")
75
- })
76
-
77
- test("match normalizes slashes for cross-platform globbing", () => {
78
- expect(Wildcard.match("C:\\Windows\\System32\\*", "C:/Windows/System32/*")).toBe(true)
79
- expect(Wildcard.match("C:/Windows/System32/drivers", "C:\\Windows\\System32\\*")).toBe(true)
80
- })
81
-
82
- test("match handles case-insensitivity on Windows", () => {
83
- if (process.platform === "win32") {
84
- expect(Wildcard.match("C:\\windows\\system32\\hosts", "C:/Windows/System32/*")).toBe(true)
85
- expect(Wildcard.match("c:/windows/system32/hosts", "C:\\Windows\\System32\\*")).toBe(true)
86
- } else {
87
- // Unix paths are case-sensitive
88
- expect(Wildcard.match("/users/test/file", "/Users/test/*")).toBe(false)
89
- }
90
- })
package/tsconfig.json DELETED
@@ -1,16 +0,0 @@
1
- {
2
- "$schema": "https://json.schemastore.org/tsconfig",
3
- "extends": "@tsconfig/bun/tsconfig.json",
4
- "compilerOptions": {
5
- "jsx": "preserve",
6
- "jsxImportSource": "@opentui/solid",
7
- "lib": ["ESNext", "DOM", "DOM.Iterable"],
8
- "types": [],
9
- "noUncheckedIndexedAccess": false,
10
- "customConditions": ["browser"],
11
- "paths": {
12
- "@/*": ["./src/*"],
13
- "@tui/*": ["./src/cli/cmd/tui/*"]
14
- }
15
- }
16
- }