git - 你如何找出这样一个工作流程中的前一个标签?

标签 git build tags workflow

我有一个项目,我使用了一种相当不常见的标记策略。我们最终将标签作为叶子,所以我们的历史看起来像这样:

  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 answerlatest.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 lgdogit log --graph --decorate --oneline 的别名,其中的“master”是提交消息工件一个让我做出一些 promise 的助手)

关于git - 你如何找出这样一个工作流程中的前一个标签?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19925288/

相关文章:

git - 带有 -a 的路径对 bash 函数没有意义

git - 更改 .gitignore 时,所有开发人员都需要运行 `git rm --cached <path>` 吗?

git - 具有多个发布版本的软件开发的最佳工作流程

git - 如何忽略 Sourcetree 中带有 Git 存储库的文件夹中的所有文件?

java - eclipse:在 jar 导出中包含任意文件

android - 由于 java 不正确,无法构建 android

javascript - 使用jquery在textarea中的颜色代码

javascript - 我们可以只使用 css 为标签做输入吗?

java - JSP找不到样式表、图像

java - Gradle 构建失败