1

给定一个包含数百个分支/数千个提交的大型 git 存储库,以及不规则的分支合并策略,如何确定两个提交之间的最短路径?换句话说,从较早的提交 A 到较晚的提交 B 的分支路径是什么路径穿过最少数量的提交?

(在我的情况下,我试图追踪一个“开发”分支的历史,该分支通过快进无意中被合并到功能分支中。“最短路径”策略似乎是一种实用的方法,但我一直在寻找git-log 和 git-rev-list [v1.8.3.1] 的帮助页面,但没有找到任何似乎可以做到这一点的选项。我是否遗漏了一些明显的东西?)

4

1 回答 1

2

我不确定你在问什么,但要找到 A 到 B 的方式,你可以使用它:

git log commitA..commitB

您可以使用--graph--simplify-merges标志使其更清晰。

您还可以像这样美化日志:

git log --simplify-merges --graph --pretty="tformat:%C(yellow)%h%Creset\\ %Cgreen(%ar)%Creset\\ %C(blue)<%an>%Creset\\ %C(red)%d%Creset\\ %s"

并得到这样的输出:

在此处输入图像描述

于 2018-11-29T18:21:16.560 回答