我在一个文件上运行git-diff,但是更改位于一个长行的末尾。
如果我使用光标键向右移动,它就失去了颜色编码——更糟糕的是,线条没有对齐——这使得跟踪变化变得更加困难。
有没有办法防止这个问题,或者简单地让行换行?
我通过mingw32运行Git 1.5.5。
我在一个文件上运行git-diff,但是更改位于一个长行的末尾。
如果我使用光标键向右移动,它就失去了颜色编码——更糟糕的是,线条没有对齐——这使得跟踪变化变得更加困难。
有没有办法防止这个问题,或者简单地让行换行?
我通过mingw32运行Git 1.5.5。
当前回答
完全归功于Josh Diehl对这个答案的评论,尽管如此,我还是觉得这应该是一个自己的答案,所以加上它:
处理在长行中看到差异的一种方法是使用面向单词的diff。这可以通过以下方式实现:
git diff --word-diff
在这种情况下,您将得到一个显著不同的diff输出,它将明确地显示一行中发生了哪些更改。
例如,不是得到这样的东西:
diff --git a/test-file.txt b/test-file.txt
index 19e6adf..eb6bb81 100644
--- a/test-file.txt
+++ b/test-file.txt
@@ -1 +1 @@
-this is a short line
+this is a slightly longer line
你可能会得到这样的东西:
diff --git a/test-file.txt b/test-file.txt
index 19e6adf..eb6bb81 100644
--- a/test-file.txt
+++ b/test-file.txt
@@ -1 +1 @@
this is a [-short-]{+slightly longer+} line
或者,用彩色代替这个:
你可能会得到这个:
现在,如果您正在比较一个非常长的行,您可能仍然对您最初描述的寻呼机情况有问题,并且在其他答案中已经解决了这个问题,显然令人满意。不过,希望这为您提供了一种新的工具,可以更容易地识别在线上发生了哪些更改。
其他回答
Mac OSX:除了某人45的“-S”而“less”是“running”之外,其他的答案都不适合我。要使换行持久,需要执行以下操作:
git config --global core.pager 'less -+$LESS -FRX'
完全归功于Josh Diehl对这个答案的评论,尽管如此,我还是觉得这应该是一个自己的答案,所以加上它:
处理在长行中看到差异的一种方法是使用面向单词的diff。这可以通过以下方式实现:
git diff --word-diff
在这种情况下,您将得到一个显著不同的diff输出,它将明确地显示一行中发生了哪些更改。
例如,不是得到这样的东西:
diff --git a/test-file.txt b/test-file.txt
index 19e6adf..eb6bb81 100644
--- a/test-file.txt
+++ b/test-file.txt
@@ -1 +1 @@
-this is a short line
+this is a slightly longer line
你可能会得到这样的东西:
diff --git a/test-file.txt b/test-file.txt
index 19e6adf..eb6bb81 100644
--- a/test-file.txt
+++ b/test-file.txt
@@ -1 +1 @@
this is a [-short-]{+slightly longer+} line
或者,用彩色代替这个:
你可能会得到这个:
现在,如果您正在比较一个非常长的行,您可能仍然对您最初描述的寻呼机情况有问题,并且在其他答案中已经解决了这个问题,显然令人满意。不过,希望这为您提供了一种新的工具,可以更容易地识别在线上发生了哪些更改。
要使用less作为分页器并永久换行,您可以简单地启用折叠-长行选项:
git config --global core.pager 'less -+S'
这样你就不必在使用更少的时候打字了。
干杯
当你使用“git diff”,它显示了几个页面(你看到“:”在页面的末尾),在这种情况下,你可以输入“-S”并按enter。(S应为大写)。它将切换折叠长行。
遇到麻烦时,我经常求助于DiffMerge。优秀的差异工具,具有inline diff高亮。此外,在最新版本中,他们还添加了一个水平模式。
不过,我还没能配置git来使用它。所以我必须先把文件的两个版本都弄出来。