我在一个文件上运行git-diff,但是更改位于一个长行的末尾。

如果我使用光标键向右移动,它就失去了颜色编码——更糟糕的是,线条没有对齐——这使得跟踪变化变得更加困难。

有没有办法防止这个问题,或者简单地让行换行?

我通过mingw32运行Git 1.5.5。


当前回答

git diff输出的显示由您正在使用的分页器处理。

通常,在Linux下,使用较少。

您可以通过设置GIT_PAGER环境变量告诉git使用不同的分页器。如果您不介意分页(例如,您的终端允许您回滚),您可以尝试显式地将GIT_PAGER设置为空以停止使用分页器。在Linux下:

$ GIT_PAGER='' git diff

如果没有寻呼机,行就会自动换行。

如果你的终端不支持彩色输出,你也可以使用——no-color参数关闭它,或者在你的git配置文件的color部分中放入一个条目。

$ GIT_PAGER='' git diff --no-color

其他回答

要使用less作为分页器并永久换行,您可以简单地启用折叠-长行选项:

git config --global core.pager 'less -+S'

这样你就不必在使用更少的时候打字了。

干杯

不是一个完美的解决方案,但gitk和git-gui都可以显示这个信息, 还有滚动条。

列出当前/默认配置:

  $ git config --global core.pager  
    less -FXRS -x2

然后更新并去掉-S,比如:

  $ git config --global core.pager 'less -FXR -x2'

-S:使比屏幕宽度长的行被剪切而不是折叠。

从Git 1.5.3开始 (2007年9月)

无寻呼机选项已经可用。

git --no-pager diff

我如何防止git差异从使用寻呼机?

例子

从v2.1开始,wrap是默认的

Git v2.1发布说明

遇到麻烦时,我经常求助于DiffMerge。优秀的差异工具,具有inline diff高亮。此外,在最新版本中,他们还添加了一个水平模式。

不过,我还没能配置git来使用它。所以我必须先把文件的两个版本都弄出来。