Commit 7d5fb6c
fix: handle file mode changes (old mode/new mode) in diff parsing (#41)
* fix: handle file mode changes (old mode/new mode) in diff parsing
Files with `old mode`/`new mode` extended headers were not parsed
correctly, causing two bugs:
1. `new mode` lines were not recognized as extended headers. The
ExtendedHeader constants included `Old: 'old'` which matches
`old mode ...`, but only had `NewFile: 'new file'` for new-prefixed
headers. Since `'new mode ...'` does not start with `'new file'`,
`parseExtendedHeader` returned null, breaking the extended header
loop prematurely.
2. When `parseFileChange` returned undefined (due to unrecognized
headers and no matching return conditions), `parseFileChanges`
used `break` instead of `continue`, causing ALL subsequent files
in the diff to be silently dropped.
Fixes:
- Add `NewMode: 'new mode'` to ExtendedHeader constants
- Handle mode-only changes (no --- /+++ markers, no chunks) by
falling back to the comparison line path
- Change `parseFileChanges` to skip unparseable entries instead of
aborting the entire parse
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
* feat: add changed mode data
* remove console.log
---------
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
Co-authored-by: YeonJuan <yeonjuan93@naver.com>1 parent 9740e08 commit 7d5fb6c
File tree
22 files changed
+283
-12
lines changed- .yarn
- src
- __fixtures__
- __tests__
- __snapshots__
22 files changed
+283
-12
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
Binary file not shown.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
1177 | 1177 | | |
1178 | 1178 | | |
1179 | 1179 | | |
| 1180 | + | |
| 1181 | + | |
1180 | 1182 | | |
1181 | 1183 | | |
1182 | 1184 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
410 | 410 | | |
411 | 411 | | |
412 | 412 | | |
| 413 | + | |
| 414 | + | |
413 | 415 | | |
414 | 416 | | |
415 | 417 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
| 34 | + | |
| 35 | + | |
34 | 36 | | |
35 | 37 | | |
36 | 38 | | |
| |||
112 | 114 | | |
113 | 115 | | |
114 | 116 | | |
| 117 | + | |
| 118 | + | |
115 | 119 | | |
116 | 120 | | |
117 | 121 | | |
118 | 122 | | |
119 | 123 | | |
| 124 | + | |
| 125 | + | |
120 | 126 | | |
121 | 127 | | |
122 | 128 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
| 34 | + | |
| 35 | + | |
34 | 36 | | |
35 | 37 | | |
36 | 38 | | |
| |||
0 commit comments