Skip to content

Commit 148a417

Browse files
zeripathKN4CK3Rlunny
authored
Prevent off-by-one error on comments on newly appended lines (#18029) (#18035)
* Prevent off-by-one error on comments on newly appended lines (#18029) Backport #18029 There was a bug in CutDiffAroundLine whereby if a file without a terminal new line has a patch which appends lines to it and a comment is placed on one of those lines the comment diff will be a line out of place. This fixes CutDiffAroundLine to simply ignore the missing terminal newline - however, we should really improve this rendering to add a marker to say that there was a previously missing terminal newline. Fix #17875 Signed-off-by: Andrew Thornton <[email protected]> * Apply suggestions from code review Co-authored-by: KN4CK3R <[email protected]> Co-authored-by: KN4CK3R <[email protected]> Co-authored-by: Lunny Xiao <[email protected]>
1 parent 6081948 commit 148a417

File tree

2 files changed

+53
-0
lines changed

2 files changed

+53
-0
lines changed

modules/git/diff.go

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -218,6 +218,8 @@ func CutDiffAroundLine(originalDiff io.Reader, line int64, old bool, numbersOfLi
218218
} else {
219219
otherLine++
220220
}
221+
case '\\':
222+
// FIXME: handle `\ No newline at end of file`
221223
default:
222224
currentLine++
223225
otherLine++

modules/git/diff_test.go

Lines changed: 51 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,57 @@ index d8e4c92..19dc8ad 100644
4242
/
4343
`
4444

45+
var issue17875Diff = `diff --git a/Geschäftsordnung.md b/Geschäftsordnung.md
46+
index d46c152..a7d2d55 100644
47+
--- a/Geschäftsordnung.md
48+
+++ b/Geschäftsordnung.md
49+
@@ -1,5 +1,5 @@
50+
---
51+
-date: "23.01.2021"
52+
+date: "30.11.2021"
53+
...
54+
` + `
55+
# Geschäftsordnung
56+
@@ -16,4 +16,22 @@ Diese Geschäftsordnung regelt alle Prozesse des Vereins, solange diese nicht du
57+
` + `
58+
## § 3 Datenschutzverantwortlichkeit
59+
` + `
60+
-1. Der Verein bestellt eine datenschutzverantwortliche Person mit den Aufgaben nach Artikel 39 DSGVO.
61+
\ No newline at end of file
62+
+1. Der Verein bestellt eine datenschutzverantwortliche Person mit den Aufgaben nach Artikel 39 DSGVO.
63+
+
64+
+## §4 Umgang mit der SARS-Cov-2-Pandemie
65+
+
66+
+1. Der Vorstand hat die Befugnis, in Rücksprache mit den Vereinsmitgliedern, verschiedene Hygienemaßnahmen für Präsenzveranstaltungen zu beschließen.
67+
+
68+
+2. Die Einführung, Änderung und Abschaffung dieser Maßnahmen sind nur zum Zweck der Eindämmung der SARS-Cov-2-Pandemie zulässig.
69+
+
70+
+3. Die Einführung, Änderung und Abschaffung von Maßnahmen nach Abs. 2 bedarf einer wissenschaftlichen Grundlage.
71+
+
72+
+4. Die Maßnahmen nach Abs. 2 setzen sich aus den folgenden Bausteinen inklusive einer ihrer Ausprägungen zusammen.
73+
+
74+
+ 1. Maskenpflicht: Keine; Maskenpflicht, außer am Platz, oder wo Abstände nicht eingehalten werden können; Maskenpflicht, wenn Abstände nicht eingehalten werden können; Maskenpflicht
75+
+
76+
+ 2. Geimpft-, Genesen- oder Testnachweis: Kein Nachweis notwendig; Nachweis, dass Person geimpft, genesen oder tagesaktuell getestet ist (3G); Nachweis, dass Person geimpft oder genesen ist (2G); Nachweis, dass Person geimpft bzw. genesen und tagesaktuell getestet ist (2G+)
77+
+
78+
+ 3. Online-Veranstaltung: Keine, parallele Online-Veranstaltung, ausschließlich Online-Veranstaltung
79+
+
80+
+5. Bei Präsenzveranstungen gelten außerdem die Hygienevorschriften des Veranstaltungsorts. Bei Regelkollision greift die restriktivere Regel.
81+
\ No newline at end of file`
82+
83+
func TestCutDiffAroundLineIssue17875(t *testing.T) {
84+
result, err := CutDiffAroundLine(strings.NewReader(issue17875Diff), 23, false, 3)
85+
assert.NoError(t, err)
86+
expected := `diff --git a/Geschäftsordnung.md b/Geschäftsordnung.md
87+
--- a/Geschäftsordnung.md
88+
+++ b/Geschäftsordnung.md
89+
@@ -20,0 +21,3 @@
90+
+## §4 Umgang mit der SARS-Cov-2-Pandemie
91+
+
92+
+1. Der Vorstand hat die Befugnis, in Rücksprache mit den Vereinsmitgliedern, verschiedene Hygienemaßnahmen für Präsenzveranstaltungen zu beschließen.`
93+
assert.Equal(t, expected, result)
94+
}
95+
4596
func TestCutDiffAroundLine(t *testing.T) {
4697
result, err := CutDiffAroundLine(strings.NewReader(exampleDiff), 4, false, 3)
4798
assert.NoError(t, err)

0 commit comments

Comments
 (0)