为了说明问题:参见diff
本段中唯一的差异(从A macro that needs
空格差异开始(在某些地方插入/删除换行符);
- 运行时
git diff
,前面的段落以红色显示,后面的段落以红色显示,很难发现差异 - 运行时
git diff --word-diff
,后面的段落以灰色显示,不显示空白变化 - 运行时
git diff --word-diff-regex=.
它会显示空白更改(太棒了!)但是[编辑]它会逐个字符地进行差异,这通常是不可读的,因为它混合了来自不同单词的字母以最小化差异,例如:git show --word-diff-regex=. 4a720394bba39ce1e67d518b909cbb1c25f63d09
[- * patch compile-]r [-so `isM-]a[-inModule`-] [-is true when -d:isMainModuleIsAlwaysTr-]{+m+}u[-e-] [- T-]{+c+}h[-at'll give speedup-] be[-nefi-]t[-, and we don'-]t[- hav-]e{+r+} [-to p-]{+w+}a[-tch stdlib files-]{+y+}. ]#
我想要的是在运行时显示空白差异的选项--word-diff
(或--word-diff-regex),例如通过{+ +}
and [- -]
; 注意: for--word-diff=color
最好将这些显示给,例如,也可以通过{+ +}
and显示,[- -]
否则这些会消失。
注意:我在我的 gitconfig 中使用颜色。
注意:这无济于事,因为空格差异未显示在输出中git diff --word-diff=porcelain