我在一个文件上运行git-diff,但是更改位于一个长行的末尾。
如果我使用光标键向右移动,它就失去了颜色编码——更糟糕的是,线条没有对齐——这使得跟踪变化变得更加困难。
有没有办法防止这个问题,或者简单地让行换行?
我通过mingw32运行Git 1.5.5。
我在一个文件上运行git-diff,但是更改位于一个长行的末尾。
如果我使用光标键向右移动,它就失去了颜色编码——更糟糕的是,线条没有对齐——这使得跟踪变化变得更加困难。
有没有办法防止这个问题,或者简单地让行换行?
我通过mingw32运行Git 1.5.5。
当前回答
八年后,我从https://superuser.com/questions/777617/line-wrapping-less-in-os-x-specifically-for-use-with-git-diff:上找到了一个更好的答案
git config core.pager `fold -w 80 | less`
现在你通过fold管道git差异,首先,然后less: wrapped, less page-height是正确的,保持语法高亮显示。
其他回答
直到现在还没有人指出这一点。它很容易记住,不需要在git配置中做额外的配置
git diff --color | less -R
或者,如果您使用less作为默认的分页器,只需键入-S,同时查看差异,以重新启用less的包装。
要使用less作为分页器并永久换行,您可以简单地启用折叠-长行选项:
git config --global core.pager 'less -+S'
这样你就不必在使用更少的时候打字了。
干杯
遇到麻烦时,我经常求助于DiffMerge。优秀的差异工具,具有inline diff高亮。此外,在最新版本中,他们还添加了一个水平模式。
不过,我还没能配置git来使用它。所以我必须先把文件的两个版本都弄出来。
Mac OSX:除了某人45的“-S”而“less”是“running”之外,其他的答案都不适合我。要使换行持久,需要执行以下操作:
git config --global core.pager 'less -+$LESS -FRX'