1

我们正在使用 Mercurial 进行源代码控制,并希望为我们的 QA 流程引入自动合并和更改日志。出于讨论的目的,我们假设我们使用一个简单的 3 分支流程,如下所示:

\ = forward merge
| = back merge of fix

Default --O--A--*--B--*---
           \    ^      \
            \   |       \
QA      -----M--X--C--*--N---
                ^      \ 
                |       \
Master  --------H--------*---  

所以问题是:是否有可能构造一个 revset 查询,在合并 N 时,最好是在实际执行它之前,否则在实际执行它之后,将导致默认分支上所有提交的日志,这些提交尚未在 QA 分支中(在上图是A和B)。

另一种表述:是否可以构造一个 revset 查询来返回所有变更集,如果我们将 Default 合并到 QA 中,这些变更集将被合并。

我只对 Default 分支上的提交感兴趣,而不是已经合并到 Default 中的功能分支中的单个提交(图中未包含功能分支)。我也对 QA 分支上的提交不感兴趣。

该存储库维护得很好,但已有几年历史,包含大约 13000 个节点。

我一直在试验祖先和祖先,但要么我得到 X 作为最新的共同祖先,要么是一些非常非常古老的节点。我理解获得 X 的逻辑,但我真的在追求 O。

我最幸运的是这种变化:

hg log --rev "((heads(branch('Default')) and !closed()) % heads(branch('QA'))) and branch('Default') and p2(!branch('QA'))"
hg log --rev "((heads(branch('Default')) and !closed()) % heads(branch('QA'))) and branch('Default') and !children(branch('QA'))"

更新

按照 Tom 的建议,使用“hg merge --preview --rev XYZ”会生成如下输出:

changeset:   13070:7e59fc16aa4e
branch:      Default
parent:      13068:5b9409ad504f
parent:      13069:849bd43d2023
user:        *******
date:        Mon Dec 18 18:40:46 2017 +0200
summary:     Merged Feature branch A

changeset:   13071:07470ff919ff
branch:      Feature branch B
parent:      13061:540eda2c959b
parent:      13068:5b9409ad504f
user:        *****
date:        Mon Dec 18 18:49:42 2017 +0200
summary:     Merge with Default

changeset:   13072:a53260ffabca
branch:      Feature branch B
user:        *****
date:        Mon Dec 18 18:58:05 2017 +0200
summary:     Some text

changeset:   13073:37c895f2abf0
branch:      Default
parent:      13070:7e59fc16aa4e
parent:      13072:a53260ffabca
user:        *******
date:        Mon Dec 18 18:58:05 2017 +0200
summary:     Merged Feature branch B

还不错,但也不是很有趣。至少它需要比简单的 grep/sls 更多的逻辑来解析。

在此先感谢,约翰

4

1 回答 1

1

我找到了一个主要做我想要的解决方案:

hg log --rev "branch('Default') & !ancestors(branch('QA')) & ancestors(heads(branch('Default')) & !closed()) & !children(branch('QA'))"

现在唯一缺少的是排除多个头部合并,因为它们只是变更日志中的噪音。


更新:

所以我再次选择了这个项目,并在 SO 的其他地方找到了一些很好的答案。

以下生成类似于 hg merge --preview 的输出,但可以模板化:

hg log -r "ancestors('$sourceBranch') - ancestors(.)" --template $template

这会过滤掉所有不在源分支上的提交:

hg log -r "(ancestors('$sourceBranch') - ancestors(.)) and (branch('$sourceBranch'))" --template $template
于 2017-12-19T13:09:57.120 回答