Fix "git diff --stat" with long filenames

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



When we cut off the front of a filename to make it fit on the line, we add 
a "..." in front. However, the way the "git diff" code was written, we 
will never reset the prefix back to the empty string, so every single 
filename afterwards will have the "..." prefix, whether appropriate or 
not.

You can see this with "git diff v2.6.16.." on the current kernel tree, 
since there are filenames with long names that changed there:

 [ snip snip ]
 Documentation/filesystems/vfs.txt                  |  229 
 .../firmware_class/firmware_sample_driver.c        |    3 
 .../firmware_sample_firmware_class.c               |    1 
 ...Documentation/fujitsu/frv/kernel-ABI.txt           |  192 
 ...Documentation/hwmon/w83627hf                       |    4 
 [ snip snip ]

notice how the two Documentation/firmware** filenames caused the "..." to 
be added, but then the later filenames don't want it, and it also screws 
up the alignment of the line numbering afterwards.

Trivially fixed by moving the declaration (and initial setting) of the 
"prefix" variable into the for-loop where it is used.

Signed-off-by: Linus Torvalds <torvalds@xxxxxxxx>
---
diff --git a/diff.c b/diff.c
index c845c87..5315270 100644
--- a/diff.c
+++ b/diff.c
@@ -296,7 +296,6 @@ static const char minuses[]= "----------
 
 static void show_stats(struct diffstat_t* data)
 {
-	char *prefix = "";
 	int i, len, add, del, total, adds = 0, dels = 0;
 	int max, max_change = 0, max_len = 0;
 	int total_files = data->nr;
@@ -318,6 +317,7 @@ static void show_stats(struct diffstat_t
 	}
 
 	for (i = 0; i < data->nr; i++) {
+		char *prefix = "";
 		char *name = data->files[i]->name;
 		int added = data->files[i]->added;
 		int deleted = data->files[i]->deleted;
-
: 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

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]