除了编写别名或脚本之外,是否还有更短的命令来获取特定提交的差异?

git diff 15dc8^..15dc8

如果你只给一个提交id git diff 15dc8,它就会对HEAD进行不同的提交。


当前回答

git diff 15dc8 15dce~1

~1表示“父母”,~2表示“祖父母”,等等。

其他回答

git diff 15dc8 15dce~1

~1表示“父母”,~2表示“祖父母”,等等。

这使用别名,所以它不能准确地回答你的问题,但我发现这些对你想做的事情很有用……

alias gitdiff-1="git log --reverse|grep commit|cut -d ' ' -f2|tail -n 2|head -n 2|xargs echo|sed -e 's/\s/../'|xargs -n 1 git diff"
alias gitdiff-2="git log --reverse|grep commit|cut -d ' ' -f2|tail -n 3|head -n 2|xargs echo|sed -e 's/\s/../'|xargs -n 1 git diff"
alias gitdiff-3="git log --reverse|grep commit|cut -d ' ' -f2|tail -n 4|head -n 2|xargs echo|sed -e 's/\s/../'|xargs -n 1 git diff"

alias gitlog-1="git log --reverse|grep commit|cut -d ' ' -f2|tail -n 2|head -n 2|xargs echo|sed -e 's/\s/../'|xargs -n 1 git log --summary"
alias gitlog-2="git log --reverse|grep commit|cut -d ' ' -f2|tail -n 3|head -n 2|xargs echo|sed -e 's/\s/../'|xargs -n 1 git log --summary"
alias gitlog-3="git log --reverse|grep commit|cut -d ' ' -f2|tail -n 4|head -n 2|xargs echo|sed -e 's/\s/../'|xargs -n 1 git log --summary"

正如mipadi指出的,您可以使用git show $COMMIT,但这也会显示一些报头和提交消息。如果你想要一个直接的差异,使用git show——pretty=format:%b $COMMIT。

这显然不是很简短,所以我将这个别名保留在.gitconfig中

    [alias]
      sd = show --pretty=format:%b

这使我可以使用git sd $ committ来显示diff。

Use:

git diff 15dc8^!

如下面的Git -rev-parse(1)手册页(或者现代Git gitrevisions(7)手册页)片段所述:

命名由commit和its组成的集合的另外两个简写 父提交存在。r1^@表示r1的所有父结点。r1 ^ ! 包括提交r1,但不包括它的所有父类。

这意味着你可以使用15dc8^!作为15dc8^..15dc8在Git中任何需要修改的地方。对于diff命令,git diff 15dc8^..15dc8被理解为git diff 15dc8^ 15dc8,这意味着commit (15dc8^)和commit (15dc8)的父节点之间的差异。

注意:git-rev-parse(1)手册中的描述谈到了修订范围,它也需要用于合并提交,有多个父级。然后r1 ^ !是r1 -not r1^@,即。"r1 ^r1^1 ^r1^2…"


此外,你可以使用git show COMMIT来获取提交描述和提交的diff。如果你只想要diff,你可以使用git diff-tree -p COMMIT。

保罗的解决方案达到了我的期望。

$ git diff HEAD^1

另外,添加像上面提到的hobs这样的别名也很有用。如果您将以下内容放在~/的[alias]部分中。Gitconfig文件,然后您可以使用简写来查看头和前之间的差异。

[alias]
    diff-last = diff HEAD^1

然后运行$ git diff-last将得到结果。请注意,这还将包括您尚未提交的任何更改以及提交之间的差异。如果你想忽略你还没有提交的更改,那么你可以使用diff直接比较HEAD和它的父类:

$ git diff HEAD^1 HEAD