2 回答
TA贡献1783条经验 获得超4个赞
这是在go-git
问题 1161中提出的请求,并在go-git
v4.12.0中通过PR 1096和PR 1097交付。
您可以使用该命令检查和 的merge-base
共同祖先是否相同(您已经推送了所有内容)或不同(您有尚未推送的本地提交,或者相反,您落后了)master
origin/master
origin/master
TA贡献1757条经验 获得超7个赞
func main() {
dir, err := os.Getwd()
CheckIfError(err)
repo, err := git.PlainOpen(dir)
CheckIfError(err)
revision := "origin/master"
revHash, err := repo.ResolveRevision(plumbing.Revision(revision))
CheckIfError(err)
revCommit, err := repo.CommitObject(*revHash)
CheckIfError(err)
headRef, err := repo.Head()
CheckIfError(err)
// ... retrieving the commit object
headCommit, err := repo.CommitObject(headRef.Hash())
CheckIfError(err)
isAncestor, err := headCommit.IsAncestor(revCommit)
CheckIfError(err)
fmt.Printf("Is the HEAD an IsAncestor of origin/master? : %v\n",isAncestor)
}
- 2 回答
- 0 关注
- 117 浏览
添加回答
举报