Commit 000cfe3
feat: add file triage, dynamic context boundaries, and robust LLM parsing
Phase 1 improvements to the review pipeline, informed by competitive analysis
of Greptile, CodeRabbit, and Qodo Merge architectures:
- File triage (#29): Heuristic classifier skips lock files, generated files,
deletion-only, whitespace-only, and comment-only changes before expensive
LLM review. 45 unit tests.
- Dynamic context boundaries (#25): Context fetcher now searches upward for
enclosing function/class definitions instead of using fixed-window context.
Uses asymmetric padding (more before, less after) matching Qodo's approach.
6 unit tests.
- Robust LLM output parsing (#28): 5-strategy fallback chain for parsing LLM
responses — primary format, numbered lists, markdown bullets, file:line
format, and JSON extraction. Prevents silent comment loss when models deviate
from the expected format. 11 unit tests.
- Fix rust-embed v8 derive macro (Embed -> RustEmbed)
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>1 parent aa2f3c4 commit 000cfe3
File tree
7 files changed
+1169
-5
lines changed- src
- core
- parsing
- review
- server
7 files changed
+1169
-5
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
8 | 9 | | |
9 | 10 | | |
10 | 11 | | |
| |||
50 | 51 | | |
51 | 52 | | |
52 | 53 | | |
53 | | - | |
54 | | - | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
55 | 67 | | |
56 | 68 | | |
57 | 69 | | |
| |||
62 | 74 | | |
63 | 75 | | |
64 | 76 | | |
65 | | - | |
| 77 | + | |
66 | 78 | | |
67 | 79 | | |
68 | 80 | | |
| |||
330 | 342 | | |
331 | 343 | | |
332 | 344 | | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
333 | 367 | | |
334 | 368 | | |
335 | 369 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
282 | 282 | | |
283 | 283 | | |
284 | 284 | | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
285 | 300 | | |
286 | 301 | | |
287 | 302 | | |
| |||
851 | 866 | | |
852 | 867 | | |
853 | 868 | | |
| 869 | + | |
| 870 | + | |
| 871 | + | |
| 872 | + | |
| 873 | + | |
| 874 | + | |
| 875 | + | |
| 876 | + | |
| 877 | + | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
| 881 | + | |
| 882 | + | |
| 883 | + | |
| 884 | + | |
| 885 | + | |
| 886 | + | |
| 887 | + | |
| 888 | + | |
| 889 | + | |
| 890 | + | |
| 891 | + | |
| 892 | + | |
| 893 | + | |
| 894 | + | |
| 895 | + | |
| 896 | + | |
| 897 | + | |
| 898 | + | |
| 899 | + | |
| 900 | + | |
| 901 | + | |
| 902 | + | |
| 903 | + | |
| 904 | + | |
| 905 | + | |
| 906 | + | |
| 907 | + | |
| 908 | + | |
| 909 | + | |
| 910 | + | |
| 911 | + | |
| 912 | + | |
| 913 | + | |
854 | 914 | | |
855 | 915 | | |
856 | 916 | | |
| |||
0 commit comments