diff options
author | Pat Thoyts <patthoyts@users.sourceforge.net> | 2009-03-16 10:24:40 +0000 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2009-03-23 21:52:57 +1100 |
commit | 681c3290e379e61f9dd762039f140296434d1d9f (patch) | |
tree | ea90fe43649a5660c9baa9f1bc07a5193abf8f65 | |
parent | 52b8ea934ecd24b52806188b53367aaa6185deb3 (diff) | |
download | git-681c3290e379e61f9dd762039f140296434d1d9f.tar.gz git-681c3290e379e61f9dd762039f140296434d1d9f.tar.xz |
gitk: Handle blobs containing a DOS end-of-file marker
If a patchset contains an EOF marker (Ctrl-Z) the blob diff terminates
at that point. This permits gitk to ignore the eof and continue to
display any subsequent blobs and also displays a sensible representation
of the eof char.
Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
Signed-off-by: Paul Mackerras <paulus@samba.org>
-rwxr-xr-x | gitk | 5 |
1 files changed, 3 insertions, 2 deletions
@@ -7216,7 +7216,7 @@ proc getblobdiffs {ids} { set diffnparents 0 set diffinhdr 0 set diffencoding [get_path_encoding {}] - fconfigure $bdf -blocking 0 -encoding binary + fconfigure $bdf -blocking 0 -encoding binary -eofchar {} set blobdifffd($ids) $bdf filerun $bdf [list getblobdiffline $bdf $diffids] } @@ -7367,7 +7367,8 @@ proc getblobdiffline {bdf ids} { $ctext insert end "$line\n" filesep } else { - set line [encoding convertfrom $diffencoding $line] + set line [string map {\x1A ^Z} \ + [encoding convertfrom $diffencoding $line]] # parse the prefix - one ' ', '-' or '+' for each parent set prefix [string range $line 0 [expr {$diffnparents - 1}]] set tag [expr {$diffnparents > 1? "m": "d"}] |