|
|
|
[PATCH] Fix 'No newline...' annotation in rewrite diffs. | |
| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] |
|
From 01730a741cc5fd7d0a5d8bd0d3df80d12c81fe48 Mon Sep 17 00:00:00 2001 From: Adam Butcher <dev.lists@xxxxxxxxxxxxxxx> Date: Wed, 1 Aug 2012 22:25:09 +0100 Subject: [PATCH] Fix 'No newline...' annotation in rewrite diffs. When operating in --break-rewrites (-B) mode on a file with no newline terminator (and assuming --break-rewrites determines that the diff _is_ a rewrite), git diff previously concatenated the indicator comment '\ No newline at end of file' directly to the terminating line rather than on a line of its own. The resulting diff is broken; claiming that the last line actually contains the indicator text. Without -B there is no problem with the same files. This patch fixes the former case by inserting a newline into the output prior to emitting the indicator comment. Potential issue: Currently this emits an ASCII 10 newline character only. I'm not sure whether this will be okay on all platforms; it seems to work fine on Windows and GNU at least. A couple of tests have been added to the rewrite suite to confirm that the indicator comment is generated on its own line in both plain diff and rewrite mode. The latter test fails if the functional part of this patch (i.e. diff.c) is reverted. --- diff.c | 1 + t/t4022-diff-rewrite.sh | 27 +++++++++++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/diff.c b/diff.c index 95706a5..77d4e84 100644 --- a/diff.c +++ b/diff.c@@ -574,6 +574,7 @@ static void emit_rewrite_lines(struct emit_callback *ecb,
if (!endp) {
const char *plain = diff_get_color(ecb->color_diff,
DIFF_PLAIN);
+ putc('\n', ecb->opt->file);
emit_line_0(ecb->opt, plain, reset, '\\',
nneof, strlen(nneof));
}
diff --git a/t/t4022-diff-rewrite.sh b/t/t4022-diff-rewrite.sh
index c00a94b..c85154d 100755
--- a/t/t4022-diff-rewrite.sh
+++ b/t/t4022-diff-rewrite.sh
@@ -66,5 +66,32 @@ test_expect_success 'suppress deletion diff with -B
-D' '
grep -v "Linus Torvalds" actual ' +# create a file containing numbers with no newline at +# the end and modify it such that the starting 10 lines +# are unchanged, the next 101 are rewritten and the last +# line differs only in that in is terminated by a newline. +seq 1 10 > seq +seq 100 +1 200 >> seq +printf 201 >> seq +(git add seq; git commit seq -m seq) >/dev/null +seq 1 10 > seq +seq 300 -1 200 >> seq ++test_expect_success 'no newline at eof is on its own line without -B' '
+ + (git diff seq; true) > res && + grep "^\\\\ No newline at end of file$" res && + grep -v "^.\\+\\\\ No newline at end of file" res && + grep -v "\\\\ No newline at end of file.\\+$" res +' + +test_expect_success 'no newline at eof is on its own line with -B' ' + + (git diff -B seq; true) > res && + grep "^\\\\ No newline at end of file$" res && + grep -v "^.\\+\\\\ No newline at end of file" res && + grep -v "\\\\ No newline at end of file.\\+$" res +' + test_done -- 1.7.11.msysgit.0 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html
[Newbies FAQ] [Linux Kernel Development] [Free Online Dating] [Gcc Help] [IETF Annouce] [DCCP] [Netdev] [Networking] [Security] [V4L] [Bugtraq] [Free Online Dating] [Photo] [Yosemite] [MIPS Linux] [ARM Linux] [Linux Security] [Linux RAID] [Linux SCSI] [Fedora Users] [Linux Resources]