2

我正在使用 git rev-list 以两种不同的方式从 repo 中获取提交的选择:

git rev-list --reverse HEAD~<n>..

和 git rev-list --reverse ..

阅读了 git rev-list 手册页后,我知道 .. 等同于 ^,并且这不会包含在所选提交范围内,但是手册页没有指定如果我想要包含的范围提交(即包括 )

我有同样的问题: git rev-list --reverse HEAD~..

这是我想要的规范:

说我有四个提交:

A--B--C--D

我有一个脚本,我给出了两个提交:

myscript --from B --to D

我想要一个大小为 3 的提交列表:

B, C, D

或者如果我这样做了:

myscript --last 4

我会得到:

A, B, C, D

我提出的解决方案是执行以下操作:

git rev-list --reverse <tag1>~1..<tag2>

或 git rev-list --reverse HEAD~..

但是,如果 n == 提交次数,或者 tag1 是第一次提交,这将不起作用。

任何帮助,将不胜感激。

4

2 回答 2

6

因此,对于 --last N 选项,我发现以下效果非常好:

git rev-list --reverse HEAD -n <n> 

不幸的是,选择包含范围的解决方案并不那么干净:

git rev-list --reverse <tag1>..<tag2> --boundary

这会给你你想要的,但是它会在第一次提交前放一个小破折号(“-”)。不过,这可以通过一些字符串处理来解决。

于 2013-07-11T17:47:57.633 回答
0

rev-list手册页:

列出可以通过跟随给定提交的父链接到达的提交,但排除可以从前面带有 ^ 的提交中到达的提交。

要获得包含的提交列表,只需列出用空格分隔的两个引用。您的第一个引用应使用 tilda 引用先前的提交,~然后将其排除在外,这用前导抑扬符表示^

git rev-list --reverse ^<tag1>~ <tag2>

例如:

git log --oneline
071f2c5 (HEAD -> master) D
8b2c3ee C
4f9aa7e B
6296bbd A
git rev-list --reverse ^4f9aa7e~ 071f2c5
4f9aa7e4d421e7cad3113bf92967cb646484ea25
8b2c3eeb38b21b5cf143e9a79c21bf23453eef85
071f2c527712d8d16aede35e1881a07fb55b408f
于 2017-07-20T16:54:53.270 回答