我有一个项目,我使用了一种相当不常见的标记策略。我们最终将标签作为叶子,所以我们的历史看起来像这样:
0.3.0 0.3.0
|/ |
| 0.2.0 rather than 0.2.0
|/ |
| 0.1.0 0.1.0
|/ |
我这样做的原因是我们的标签应该包含 dist
输出,而在开发期间我们不想将此类文件提交到版本控制中。因此,当我运行构建时,构建工具会自动分支,添加构建工件(dist
文件夹)和生成的提交,然后在那里创建标签。
这个工作流程乍一看可能很奇怪,但到目前为止我发现它非常方便,因为我们需要在标签中包含 dist
文件夹以用于下游部署过程。
现在的问题是,我想自动生成release notes,只是问题是,在这种情况下,我如何找出previous tag?我知道给出的答案 here但是标签是叶子,这样就不行了。
最佳答案
(编辑:下面的原始奖励答案,这里有一个更简单的标签 merge 碱基的方法,因此 git describe
可以找到它们。
doit ()
{
cleanup="`mktemp -t`";
git for-each-ref refs/tags/"$1" --format='
echo git tag -d base/%(refname:short) >> '"$cleanup"'
git tag base/%(refname:short) $(git merge-base HEAD %(refname:short))
' | sh -x;
result=`git describe --tags`;
sh -x "$cleanup";
rm "$cleanup"
echo ${result#base/}
}
doit "0.*"
)
使用来自 this answer 的 latest.awk
这样:
doit ()
{
git rev-list --topo-order --first-parent --children --tags --format=%d \
| awk -f path/to/latest.awk \
| sed -n /$1"/,$ { /"$1"/! {p;q} }"
}
测试:
~/sandbox/15$ git lgdo --topo-order --tags
* ecb363d (tag: tag4) tag4
* cd9f402 master
| * 26aa94b (tag: tag3) tag3
|/
* a1b6c1b master
| * 8866091
(tag: tag2)
tag2
|/
* b5d5283 master
| * 29a4e54
(tag: tag1)
tag1
|/
* cfcd7dc master
* 6120ab4 (tag: empty)
~/sandbox/15$ doit tag2
29a4e54debae973dfc3955d6663f14d6ade73df9 (tag: tag1)
~/sandbox/15$
(编辑:和
~/sandbox/15$ git checkout tag4
HEAD is now at ecb363d... tag4
~/sandbox/15$ git describe --tags
tag4
~/sandbox/15$ doit `git describe --tags`
26aa94bad1e37602791c354823cb4a84ff6fc437 (tag: tag3)
~/sandbox/15$
)
(git lgdo
是 git log --graph --decorate --oneline
的别名,其中的“master”是提交消息工件一个让我做出一些 promise 的助手)
关于git - 你如何找出这样一个工作流程中的前一个标签?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19925288/