@sentry/warden 0.1.0 → 0.2.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 (588) hide show
  1. package/dist/cli/commands/init.d.ts.map +1 -1
  2. package/dist/cli/commands/init.js +3 -1
  3. package/dist/cli/commands/init.js.map +1 -1
  4. package/dist/cli/commands/setup-app/manifest.d.ts.map +1 -1
  5. package/dist/cli/commands/setup-app/manifest.js +3 -1
  6. package/dist/cli/commands/setup-app/manifest.js.map +1 -1
  7. package/dist/cli/commands/setup-app.js +1 -1
  8. package/dist/cli/commands/setup-app.js.map +1 -1
  9. package/dist/cli/files.d.ts +11 -1
  10. package/dist/cli/files.d.ts.map +1 -1
  11. package/dist/cli/files.js +145 -4
  12. package/dist/cli/files.js.map +1 -1
  13. package/dist/cli/git.d.ts.map +1 -1
  14. package/dist/cli/git.js +5 -9
  15. package/dist/cli/git.js.map +1 -1
  16. package/dist/cli/index.js +0 -0
  17. package/dist/cli/output/icons.d.ts +4 -0
  18. package/dist/cli/output/icons.d.ts.map +1 -1
  19. package/dist/cli/output/icons.js +4 -0
  20. package/dist/cli/output/icons.js.map +1 -1
  21. package/dist/cli/output/ink-runner.d.ts +20 -0
  22. package/dist/cli/output/ink-runner.d.ts.map +1 -1
  23. package/dist/cli/output/ink-runner.js +53 -19
  24. package/dist/cli/output/ink-runner.js.map +1 -1
  25. package/dist/cli/output/tasks.d.ts.map +1 -1
  26. package/dist/cli/output/tasks.js +5 -1
  27. package/dist/cli/output/tasks.js.map +1 -1
  28. package/dist/config/schema.d.ts.map +1 -1
  29. package/dist/config/schema.js +15 -1
  30. package/dist/config/schema.js.map +1 -1
  31. package/dist/diff/coalesce.d.ts +32 -2
  32. package/dist/diff/coalesce.d.ts.map +1 -1
  33. package/dist/diff/coalesce.js +174 -2
  34. package/dist/diff/coalesce.js.map +1 -1
  35. package/dist/output/dedup.d.ts.map +1 -1
  36. package/dist/output/dedup.js +8 -3
  37. package/dist/output/dedup.js.map +1 -1
  38. package/dist/output/renderer.d.ts.map +1 -1
  39. package/dist/output/renderer.js +49 -5
  40. package/dist/output/renderer.js.map +1 -1
  41. package/dist/output/stale.d.ts.map +1 -1
  42. package/dist/output/stale.js +7 -0
  43. package/dist/output/stale.js.map +1 -1
  44. package/dist/output/types.d.ts +15 -1
  45. package/dist/output/types.d.ts.map +1 -1
  46. package/dist/sdk/analyze.d.ts +18 -0
  47. package/dist/sdk/analyze.d.ts.map +1 -0
  48. package/dist/sdk/analyze.js +425 -0
  49. package/dist/sdk/analyze.js.map +1 -0
  50. package/dist/sdk/errors.d.ts +23 -0
  51. package/dist/sdk/errors.d.ts.map +1 -0
  52. package/dist/sdk/errors.js +72 -0
  53. package/dist/sdk/errors.js.map +1 -0
  54. package/dist/sdk/extract.d.ts +44 -0
  55. package/dist/sdk/extract.d.ts.map +1 -0
  56. package/dist/sdk/extract.js +224 -0
  57. package/dist/sdk/extract.js.map +1 -0
  58. package/dist/sdk/prepare.d.ts +13 -0
  59. package/dist/sdk/prepare.d.ts.map +1 -0
  60. package/dist/sdk/prepare.js +73 -0
  61. package/dist/sdk/prepare.js.map +1 -0
  62. package/dist/sdk/prompt.d.ts +30 -0
  63. package/dist/sdk/prompt.d.ts.map +1 -0
  64. package/dist/sdk/prompt.js +109 -0
  65. package/dist/sdk/prompt.js.map +1 -0
  66. package/dist/sdk/retry.d.ts +12 -0
  67. package/dist/sdk/retry.d.ts.map +1 -0
  68. package/dist/sdk/retry.js +31 -0
  69. package/dist/sdk/retry.js.map +1 -0
  70. package/dist/sdk/runner.d.ts +22 -199
  71. package/dist/sdk/runner.d.ts.map +1 -1
  72. package/dist/sdk/runner.js +26 -884
  73. package/dist/sdk/runner.js.map +1 -1
  74. package/dist/sdk/types.d.ts +127 -0
  75. package/dist/sdk/types.d.ts.map +1 -0
  76. package/dist/sdk/types.js +5 -0
  77. package/dist/sdk/types.js.map +1 -0
  78. package/dist/sdk/usage.d.ts +20 -0
  79. package/dist/sdk/usage.d.ts.map +1 -0
  80. package/dist/sdk/usage.js +44 -0
  81. package/dist/sdk/usage.js.map +1 -0
  82. package/dist/skills/remote.d.ts.map +1 -1
  83. package/dist/skills/remote.js +3 -7
  84. package/dist/skills/remote.js.map +1 -1
  85. package/dist/types/index.d.ts +1 -0
  86. package/dist/types/index.d.ts.map +1 -1
  87. package/dist/types/index.js +2 -0
  88. package/dist/types/index.js.map +1 -1
  89. package/dist/utils/exec.d.ts +61 -0
  90. package/dist/utils/exec.d.ts.map +1 -0
  91. package/dist/utils/exec.js +111 -0
  92. package/dist/utils/exec.js.map +1 -0
  93. package/dist/utils/index.d.ts +2 -0
  94. package/dist/utils/index.d.ts.map +1 -1
  95. package/dist/utils/index.js +1 -0
  96. package/dist/utils/index.js.map +1 -1
  97. package/package.json +15 -16
  98. package/.agents/skills/find-bugs/SKILL.md +0 -75
  99. package/.agents/skills/vercel-react-best-practices/AGENTS.md +0 -2934
  100. package/.agents/skills/vercel-react-best-practices/SKILL.md +0 -136
  101. package/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  102. package/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +0 -42
  103. package/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +0 -39
  104. package/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +0 -38
  105. package/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +0 -80
  106. package/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +0 -51
  107. package/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +0 -28
  108. package/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +0 -99
  109. package/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +0 -59
  110. package/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +0 -31
  111. package/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +0 -49
  112. package/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  113. package/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +0 -50
  114. package/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +0 -74
  115. package/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +0 -71
  116. package/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +0 -48
  117. package/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +0 -56
  118. package/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +0 -107
  119. package/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +0 -80
  120. package/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +0 -28
  121. package/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +0 -70
  122. package/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +0 -32
  123. package/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +0 -50
  124. package/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +0 -45
  125. package/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +0 -37
  126. package/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +0 -49
  127. package/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +0 -82
  128. package/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +0 -24
  129. package/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +0 -57
  130. package/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +0 -26
  131. package/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  132. package/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +0 -40
  133. package/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +0 -38
  134. package/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  135. package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  136. package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  137. package/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +0 -28
  138. package/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  139. package/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +0 -39
  140. package/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +0 -45
  141. package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  142. package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +0 -29
  143. package/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +0 -74
  144. package/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  145. package/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  146. package/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +0 -44
  147. package/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  148. package/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  149. package/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +0 -40
  150. package/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  151. package/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +0 -73
  152. package/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +0 -96
  153. package/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +0 -41
  154. package/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +0 -76
  155. package/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +0 -65
  156. package/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +0 -83
  157. package/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +0 -38
  158. package/.claude/settings.json +0 -57
  159. package/.claude/skills/agent-prompt/SKILL.md +0 -54
  160. package/.claude/skills/agent-prompt/references/agentic-patterns.md +0 -94
  161. package/.claude/skills/agent-prompt/references/anti-patterns.md +0 -140
  162. package/.claude/skills/agent-prompt/references/context-design.md +0 -124
  163. package/.claude/skills/agent-prompt/references/core-principles.md +0 -75
  164. package/.claude/skills/agent-prompt/references/model-guidance.md +0 -118
  165. package/.claude/skills/agent-prompt/references/output-formats.md +0 -98
  166. package/.claude/skills/agent-prompt/references/skill-structure.md +0 -115
  167. package/.claude/skills/agent-prompt/references/system-prompts.md +0 -115
  168. package/.claude/skills/notseer/SKILL.md +0 -131
  169. package/.claude/skills/skill-writer/SKILL.md +0 -140
  170. package/.claude/skills/testing-guidelines/SKILL.md +0 -132
  171. package/.claude/skills/warden-skill/SKILL.md +0 -250
  172. package/.claude/skills/warden-skill/references/config-schema.md +0 -133
  173. package/.dex/config.toml +0 -2
  174. package/.github/workflows/ci.yml +0 -33
  175. package/.github/workflows/release.yml +0 -59
  176. package/.github/workflows/warden.yml +0 -40
  177. package/AGENTS.md +0 -89
  178. package/CONTRIBUTING.md +0 -60
  179. package/SPEC.md +0 -263
  180. package/action.yml +0 -87
  181. package/assets/favicon.png +0 -0
  182. package/assets/warden-icon-bw.svg +0 -5
  183. package/assets/warden-icon-purple.png +0 -0
  184. package/assets/warden-icon-purple.svg +0 -5
  185. package/dist/action/159.index.js +0 -523
  186. package/dist/action/159.index.js.map +0 -1
  187. package/dist/action/action/index.d.ts +0 -2
  188. package/dist/action/action/index.d.ts.map +0 -1
  189. package/dist/action/action/main.d.ts +0 -2
  190. package/dist/action/action/main.d.ts.map +0 -1
  191. package/dist/action/cli/args.d.ts +0 -74
  192. package/dist/action/cli/args.d.ts.map +0 -1
  193. package/dist/action/cli/args.test.d.ts +0 -2
  194. package/dist/action/cli/args.test.d.ts.map +0 -1
  195. package/dist/action/cli/commands/add.d.ts +0 -7
  196. package/dist/action/cli/commands/add.d.ts.map +0 -1
  197. package/dist/action/cli/commands/init.d.ts +0 -10
  198. package/dist/action/cli/commands/init.d.ts.map +0 -1
  199. package/dist/action/cli/commands/init.test.d.ts +0 -2
  200. package/dist/action/cli/commands/init.test.d.ts.map +0 -1
  201. package/dist/action/cli/commands/setup-app/browser.d.ts +0 -9
  202. package/dist/action/cli/commands/setup-app/browser.d.ts.map +0 -1
  203. package/dist/action/cli/commands/setup-app/credentials.d.ts +0 -15
  204. package/dist/action/cli/commands/setup-app/credentials.d.ts.map +0 -1
  205. package/dist/action/cli/commands/setup-app/manifest.d.ts +0 -24
  206. package/dist/action/cli/commands/setup-app/manifest.d.ts.map +0 -1
  207. package/dist/action/cli/commands/setup-app/server.d.ts +0 -28
  208. package/dist/action/cli/commands/setup-app/server.d.ts.map +0 -1
  209. package/dist/action/cli/commands/setup-app.d.ts +0 -11
  210. package/dist/action/cli/commands/setup-app.d.ts.map +0 -1
  211. package/dist/action/cli/commands/sync.d.ts +0 -9
  212. package/dist/action/cli/commands/sync.d.ts.map +0 -1
  213. package/dist/action/cli/context.d.ts +0 -27
  214. package/dist/action/cli/context.d.ts.map +0 -1
  215. package/dist/action/cli/files.d.ts +0 -22
  216. package/dist/action/cli/files.d.ts.map +0 -1
  217. package/dist/action/cli/files.test.d.ts +0 -2
  218. package/dist/action/cli/files.test.d.ts.map +0 -1
  219. package/dist/action/cli/fix.d.ts +0 -41
  220. package/dist/action/cli/fix.d.ts.map +0 -1
  221. package/dist/action/cli/fix.test.d.ts +0 -2
  222. package/dist/action/cli/fix.test.d.ts.map +0 -1
  223. package/dist/action/cli/git.d.ts +0 -73
  224. package/dist/action/cli/git.d.ts.map +0 -1
  225. package/dist/action/cli/git.test.d.ts +0 -2
  226. package/dist/action/cli/git.test.d.ts.map +0 -1
  227. package/dist/action/cli/index.d.ts +0 -3
  228. package/dist/action/cli/index.d.ts.map +0 -1
  229. package/dist/action/cli/main.d.ts +0 -7
  230. package/dist/action/cli/main.d.ts.map +0 -1
  231. package/dist/action/cli/output/box.d.ts +0 -75
  232. package/dist/action/cli/output/box.d.ts.map +0 -1
  233. package/dist/action/cli/output/formatters.d.ts +0 -90
  234. package/dist/action/cli/output/formatters.d.ts.map +0 -1
  235. package/dist/action/cli/output/formatters.test.d.ts +0 -2
  236. package/dist/action/cli/output/formatters.test.d.ts.map +0 -1
  237. package/dist/action/cli/output/icons.d.ts +0 -11
  238. package/dist/action/cli/output/icons.d.ts.map +0 -1
  239. package/dist/action/cli/output/index.d.ts +0 -10
  240. package/dist/action/cli/output/index.d.ts.map +0 -1
  241. package/dist/action/cli/output/ink-runner.d.ts +0 -9
  242. package/dist/action/cli/output/ink-runner.d.ts.map +0 -1
  243. package/dist/action/cli/output/jsonl.d.ts +0 -43
  244. package/dist/action/cli/output/jsonl.d.ts.map +0 -1
  245. package/dist/action/cli/output/jsonl.test.d.ts +0 -2
  246. package/dist/action/cli/output/jsonl.test.d.ts.map +0 -1
  247. package/dist/action/cli/output/reporter.d.ts +0 -108
  248. package/dist/action/cli/output/reporter.d.ts.map +0 -1
  249. package/dist/action/cli/output/tasks.d.ts +0 -89
  250. package/dist/action/cli/output/tasks.d.ts.map +0 -1
  251. package/dist/action/cli/output/tty.d.ts +0 -21
  252. package/dist/action/cli/output/tty.d.ts.map +0 -1
  253. package/dist/action/cli/output/tty.test.d.ts +0 -2
  254. package/dist/action/cli/output/tty.test.d.ts.map +0 -1
  255. package/dist/action/cli/output/verbosity.d.ts +0 -20
  256. package/dist/action/cli/output/verbosity.d.ts.map +0 -1
  257. package/dist/action/cli/output/verbosity.test.d.ts +0 -2
  258. package/dist/action/cli/output/verbosity.test.d.ts.map +0 -1
  259. package/dist/action/cli/terminal.d.ts +0 -19
  260. package/dist/action/cli/terminal.d.ts.map +0 -1
  261. package/dist/action/cli/terminal.test.d.ts +0 -2
  262. package/dist/action/cli/terminal.test.d.ts.map +0 -1
  263. package/dist/action/config/index.d.ts +0 -4
  264. package/dist/action/config/index.d.ts.map +0 -1
  265. package/dist/action/config/loader.d.ts +0 -27
  266. package/dist/action/config/loader.d.ts.map +0 -1
  267. package/dist/action/config/loader.test.d.ts +0 -2
  268. package/dist/action/config/loader.test.d.ts.map +0 -1
  269. package/dist/action/config/schema.d.ts +0 -318
  270. package/dist/action/config/schema.d.ts.map +0 -1
  271. package/dist/action/config/writer.d.ts +0 -11
  272. package/dist/action/config/writer.d.ts.map +0 -1
  273. package/dist/action/config/writer.test.d.ts +0 -2
  274. package/dist/action/config/writer.test.d.ts.map +0 -1
  275. package/dist/action/diff/classify.d.ts +0 -29
  276. package/dist/action/diff/classify.d.ts.map +0 -1
  277. package/dist/action/diff/classify.test.d.ts +0 -2
  278. package/dist/action/diff/classify.test.d.ts.map +0 -1
  279. package/dist/action/diff/coalesce.d.ts +0 -42
  280. package/dist/action/diff/coalesce.d.ts.map +0 -1
  281. package/dist/action/diff/coalesce.test.d.ts +0 -2
  282. package/dist/action/diff/coalesce.test.d.ts.map +0 -1
  283. package/dist/action/diff/context.d.ts +0 -30
  284. package/dist/action/diff/context.d.ts.map +0 -1
  285. package/dist/action/diff/context.test.d.ts +0 -2
  286. package/dist/action/diff/context.test.d.ts.map +0 -1
  287. package/dist/action/diff/index.d.ts +0 -5
  288. package/dist/action/diff/index.d.ts.map +0 -1
  289. package/dist/action/diff/parser.d.ts +0 -52
  290. package/dist/action/diff/parser.d.ts.map +0 -1
  291. package/dist/action/diff/parser.test.d.ts +0 -2
  292. package/dist/action/diff/parser.test.d.ts.map +0 -1
  293. package/dist/action/event/context.d.ts +0 -9
  294. package/dist/action/event/context.d.ts.map +0 -1
  295. package/dist/action/event/index.d.ts +0 -3
  296. package/dist/action/event/index.d.ts.map +0 -1
  297. package/dist/action/event/schedule-context.d.ts +0 -30
  298. package/dist/action/event/schedule-context.d.ts.map +0 -1
  299. package/dist/action/examples/examples.integration.test.d.ts +0 -2
  300. package/dist/action/examples/examples.integration.test.d.ts.map +0 -1
  301. package/dist/action/examples/index.d.ts +0 -50
  302. package/dist/action/examples/index.d.ts.map +0 -1
  303. package/dist/action/examples/index.test.d.ts +0 -2
  304. package/dist/action/examples/index.test.d.ts.map +0 -1
  305. package/dist/action/examples/setup.d.ts +0 -2
  306. package/dist/action/examples/setup.d.ts.map +0 -1
  307. package/dist/action/index.d.ts +0 -11
  308. package/dist/action/index.d.ts.map +0 -1
  309. package/dist/action/index.js +0 -38231
  310. package/dist/action/index.js.map +0 -1
  311. package/dist/action/licenses.txt +0 -992
  312. package/dist/action/main.d.ts +0 -2
  313. package/dist/action/main.d.ts.map +0 -1
  314. package/dist/action/main.js +0 -707
  315. package/dist/action/main.js.map +0 -1
  316. package/dist/action/output/dedup.d.ts +0 -153
  317. package/dist/action/output/dedup.d.ts.map +0 -1
  318. package/dist/action/output/dedup.test.d.ts +0 -2
  319. package/dist/action/output/dedup.test.d.ts.map +0 -1
  320. package/dist/action/output/github-checks.d.ts +0 -106
  321. package/dist/action/output/github-checks.d.ts.map +0 -1
  322. package/dist/action/output/github-checks.test.d.ts +0 -2
  323. package/dist/action/output/github-checks.test.d.ts.map +0 -1
  324. package/dist/action/output/github-issues.d.ts +0 -35
  325. package/dist/action/output/github-issues.d.ts.map +0 -1
  326. package/dist/action/output/index.d.ts +0 -6
  327. package/dist/action/output/index.d.ts.map +0 -1
  328. package/dist/action/output/issue-renderer.d.ts +0 -20
  329. package/dist/action/output/issue-renderer.d.ts.map +0 -1
  330. package/dist/action/output/renderer.d.ts +0 -4
  331. package/dist/action/output/renderer.d.ts.map +0 -1
  332. package/dist/action/output/renderer.test.d.ts +0 -2
  333. package/dist/action/output/renderer.test.d.ts.map +0 -1
  334. package/dist/action/output/stale.d.ts +0 -31
  335. package/dist/action/output/stale.d.ts.map +0 -1
  336. package/dist/action/output/stale.test.d.ts +0 -2
  337. package/dist/action/output/stale.test.d.ts.map +0 -1
  338. package/dist/action/output/types.d.ts +0 -31
  339. package/dist/action/output/types.d.ts.map +0 -1
  340. package/dist/action/package.json +0 -3
  341. package/dist/action/sdk/index.d.ts +0 -2
  342. package/dist/action/sdk/index.d.ts.map +0 -1
  343. package/dist/action/sdk/runner.d.ts +0 -202
  344. package/dist/action/sdk/runner.d.ts.map +0 -1
  345. package/dist/action/sdk/runner.test.d.ts +0 -2
  346. package/dist/action/sdk/runner.test.d.ts.map +0 -1
  347. package/dist/action/skills/index.d.ts +0 -5
  348. package/dist/action/skills/index.d.ts.map +0 -1
  349. package/dist/action/skills/loader.d.ts +0 -111
  350. package/dist/action/skills/loader.d.ts.map +0 -1
  351. package/dist/action/skills/loader.test.d.ts +0 -2
  352. package/dist/action/skills/loader.test.d.ts.map +0 -1
  353. package/dist/action/skills/remote.d.ts +0 -117
  354. package/dist/action/skills/remote.d.ts.map +0 -1
  355. package/dist/action/skills/remote.test.d.ts +0 -2
  356. package/dist/action/skills/remote.test.d.ts.map +0 -1
  357. package/dist/action/sourcemap-register.cjs +0 -1
  358. package/dist/action/triggers/matcher.d.ts +0 -30
  359. package/dist/action/triggers/matcher.d.ts.map +0 -1
  360. package/dist/action/triggers/matcher.test.d.ts +0 -2
  361. package/dist/action/triggers/matcher.test.d.ts.map +0 -1
  362. package/dist/action/types/index.d.ts +0 -269
  363. package/dist/action/types/index.d.ts.map +0 -1
  364. package/dist/action/utils/async.d.ts +0 -5
  365. package/dist/action/utils/async.d.ts.map +0 -1
  366. package/dist/action/utils/index.d.ts +0 -16
  367. package/dist/action/utils/index.d.ts.map +0 -1
  368. package/dist/action/utils/index.test.d.ts +0 -2
  369. package/dist/action/utils/index.test.d.ts.map +0 -1
  370. package/dist/action/utils/version.d.ts +0 -3
  371. package/dist/action/utils/version.d.ts.map +0 -1
  372. package/dist/cli/args.test.d.ts +0 -2
  373. package/dist/cli/args.test.d.ts.map +0 -1
  374. package/dist/cli/args.test.js +0 -392
  375. package/dist/cli/args.test.js.map +0 -1
  376. package/dist/cli/commands/init.test.d.ts +0 -2
  377. package/dist/cli/commands/init.test.d.ts.map +0 -1
  378. package/dist/cli/commands/init.test.js +0 -117
  379. package/dist/cli/commands/init.test.js.map +0 -1
  380. package/dist/cli/files.test.d.ts +0 -2
  381. package/dist/cli/files.test.d.ts.map +0 -1
  382. package/dist/cli/files.test.js +0 -117
  383. package/dist/cli/files.test.js.map +0 -1
  384. package/dist/cli/fix.test.d.ts +0 -2
  385. package/dist/cli/fix.test.d.ts.map +0 -1
  386. package/dist/cli/fix.test.js +0 -251
  387. package/dist/cli/fix.test.js.map +0 -1
  388. package/dist/cli/git.test.d.ts +0 -2
  389. package/dist/cli/git.test.d.ts.map +0 -1
  390. package/dist/cli/git.test.js +0 -96
  391. package/dist/cli/git.test.js.map +0 -1
  392. package/dist/cli/output/formatters.test.d.ts +0 -2
  393. package/dist/cli/output/formatters.test.d.ts.map +0 -1
  394. package/dist/cli/output/formatters.test.js +0 -152
  395. package/dist/cli/output/formatters.test.js.map +0 -1
  396. package/dist/cli/output/jsonl.test.d.ts +0 -2
  397. package/dist/cli/output/jsonl.test.d.ts.map +0 -1
  398. package/dist/cli/output/jsonl.test.js +0 -284
  399. package/dist/cli/output/jsonl.test.js.map +0 -1
  400. package/dist/cli/output/tty.test.d.ts +0 -2
  401. package/dist/cli/output/tty.test.d.ts.map +0 -1
  402. package/dist/cli/output/tty.test.js +0 -105
  403. package/dist/cli/output/tty.test.js.map +0 -1
  404. package/dist/cli/output/verbosity.test.d.ts +0 -2
  405. package/dist/cli/output/verbosity.test.d.ts.map +0 -1
  406. package/dist/cli/output/verbosity.test.js +0 -35
  407. package/dist/cli/output/verbosity.test.js.map +0 -1
  408. package/dist/cli/terminal.test.d.ts +0 -2
  409. package/dist/cli/terminal.test.d.ts.map +0 -1
  410. package/dist/cli/terminal.test.js +0 -123
  411. package/dist/cli/terminal.test.js.map +0 -1
  412. package/dist/config/loader.test.d.ts +0 -2
  413. package/dist/config/loader.test.d.ts.map +0 -1
  414. package/dist/config/loader.test.js +0 -263
  415. package/dist/config/loader.test.js.map +0 -1
  416. package/dist/config/writer.test.d.ts +0 -2
  417. package/dist/config/writer.test.d.ts.map +0 -1
  418. package/dist/config/writer.test.js +0 -98
  419. package/dist/config/writer.test.js.map +0 -1
  420. package/dist/diff/classify.test.d.ts +0 -2
  421. package/dist/diff/classify.test.d.ts.map +0 -1
  422. package/dist/diff/classify.test.js +0 -140
  423. package/dist/diff/classify.test.js.map +0 -1
  424. package/dist/diff/coalesce.test.d.ts +0 -2
  425. package/dist/diff/coalesce.test.d.ts.map +0 -1
  426. package/dist/diff/coalesce.test.js +0 -159
  427. package/dist/diff/coalesce.test.js.map +0 -1
  428. package/dist/diff/context.test.d.ts +0 -2
  429. package/dist/diff/context.test.d.ts.map +0 -1
  430. package/dist/diff/context.test.js +0 -190
  431. package/dist/diff/context.test.js.map +0 -1
  432. package/dist/diff/parser.test.d.ts +0 -2
  433. package/dist/diff/parser.test.d.ts.map +0 -1
  434. package/dist/diff/parser.test.js +0 -178
  435. package/dist/diff/parser.test.js.map +0 -1
  436. package/dist/examples/examples.integration.test.d.ts +0 -2
  437. package/dist/examples/examples.integration.test.d.ts.map +0 -1
  438. package/dist/examples/examples.integration.test.js +0 -55
  439. package/dist/examples/examples.integration.test.js.map +0 -1
  440. package/dist/examples/index.test.d.ts +0 -2
  441. package/dist/examples/index.test.d.ts.map +0 -1
  442. package/dist/examples/index.test.js +0 -88
  443. package/dist/examples/index.test.js.map +0 -1
  444. package/dist/output/dedup.test.d.ts +0 -2
  445. package/dist/output/dedup.test.d.ts.map +0 -1
  446. package/dist/output/dedup.test.js +0 -357
  447. package/dist/output/dedup.test.js.map +0 -1
  448. package/dist/output/github-checks.test.d.ts +0 -2
  449. package/dist/output/github-checks.test.d.ts.map +0 -1
  450. package/dist/output/github-checks.test.js +0 -255
  451. package/dist/output/github-checks.test.js.map +0 -1
  452. package/dist/output/renderer.test.d.ts +0 -2
  453. package/dist/output/renderer.test.d.ts.map +0 -1
  454. package/dist/output/renderer.test.js +0 -645
  455. package/dist/output/renderer.test.js.map +0 -1
  456. package/dist/output/stale.test.d.ts +0 -2
  457. package/dist/output/stale.test.d.ts.map +0 -1
  458. package/dist/output/stale.test.js +0 -330
  459. package/dist/output/stale.test.js.map +0 -1
  460. package/dist/sdk/runner.test.d.ts +0 -2
  461. package/dist/sdk/runner.test.d.ts.map +0 -1
  462. package/dist/sdk/runner.test.js +0 -677
  463. package/dist/sdk/runner.test.js.map +0 -1
  464. package/dist/skills/loader.test.d.ts +0 -2
  465. package/dist/skills/loader.test.d.ts.map +0 -1
  466. package/dist/skills/loader.test.js +0 -241
  467. package/dist/skills/loader.test.js.map +0 -1
  468. package/dist/skills/remote.test.d.ts +0 -2
  469. package/dist/skills/remote.test.d.ts.map +0 -1
  470. package/dist/skills/remote.test.js +0 -582
  471. package/dist/skills/remote.test.js.map +0 -1
  472. package/dist/triggers/matcher.test.d.ts +0 -2
  473. package/dist/triggers/matcher.test.d.ts.map +0 -1
  474. package/dist/triggers/matcher.test.js +0 -234
  475. package/dist/triggers/matcher.test.js.map +0 -1
  476. package/dist/utils/index.test.d.ts +0 -2
  477. package/dist/utils/index.test.d.ts.map +0 -1
  478. package/dist/utils/index.test.js +0 -68
  479. package/dist/utils/index.test.js.map +0 -1
  480. package/docs/astro.config.mjs +0 -43
  481. package/docs/package.json +0 -19
  482. package/docs/pnpm-lock.yaml +0 -4000
  483. package/docs/public/favicon.svg +0 -5
  484. package/docs/src/components/Code.astro +0 -141
  485. package/docs/src/components/PackageManagerTabs.astro +0 -183
  486. package/docs/src/components/Terminal.astro +0 -212
  487. package/docs/src/layouts/Base.astro +0 -380
  488. package/docs/src/pages/cli.astro +0 -167
  489. package/docs/src/pages/config.astro +0 -395
  490. package/docs/src/pages/guide.astro +0 -450
  491. package/docs/src/pages/index.astro +0 -490
  492. package/docs/src/styles/global.css +0 -551
  493. package/docs/src/utils/version.ts +0 -6
  494. package/docs/tsconfig.json +0 -3
  495. package/docs/vercel.json +0 -5
  496. package/eslint.config.js +0 -33
  497. package/src/action/index.ts +0 -1
  498. package/src/action/main.ts +0 -868
  499. package/src/cli/args.test.ts +0 -477
  500. package/src/cli/args.ts +0 -414
  501. package/src/cli/commands/add.ts +0 -447
  502. package/src/cli/commands/init.test.ts +0 -137
  503. package/src/cli/commands/init.ts +0 -134
  504. package/src/cli/commands/setup-app/browser.ts +0 -38
  505. package/src/cli/commands/setup-app/credentials.ts +0 -45
  506. package/src/cli/commands/setup-app/manifest.ts +0 -48
  507. package/src/cli/commands/setup-app/server.ts +0 -172
  508. package/src/cli/commands/setup-app.ts +0 -156
  509. package/src/cli/commands/sync.ts +0 -114
  510. package/src/cli/context.ts +0 -131
  511. package/src/cli/files.test.ts +0 -155
  512. package/src/cli/files.ts +0 -89
  513. package/src/cli/fix.test.ts +0 -310
  514. package/src/cli/fix.ts +0 -387
  515. package/src/cli/git.test.ts +0 -119
  516. package/src/cli/git.ts +0 -318
  517. package/src/cli/index.ts +0 -14
  518. package/src/cli/main.ts +0 -672
  519. package/src/cli/output/box.ts +0 -235
  520. package/src/cli/output/formatters.test.ts +0 -187
  521. package/src/cli/output/formatters.ts +0 -269
  522. package/src/cli/output/icons.ts +0 -13
  523. package/src/cli/output/index.ts +0 -44
  524. package/src/cli/output/ink-runner.tsx +0 -337
  525. package/src/cli/output/jsonl.test.ts +0 -347
  526. package/src/cli/output/jsonl.ts +0 -126
  527. package/src/cli/output/reporter.ts +0 -434
  528. package/src/cli/output/tasks.ts +0 -374
  529. package/src/cli/output/tty.test.ts +0 -117
  530. package/src/cli/output/tty.ts +0 -60
  531. package/src/cli/output/verbosity.test.ts +0 -40
  532. package/src/cli/output/verbosity.ts +0 -31
  533. package/src/cli/terminal.test.ts +0 -148
  534. package/src/cli/terminal.ts +0 -301
  535. package/src/config/index.ts +0 -3
  536. package/src/config/loader.test.ts +0 -313
  537. package/src/config/loader.ts +0 -103
  538. package/src/config/schema.ts +0 -168
  539. package/src/config/writer.test.ts +0 -119
  540. package/src/config/writer.ts +0 -84
  541. package/src/diff/classify.test.ts +0 -162
  542. package/src/diff/classify.ts +0 -92
  543. package/src/diff/coalesce.test.ts +0 -208
  544. package/src/diff/coalesce.ts +0 -133
  545. package/src/diff/context.test.ts +0 -226
  546. package/src/diff/context.ts +0 -201
  547. package/src/diff/index.ts +0 -4
  548. package/src/diff/parser.test.ts +0 -212
  549. package/src/diff/parser.ts +0 -149
  550. package/src/event/context.ts +0 -132
  551. package/src/event/index.ts +0 -2
  552. package/src/event/schedule-context.ts +0 -101
  553. package/src/examples/examples.integration.test.ts +0 -66
  554. package/src/examples/index.test.ts +0 -101
  555. package/src/examples/index.ts +0 -122
  556. package/src/examples/setup.ts +0 -25
  557. package/src/index.ts +0 -115
  558. package/src/output/dedup.test.ts +0 -419
  559. package/src/output/dedup.ts +0 -607
  560. package/src/output/github-checks.test.ts +0 -300
  561. package/src/output/github-checks.ts +0 -476
  562. package/src/output/github-issues.ts +0 -329
  563. package/src/output/index.ts +0 -5
  564. package/src/output/issue-renderer.ts +0 -197
  565. package/src/output/renderer.test.ts +0 -727
  566. package/src/output/renderer.ts +0 -217
  567. package/src/output/stale.test.ts +0 -375
  568. package/src/output/stale.ts +0 -155
  569. package/src/output/types.ts +0 -34
  570. package/src/sdk/index.ts +0 -1
  571. package/src/sdk/runner.test.ts +0 -806
  572. package/src/sdk/runner.ts +0 -1232
  573. package/src/skills/index.ts +0 -36
  574. package/src/skills/loader.test.ts +0 -300
  575. package/src/skills/loader.ts +0 -423
  576. package/src/skills/remote.test.ts +0 -704
  577. package/src/skills/remote.ts +0 -604
  578. package/src/triggers/matcher.test.ts +0 -277
  579. package/src/triggers/matcher.ts +0 -152
  580. package/src/types/index.ts +0 -194
  581. package/src/utils/async.ts +0 -18
  582. package/src/utils/index.test.ts +0 -84
  583. package/src/utils/index.ts +0 -51
  584. package/src/utils/version.ts +0 -17
  585. package/tsconfig.json +0 -25
  586. package/vitest.config.ts +0 -8
  587. package/vitest.integration.config.ts +0 -11
  588. package/warden.toml +0 -19
