summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--diff.c16
-rwxr-xr-xt/t3206-range-diff.sh2
2 files changed, 9 insertions, 9 deletions
diff --git a/diff.c b/diff.c
index 4ef6638928..4f430f44e6 100644
--- a/diff.c
+++ b/diff.c
@@ -656,12 +656,14 @@ static void emit_line_0(struct diff_options *o,
fputs(set_sign, file);
if (first && !nofirst)
fputc(first, file);
- if (set && set != set_sign) {
- if (set_sign)
- fputs(reset, file);
- fputs(set, file);
+ if (len) {
+ if (set && set != set_sign) {
+ if (set_sign)
+ fputs(reset, file);
+ fputs(set, file);
+ }
+ fwrite(line, len, 1, file);
}
- fwrite(line, len, 1, file);
fputs(reset, file);
}
if (has_trailing_carriage_return)
@@ -1207,9 +1209,7 @@ static void emit_line_ws_markup(struct diff_options *o,
if (!ws && !set_sign)
emit_line_0(o, set, NULL, 0, reset, sign, line, len);
else if (!ws) {
- /* Emit just the prefix, then the rest. */
- emit_line_0(o, set_sign, NULL, !!set_sign, reset, sign, "", 0);
- emit_line_0(o, set, NULL, 0, reset, 0, line, len);
+ emit_line_0(o, set_sign, set, !!set_sign, reset, sign, line, len);
} else if (blank_at_eof)
/* Blank line at EOF - paint '+' as well */
emit_line_0(o, ws, NULL, 0, reset, sign, line, len);
diff --git a/t/t3206-range-diff.sh b/t/t3206-range-diff.sh
index 31f6458f96..7dc7c80a1d 100755
--- a/t/t3206-range-diff.sh
+++ b/t/t3206-range-diff.sh
@@ -151,7 +151,7 @@ test_expect_success 'dual-coloring' '
: s/4/A/<RESET>
: <RESET>
: <REVERSE><GREEN>+<RESET><BOLD> Also a silly comment here!<RESET>
- : <REVERSE><GREEN>+<RESET><BOLD><RESET>
+ : <REVERSE><GREEN>+<RESET>
: diff --git a/file b/file<RESET>
: <RED> --- a/file<RESET>
: <GREEN> +++ b/file<RESET>