当我输入git diff时,我希望看到一个并排的diff,就像用diff -y一样,或者像在kdiff3这样的交互式diff工具中显示diff。如何做到这一点呢?
当前回答
你可以使用sdiff做一个并排的diff,如下所示:
$ git difftool -y -x sdiff HEAD^ | less
其中HEAD^是一个例子,你应该用任何你想要反对的东西来替换它。
我在这里找到了这个解决方案,还有一些其他的建议。然而,这一个答案是OP的问题简洁而清楚。
有关这些论点的解释,请参阅man git-difftool。
把注释记在板上,你可以通过编写以下可执行脚本创建一个方便的git sdiff命令:
#!/bin/sh
git difftool -y -x "sdiff -w $(tput cols)" "${@}" | less
保存为/usr/bin/git-sdiff并chmod +x它。然后你就可以这样做了:
$ git sdiff HEAD^
额外的小费
正如评论中所建议的,你可以使用icdiff来做sdiff对彩色输出所做的事情:
$ more /usr/bin/git-sdiff
#!/bin/sh
git difftool -y -x "icdiff --cols $(tput cols)" "${@}" | less --raw-control-chars
其他回答
export GIT_EXTERNAL_DIFF='meld $2 $5; echo >/dev/null'
然后简单的:
git diff
在这个帖子里有很多很好的答案。对于这个问题,我的解决方案是编写一个脚本。
将其命名为“git-scriptname”(并使其可执行并将其放在您的PATH中,就像任何脚本一样),您可以像正常的git命令一样通过运行调用它
$ git scriptname
实际的功能在最后一行。来源如下:
#!/usr/bin/env zsh
#
# Show a side-by-side diff of a particular file how it currently exists between:
# * the file system
# * in HEAD (latest committed changes)
function usage() {
cat <<-HERE
USAGE
$(basename $1) <file>
Show a side-by-side diff of a particular file between the current versions:
* on the file system (latest edited changes)
* in HEAD (latest committed changes)
HERE
}
if [[ $# = 0 ]]; then
usage $0
exit
fi
file=$1
diff -y =(git show HEAD:$file) $file | pygmentize -g | less -R
这可能是一个有点有限的解决方案,但在没有外部工具的情况下使用系统的diff命令完成工作:
diff -y <(git show from-rev:the/file/path) <(git show to-rev:the/file/path)
仅过滤更改行使用——suppress-common-lines(如果您的diff支持该选项)。 在这种情况下,没有颜色,只有通常的不同标记 可以调整列宽度-width=term-width;在Bash中可以获取宽度为$COLUMNS或tput cols。
为了更方便,这也可以被包装到一个helper git-script中,例如,这样使用:
git diffy the/file/path --from rev1 --to rev2
尽管Git有一个diff的内部实现,但是您可以设置一个外部工具。
有两种不同的方法来指定外部差异工具:
设置GIT_EXTERNAL_DIFF和GIT_DIFF_OPTS环境变量。 通过git config配置外部diff工具
Ymattw的答案也非常简洁,使用ydiff
参见:
https://git-scm.com/book/en/v2/Customizing-Git-Git-Configuration Git diff——救命 http://www.pixelbeat.org/programming/diffs/
在执行git diff时,git会检查上述环境变量的设置及其.gitconfig文件。
默认情况下,Git将以下七个参数传递给diff程序:
path old-file old-hex old-mode new-file new-hex new-mode
通常只需要old-file和new-file参数。当然,大多数diff工具只接受两个文件名作为参数。这意味着您需要编写一个小的包装器脚本,它接受Git提供给脚本的参数,并将它们传递给您选择的外部Git程序。
假设你把你的包装脚本放在~/scripts/my_diff.sh下面:
#!/bin/bash
# un-comment one diff tool you'd like to use
# side-by-side diff with custom options:
# /usr/bin/sdiff -w200 -l "$2" "$5"
# using kdiff3 as the side-by-side diff:
# /usr/bin/kdiff3 "$2" "$5"
# using Meld
/usr/bin/meld "$2" "$5"
# using VIM
# /usr/bin/vim -d "$2" "$5"
然后你需要使该脚本可执行:
chmod a+x ~/scripts/my_diff.sh
然后,您需要告诉Git如何以及在哪里找到您的自定义差异包装器脚本。 你有三个选择如何做到这一点:(我更喜欢编辑.gitconfig文件)
使用GIT_EXTERNAL_DIFF, GIT_DIFF_OPTS 例如,在你的.bashrc或.bash_profile文件中,你可以设置: GIT_EXTERNAL_DIFF = $ HOME /脚本/ my_diff.sh 出口GIT_EXTERNAL_DIFF 使用git配置 使用“git config”来定义你的包装器脚本可以在哪里找到: Git配置——global diff.external ~/scripts/my_diff.sh 编辑~/。gitconfig文件 您可以编辑~/。Gitconfig文件添加这些行: (diff) External = ~/scripts/my_diff.sh
注意:
与安装自定义diff工具类似,您还可以安装一个自定义合并工具,它可以是一个可视化的合并工具,以更好地帮助可视化合并。(参见progit.org页面)
参见:http://fredpalma.com/518/visual-diff-and-merge-tool/和https://git-scm.com/book/en/v2/Customizing-Git-Git-Configuration
你也可以试试git diff——word-diff。 它不是完全并排的,但不知何故更好,所以你可能更喜欢它而不是你实际并排的需要。
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别