@@ -1,226 +0,0 @@
1
- import { describe, it, expect, beforeEach, afterEach } from 'vitest';
2
- import { mkdirSync, writeFileSync, rmSync } from 'node:fs';
3
- import { join } from 'node:path';
4
- import { tmpdir } from 'node:os';
5
- import {
6
- expandHunkContext,
7
- expandDiffContext,
8
- formatHunkForAnalysis,
9
- } from './context.js';
10
- import type { DiffHunk, ParsedDiff } from './parser.js';
11
-
12
- describe('expandHunkContext', () => {
13
- let tempDir: string;
14
-
15
- beforeEach(() => {
16
- tempDir = join(tmpdir(), `warden-test-${Date.now()}-${Math.random().toString(36).slice(2)}`);
17
- mkdirSync(tempDir, { recursive: true });
18
- });
19
-
20
- afterEach(() => {
21
- rmSync(tempDir, { recursive: true, force: true });
22
- });
23
-
24
- it('expands hunk with surrounding file context', () => {
25
- const fileContent = Array.from({ length: 50 }, (_, i) => `line ${i + 1}`).join('\n');
26
- writeFileSync(join(tempDir, 'test.ts'), fileContent);
27
-
28
- const hunk: DiffHunk = {
29
- oldStart: 20,
30
- oldCount: 3,
31
- newStart: 20,
32
- newCount: 4,
33
- content: '@@ -20,3 +20,4 @@\n line 20\n+added\n line 21\n line 22',
34
- lines: [' line 20', '+added', ' line 21', ' line 22'],
35
- };
36
-
37
- const result = expandHunkContext(tempDir, 'test.ts', hunk, 5);
38
-
39
- expect(result.filename).toBe('test.ts');
40
- expect(result.hunk).toBe(hunk);
41
- expect(result.language).toBe('typescript');
42
- expect(result.contextBefore).toHaveLength(5); // lines 15-19
43
- expect(result.contextBefore[0]).toBe('line 15');
44
- expect(result.contextAfter).toHaveLength(5); // lines 24-28
45
- expect(result.contextAfter[0]).toBe('line 24');
46
- expect(result.contextStartLine).toBe(15);
47
- });
48
-
49
- it('handles missing file gracefully', () => {
50
- const hunk: DiffHunk = {
51
- oldStart: 1,
52
- oldCount: 2,
53
- newStart: 1,
54
- newCount: 2,
55
- content: '@@ -1,2 +1,2 @@',
56
- lines: [],
57
- };
58
-
59
- const result = expandHunkContext(tempDir, 'nonexistent.ts', hunk);
60
-
61
- expect(result.contextBefore).toEqual([]);
62
- expect(result.contextAfter).toEqual([]);
63
- });
64
-
65
- it('detects language from file extension', () => {
66
- writeFileSync(join(tempDir, 'test.py'), 'print("hello")');
67
-
68
- const hunk: DiffHunk = {
69
- oldStart: 1,
70
- oldCount: 1,
71
- newStart: 1,
72
- newCount: 1,
73
- content: '@@ -1 +1 @@',
74
- lines: [],
75
- };
76
-
77
- const result = expandHunkContext(tempDir, 'test.py', hunk);
78
- expect(result.language).toBe('python');
79
- });
80
-
81
- it('handles files at start with limited context before', () => {
82
- const fileContent = 'line 1\nline 2\nline 3\nline 4\nline 5';
83
- writeFileSync(join(tempDir, 'start.ts'), fileContent);
84
-
85
- const hunk: DiffHunk = {
86
- oldStart: 1,
87
- oldCount: 2,
88
- newStart: 1,
89
- newCount: 3,
90
- content: '@@ -1,2 +1,3 @@',
91
- lines: [],
92
- };
93
-
94
- const result = expandHunkContext(tempDir, 'start.ts', hunk, 10);
95
- expect(result.contextBefore).toEqual([]);
96
- expect(result.contextStartLine).toBe(1);
97
- });
98
- });
99
-
100
- describe('expandDiffContext', () => {
101
- let tempDir: string;
102
-
103
- beforeEach(() => {
104
- tempDir = join(tmpdir(), `warden-test-${Date.now()}-${Math.random().toString(36).slice(2)}`);
105
- mkdirSync(tempDir, { recursive: true });
106
- });
107
-
108
- afterEach(() => {
109
- rmSync(tempDir, { recursive: true, force: true });
110
- });
111
-
112
- it('expands all hunks in a parsed diff', () => {
113
- const fileContent = Array.from({ length: 100 }, (_, i) => `line ${i + 1}`).join('\n');
114
- writeFileSync(join(tempDir, 'multi.ts'), fileContent);
115
-
116
- const diff: ParsedDiff = {
117
- filename: 'multi.ts',
118
- status: 'modified',
119
- hunks: [
120
- {
121
- oldStart: 10,
122
- oldCount: 2,
123
- newStart: 10,
124
- newCount: 3,
125
- content: '@@ -10,2 +10,3 @@',
126
- lines: [],
127
- },
128
- {
129
- oldStart: 50,
130
- oldCount: 2,
131
- newStart: 51,
132
- newCount: 3,
133
- content: '@@ -50,2 +51,3 @@',
134
- lines: [],
135
- },
136
- ],
137
- rawPatch: '',
138
- };
139
-
140
- const results = expandDiffContext(tempDir, diff, 3);
141
-
142
- expect(results).toHaveLength(2);
143
- expect(results[0]!.hunk.newStart).toBe(10);
144
- expect(results[1]!.hunk.newStart).toBe(51);
145
- });
146
- });
147
-
148
- describe('formatHunkForAnalysis', () => {
149
- it('formats hunk with all sections', () => {
150
- const hunkCtx = {
151
- filename: 'src/index.ts',
152
- hunk: {
153
- oldStart: 10,
154
- oldCount: 2,
155
- newStart: 10,
156
- newCount: 3,
157
- header: 'function example()',
158
- content: '@@ -10,2 +10,3 @@ function example()\n const x = 1;\n+const y = 2;\n return x;',
159
- lines: [' const x = 1;', '+const y = 2;', ' return x;'],
160
- },
161
- contextBefore: ['// before line 1', '// before line 2'],
162
- contextAfter: ['// after line 1'],
163
- contextStartLine: 8,
164
- language: 'typescript',
165
- };
166
-
167
- const output = formatHunkForAnalysis(hunkCtx);
168
-
169
- expect(output).toContain('## File: src/index.ts');
170
- expect(output).toContain('## Language: typescript');
171
- expect(output).toContain('## Hunk: lines 10-12');
172
- expect(output).toContain('## Scope: function example()');
173
- expect(output).toContain('### Context Before (lines 8-9)');
174
- expect(output).toContain('```typescript');
175
- expect(output).toContain('// before line 1');
176
- expect(output).toContain('### Changes');
177
- expect(output).toContain('```diff');
178
- expect(output).toContain('### Context After (lines 13-13)');
179
- });
180
-
181
- it('omits context sections when empty', () => {
182
- const hunkCtx = {
183
- filename: 'new.ts',
184
- hunk: {
185
- oldStart: 0,
186
- oldCount: 0,
187
- newStart: 1,
188
- newCount: 2,
189
- content: '@@ -0,0 +1,2 @@\n+line 1\n+line 2',
190
- lines: ['+line 1', '+line 2'],
191
- },
192
- contextBefore: [],
193
- contextAfter: [],
194
- contextStartLine: 1,
195
- language: 'typescript',
196
- };
197
-
198
- const output = formatHunkForAnalysis(hunkCtx);
199
-
200
- expect(output).not.toContain('### Context Before');
201
- expect(output).not.toContain('### Context After');
202
- expect(output).toContain('### Changes');
203
- });
204
-
205
- it('omits scope when no header', () => {
206
- const hunkCtx = {
207
- filename: 'test.ts',
208
- hunk: {
209
- oldStart: 1,
210
- oldCount: 1,
211
- newStart: 1,
212
- newCount: 1,
213
- content: '@@ -1 +1 @@',
214
- lines: [],
215
- },
216
- contextBefore: [],
217
- contextAfter: [],
218
- contextStartLine: 1,
219
- language: 'typescript',
220
- };
221
-
222
- const output = formatHunkForAnalysis(hunkCtx);
223
-
224
- expect(output).not.toContain('## Scope:');
225
- });
226
- });
@@ -1,201 +0,0 @@
1
- import { readFileSync, existsSync } from 'node:fs';
2
- import { join } from 'node:path';
3
- import type { DiffHunk, ParsedDiff } from './parser.js';
4
- import { getExpandedLineRange } from './parser.js';
5
-
6
- /** Cache for file contents to avoid repeated reads */
7
- const fileCache = new Map<string, string[] | null>();
8
-
9
- /** Clear the file cache (useful for testing or long-running processes) */
10
- export function clearFileCache(): void {
11
- fileCache.clear();
12
- }
13
-
14
- /** Get cached file lines or read and cache them */
15
- function getCachedFileLines(filePath: string): string[] | null {
16
- if (fileCache.has(filePath)) {
17
- return fileCache.get(filePath) ?? null;
18
- }
19
-
20
- if (!existsSync(filePath)) {
21
- fileCache.set(filePath, null);
22
- return null;
23
- }
24
-
25
- try {
26
- const content = readFileSync(filePath, 'utf-8');
27
- const lines = content.split('\n');
28
- fileCache.set(filePath, lines);
29
- return lines;
30
- } catch {
31
- // Binary file or read error
32
- fileCache.set(filePath, null);
33
- return null;
34
- }
35
- }
36
-
37
- export interface HunkWithContext {
38
- /** File path */
39
- filename: string;
40
- /** The hunk being analyzed */
41
- hunk: DiffHunk;
42
- /** Lines before the hunk (from actual file) */
43
- contextBefore: string[];
44
- /** Lines after the hunk (from actual file) */
45
- contextAfter: string[];
46
- /** Start line of contextBefore */
47
- contextStartLine: number;
48
- /** Detected language from file extension */
49
- language: string;
50
- }
51
-
52
- /**
53
- * Detect language from filename.
54
- */
55
- function detectLanguage(filename: string): string {
56
- const ext = filename.split('.').pop()?.toLowerCase() ?? '';
57
- const languageMap: Record<string, string> = {
58
- ts: 'typescript',
59
- tsx: 'typescript',
60
- js: 'javascript',
61
- jsx: 'javascript',
62
- py: 'python',
63
- rb: 'ruby',
64
- go: 'go',
65
- rs: 'rust',
66
- java: 'java',
67
- kt: 'kotlin',
68
- cs: 'csharp',
69
- cpp: 'cpp',
70
- c: 'c',
71
- h: 'c',
72
- hpp: 'cpp',
73
- swift: 'swift',
74
- php: 'php',
75
- sh: 'bash',
76
- bash: 'bash',
77
- zsh: 'bash',
78
- yml: 'yaml',
79
- yaml: 'yaml',
80
- json: 'json',
81
- toml: 'toml',
82
- md: 'markdown',
83
- sql: 'sql',
84
- html: 'html',
85
- css: 'css',
86
- scss: 'scss',
87
- less: 'less',
88
- };
89
- return languageMap[ext] ?? ext;
90
- }
91
-
92
- /**
93
- * Read specific lines from a file using the cache.
94
- * Returns empty array if file doesn't exist or is binary.
95
- */
96
- function readFileLines(
97
- filePath: string,
98
- startLine: number,
99
- endLine: number
100
- ): string[] {
101
- const lines = getCachedFileLines(filePath);
102
- if (!lines) {
103
- return [];
104
- }
105
- // Lines are 1-indexed, arrays are 0-indexed
106
- return lines.slice(startLine - 1, endLine);
107
- }
108
-
109
- /**
110
- * Expand a hunk with surrounding context from the actual file.
111
- */
112
- export function expandHunkContext(
113
- repoPath: string,
114
- filename: string,
115
- hunk: DiffHunk,
116
- contextLines = 20
117
- ): HunkWithContext {
118
- const filePath = join(repoPath, filename);
119
- const expandedRange = getExpandedLineRange(hunk, contextLines);
120
-
121
- // Read context before the hunk
122
- const contextBefore = readFileLines(
123
- filePath,
124
- expandedRange.start,
125
- hunk.newStart - 1
126
- );
127
-
128
- // Read context after the hunk
129
- const contextAfter = readFileLines(
130
- filePath,
131
- hunk.newStart + hunk.newCount,
132
- expandedRange.end
133
- );
134
-
135
- return {
136
- filename,
137
- hunk,
138
- contextBefore,
139
- contextAfter,
140
- contextStartLine: expandedRange.start,
141
- language: detectLanguage(filename),
142
- };
143
- }
144
-
145
- /**
146
- * Expand all hunks in a parsed diff with context.
147
- */
148
- export function expandDiffContext(
149
- repoPath: string,
150
- diff: ParsedDiff,
151
- contextLines = 20
152
- ): HunkWithContext[] {
153
- return diff.hunks.map((hunk) =>
154
- expandHunkContext(repoPath, diff.filename, hunk, contextLines)
155
- );
156
- }
157
-
158
- /**
159
- * Format a hunk with context for LLM analysis.
160
- */
161
- export function formatHunkForAnalysis(hunkCtx: HunkWithContext): string {
162
- const lines: string[] = [];
163
-
164
- lines.push(`## File: ${hunkCtx.filename}`);
165
- lines.push(`## Language: ${hunkCtx.language}`);
166
- lines.push(`## Hunk: lines ${hunkCtx.hunk.newStart}-${hunkCtx.hunk.newStart + hunkCtx.hunk.newCount - 1}`);
167
-
168
- if (hunkCtx.hunk.header) {
169
- lines.push(`## Scope: ${hunkCtx.hunk.header}`);
170
- }
171
-
172
- lines.push('');
173
-
174
- // Context before
175
- if (hunkCtx.contextBefore.length > 0) {
176
- lines.push(`### Context Before (lines ${hunkCtx.contextStartLine}-${hunkCtx.hunk.newStart - 1})`);
177
- lines.push('```' + hunkCtx.language);
178
- lines.push(hunkCtx.contextBefore.join('\n'));
179
- lines.push('```');
180
- lines.push('');
181
- }
182
-
183
- // The actual changes
184
- lines.push(`### Changes`);
185
- lines.push('```diff');
186
- lines.push(hunkCtx.hunk.content);
187
- lines.push('```');
188
- lines.push('');
189
-
190
- // Context after
191
- if (hunkCtx.contextAfter.length > 0) {
192
- const afterStart = hunkCtx.hunk.newStart + hunkCtx.hunk.newCount;
193
- const afterEnd = afterStart + hunkCtx.contextAfter.length - 1;
194
- lines.push(`### Context After (lines ${afterStart}-${afterEnd})`);
195
- lines.push('```' + hunkCtx.language);
196
- lines.push(hunkCtx.contextAfter.join('\n'));
197
- lines.push('```');
198
- }
199
-
200
- return lines.join('\n');
201
- }
package/src/diff/index.ts DELETED
@@ -1,4 +0,0 @@
1
- export * from './parser.js';
2
- export * from './context.js';
3
- export * from './classify.js';
4
- export * from './coalesce.js';
@@ -1,212 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import {
3
- parsePatch,
4
- parseFileDiff,
5
- getHunkLineRange,
6
- getExpandedLineRange,
7
- type DiffHunk,
8
- } from './parser.js';
9
-
10
- describe('parsePatch', () => {
11
- it('parses a simple hunk', () => {
12
- const patch = `@@ -1,3 +1,4 @@
13
- line 1
14
- +added line
15
- line 2
16
- line 3`;
17
-
18
- const hunks = parsePatch(patch);
19
- expect(hunks).toHaveLength(1);
20
- const hunk = hunks[0]!;
21
- expect(hunk.oldStart).toBe(1);
22
- expect(hunk.oldCount).toBe(3);
23
- expect(hunk.newStart).toBe(1);
24
- expect(hunk.newCount).toBe(4);
25
- expect(hunk.lines).toEqual([' line 1', '+added line', ' line 2', ' line 3']);
26
- });
27
-
28
- it('parses multiple hunks', () => {
29
- const patch = `@@ -1,3 +1,4 @@
30
- line 1
31
- +added line
32
- line 2
33
- @@ -10,2 +11,3 @@
34
- line 10
35
- +another added
36
- line 11`;
37
-
38
- const hunks = parsePatch(patch);
39
- expect(hunks).toHaveLength(2);
40
- expect(hunks[0]!.newStart).toBe(1);
41
- expect(hunks[1]!.newStart).toBe(11);
42
- });
43
-
44
- it('parses hunk with function header', () => {
45
- const patch = `@@ -5,3 +5,4 @@ function example()
46
- const x = 1;
47
- +const y = 2;
48
- return x;`;
49
-
50
- const hunks = parsePatch(patch);
51
- expect(hunks).toHaveLength(1);
52
- expect(hunks[0]!.header).toBe('function example()');
53
- });
54
-
55
- it('handles hunk without count (single line)', () => {
56
- const patch = `@@ -1 +1,2 @@
57
- existing
58
- +added`;
59
-
60
- const hunks = parsePatch(patch);
61
- expect(hunks).toHaveLength(1);
62
- const hunk = hunks[0]!;
63
- expect(hunk.oldCount).toBe(1);
64
- expect(hunk.newCount).toBe(2);
65
- });
66
-
67
- it('skips diff metadata lines', () => {
68
- const patch = `diff --git a/file.ts b/file.ts
69
- index abc123..def456 100644
70
- --- a/file.ts
71
- +++ b/file.ts
72
- @@ -1,2 +1,3 @@
73
- line 1
74
- +added
75
- line 2`;
76
-
77
- const hunks = parsePatch(patch);
78
- expect(hunks).toHaveLength(1);
79
- const hunk = hunks[0]!;
80
- expect(hunk.lines).toEqual([' line 1', '+added', ' line 2']);
81
- expect(hunk.content).not.toContain('diff --git');
82
- expect(hunk.content).not.toContain('index ');
83
- });
84
-
85
- it('handles "No newline at end of file" marker', () => {
86
- const patch = `@@ -1,2 +1,2 @@
87
- line 1
88
- -old line
89
- +new line
90
- \`;
91
-
92
- const hunks = parsePatch(patch);
93
- expect(hunks).toHaveLength(1);
94
- expect(hunks[0]!.lines).not.toContain('\');
95
- });
96
-
97
- it('returns empty array for empty patch', () => {
98
- expect(parsePatch('')).toEqual([]);
99
- });
100
-
101
- it('returns empty array for patch with only metadata', () => {
102
- const patch = `diff --git a/file.ts b/file.ts
103
- index abc123..def456 100644
104
- --- a/file.ts
105
- +++ b/file.ts`;
106
-
107
- expect(parsePatch(patch)).toEqual([]);
108
- });
109
- });
110
-
111
- describe('parseFileDiff', () => {
112
- it('creates parsed diff with correct structure', () => {
113
- const patch = `@@ -1,2 +1,3 @@
114
- line 1
115
- +added
116
- line 2`;
117
-
118
- const diff = parseFileDiff('src/index.ts', patch);
119
- expect(diff.filename).toBe('src/index.ts');
120
- expect(diff.status).toBe('modified');
121
- expect(diff.hunks).toHaveLength(1);
122
- expect(diff.rawPatch).toBe(patch);
123
- });
124
-
125
- it('accepts different status values', () => {
126
- const patch = `@@ -0,0 +1,2 @@
127
- +new file
128
- +content`;
129
-
130
- expect(parseFileDiff('new.ts', patch, 'added').status).toBe('added');
131
- expect(parseFileDiff('old.ts', patch, 'removed').status).toBe('removed');
132
- expect(parseFileDiff('moved.ts', patch, 'renamed').status).toBe('renamed');
133
- });
134
- });
135
-
136
- describe('getHunkLineRange', () => {
137
- it('returns correct range for hunk', () => {
138
- const hunk: DiffHunk = {
139
- oldStart: 1,
140
- oldCount: 3,
141
- newStart: 5,
142
- newCount: 10,
143
- content: '',
144
- lines: [],
145
- };
146
-
147
- const range = getHunkLineRange(hunk);
148
- expect(range.start).toBe(5);
149
- expect(range.end).toBe(14); // 5 + 10 - 1
150
- });
151
-
152
- it('handles single line hunk', () => {
153
- const hunk: DiffHunk = {
154
- oldStart: 1,
155
- oldCount: 1,
156
- newStart: 1,
157
- newCount: 1,
158
- content: '',
159
- lines: [],
160
- };
161
-
162
- const range = getHunkLineRange(hunk);
163
- expect(range.start).toBe(1);
164
- expect(range.end).toBe(1);
165
- });
166
- });
167
-
168
- describe('getExpandedLineRange', () => {
169
- it('expands range with default context', () => {
170
- const hunk: DiffHunk = {
171
- oldStart: 1,
172
- oldCount: 3,
173
- newStart: 50,
174
- newCount: 5,
175
- content: '',
176
- lines: [],
177
- };
178
-
179
- const range = getExpandedLineRange(hunk);
180
- expect(range.start).toBe(30); // 50 - 20
181
- expect(range.end).toBe(74); // 54 + 20
182
- });
183
-
184
- it('does not go below line 1', () => {
185
- const hunk: DiffHunk = {
186
- oldStart: 1,
187
- oldCount: 2,
188
- newStart: 5,
189
- newCount: 3,
190
- content: '',
191
- lines: [],
192
- };
193
-
194
- const range = getExpandedLineRange(hunk);
195
- expect(range.start).toBe(1); // Math.max(1, 5 - 20)
196
- });
197
-
198
- it('accepts custom context lines', () => {
199
- const hunk: DiffHunk = {
200
- oldStart: 1,
201
- oldCount: 2,
202
- newStart: 100,
203
- newCount: 5,
204
- content: '',
205
- lines: [],
206
- };
207
-
208
- const range = getExpandedLineRange(hunk, 50);
209
- expect(range.start).toBe(50); // 100 - 50
210
- expect(range.end).toBe(154); // 104 + 50
211
- });
212
- });