Coloured Git diff to HTML
I enjoy using git diff --color-words
to clearly see the words that have开发者_开发技巧 changed in a file:
However I want to share that diff with someone without git or a colour terminal for that matter. So does anyone know of a tool or trick that can convert colour escaped terminal output into HTML?
wget "http://www.pixelbeat.org/scripts/ansi2html.sh" -O /tmp/ansi2html.sh
chmod +x /tmp/ansi2html.sh
git diff --color-words --no-index orig.txt edited.txt | \
/tmp/ansi2html.sh > 2beshared.html
What I really needed was an ANSI to HTML converter. And I found a very decent one on http://www.pixelbeat.org/.
NOTE: You might not see any coloration unless you include --color
or --color-words
, probably because piping causes git diff to exclude colors.
NOTE 2: You may need to install gnu sed and awk, especially if you're on a Mac. Do so with brew install gnu-sed gawk
. You may need to add them to your path manually, too, e.g. with ln -s /usr/local/Cellar/gnu-sed/4.2.2/bin/gsed /usr/local/bin/
.
download diff2html, extract it and convert diff to html with this command:
$ diff2html file1.txt file2.txt > diff-demo1.htm
There is more ... take a look at this question.
Or after gitting:
git diff --color-words --no-index orig.txt /tmp/edited.txt > myfile
download both ansifilter from this location. and use this command to convert myfile to html format
ansifilter -i myfile -H -o myfile2.html
so ... this is exactly what you want ;)
I just found aha in debian repositories; it's trivial:
git diff --color | aha > white.html # white background
git diff --color | aha --black > black.html # black background
git diff --color | aha --pink > pink.html # pink background
Its tiny download size (<20KB) got me curious, so I peeked at its source: it is a self-contained C file with only 4 includes: errno.h
, stdlib.h
, stdio.h
and string.h
, and depends on only libc. Beauty!
If you want to see clean diffs with line similarity matching, better word comparison, syntax highlight and more check out diff2html which is very customizable git diff to HTML presenter.
To use it on the command line you can check diff2html-cli which is a simple CLI written in Node.js.
So you can share your diffs with colleagues it integrates with diffy.org.
Check out a diff sample here.
Don't know any tool to do exactly what you want. But here's a piece of code I often use to output html formatted colored diff: simplediff
It's available in PHP and Python. The output tags the differences using <del>
and <ins>
tags so you can easily color them using CSS.
You may want to checkout the github project rmed, which provides a command line tool, that generates static shareable html diffs using vimdiff.
I have created a perl script to generate html table for the git diff. To use this script first you have to collect the diff by using git diff sha1s... > diff.file, then run diff2html.pl diff.file. Visit:
http://kernel-demystified.com/forum/index.php/topic,23.msg28.html#new
when I use git bash, if you use git show
you only need to copy and paste what is shown in the console and it copies the colours correctly.
I know this question is very old. However, if you're using PHP I've just shared a simple renderer that adds some style to the native git diff console output: https://github.com/nrctkno/git-diff-renderer .
精彩评论