我想确定在一些Git和汞开源项目中存在的仅用于研究目的的“AA>”的数量。对如何完成这项工作有什么建议吗?
如果合并有两个不同的共同祖先,则可以确定交叉合并。它正在开发一种新的Mercurial合并策略,名为criss cross merges,它将扩展祖先.祖先()代码以返回所有最大的共同祖先。我还没找到这段新代码,但它会有很大帮助。
我对git的了解还不够,但它肯定有类似的东西。

最佳答案

我假设您希望得到存储库中任何分支之间交叉合并的次数,而不是两个分支交叉合并的次数。在这种情况下,以下shell脚本应该对git起作用:

#!/bin/sh

# Get the list of branches and convert it to an array.
branches=$(git for-each-ref --format='%(refname:short)' refs/heads/)
branches=( $branches )
N=${#branches[*]}

cc_merges=0

# Loop over all combinations of two branches.
for ((i=0; i<N-1; ++i)); do
    for ((k=i+1; k<N; ++k)); do
        a=${branches[$i]}
        b=${branches[$k]}
        bases=$(git merge-base --all $a $b | wc -l)
        if [ $bases -gt 1 ]; then
            let "cc_merges += 1"
        fi
    done
done

echo "Number of criss-cross merges in repository: $cc_merges"

对于mercurial,它的ancestor()revset和debugancestor命令不幸地只列出了最大的共同祖先,而不是所有祖先的列表,所以我不能在这里提出解决方案。

09-04 15:22