除了编写别名或脚本之外,是否还有更短的命令来获取特定提交的差异?
git diff 15dc8^..15dc8
如果你只给一个提交id git diff 15dc8,它就会对HEAD进行不同的提交。
除了编写别名或脚本之外,是否还有更短的命令来获取特定提交的差异?
git diff 15dc8^..15dc8
如果你只给一个提交id git diff 15dc8,它就会对HEAD进行不同的提交。
如果你知道多久以前,你可以试试这样的方法:
# Current branch vs. parent
git diff HEAD^ HEAD
# Current branch, diff between commits 2 and 3 times back
git diff HEAD~3 HEAD~2
预先提交的工作原理是这样的:
# Parent of HEAD
git show HEAD^1
# Grandparent
git show HEAD^2
有很多方法可以指定提交:
# Great grandparent
git show HEAD~3
详情请参阅本页。
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。
正如mipadi指出的,您可以使用git show $COMMIT,但这也会显示一些报头和提交消息。如果你想要一个直接的差异,使用git show——pretty=format:%b $COMMIT。
这显然不是很简短,所以我将这个别名保留在.gitconfig中
[alias]
sd = show --pretty=format:%b
这使我可以使用git sd $ committ来显示diff。
这使用别名,所以它不能准确地回答你的问题,但我发现这些对你想做的事情很有用……
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"
保罗的解决方案达到了我的期望。
$ git diff HEAD^1
另外,添加像上面提到的hobs这样的别名也很有用。如果您将以下内容放在~/的[alias]部分中。Gitconfig文件,然后您可以使用简写来查看头和前之间的差异。
[alias]
diff-last = diff HEAD^1
然后运行$ git diff-last将得到结果。请注意,这还将包括您尚未提交的任何更改以及提交之间的差异。如果你想忽略你还没有提交的更改,那么你可以使用diff直接比较HEAD和它的父类:
$ git diff HEAD^1 HEAD
许多提到的例子(例如git diff 15dc8^!,或git diff 15dc8^..15dc8)不工作,如果你正在使用Z shell和extendedglob选项集。你可以通过以下三种方法之一来修复它:
Unsetopt extendedglob(和/或从.zshrc中删除它) setopt NO_NOMATCH(和/或在.zshrc中设置它) 每次使用反斜杠转义插入符号和砰砰声,例如,git diff 15dc8\^\!