3

使用 go-git,有什么方法可以检查我是否已提交,但尚未将其推送到远程?

例如:

$ echo "Hello" > hello.txt
$ git add -A
$ git commit -am "Add hello"
$ git status
On branch master
Your branch is ahead of 'origin/master' by 2 commits.
  (use "git push" to publish your local commits)

nothing to commit, working tree clean

我知道我可以使用 go-git 来检查w,_ = repo.Worktree()and w.Status(),但这似乎并没有给我我想要的东西,除非我错过了一些东西。

4

2 回答 2

1

这是在go-gitissue 1161中提出的,并在go-gitv4.12.0中提供,带有PR 1096PR 1097

您可以使用该命令merge-base检查masterand的共同祖先origin/master是否相同(您已推送所有内容)或不同(您有未推送的本地提交,或者相反,您落后了origin/master

于 2019-08-20T04:37:54.180 回答
1

我按照 VonC 的回答编写了一个解决方案。

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)
}

要点在这里

于 2019-08-20T19:11:25.853 回答