一个git子模块目前在一个分支上,我不确定它是否在尖端。如何获取分支提示的提交ID,以便在必要时可以提取子模块?
答案 0 :(得分:2)
如果您在子模块中的分支foo
上,那么根据定义,您就在该分支的顶端。也许您想要的是根据“超级模块”中提交的版本找出子模块应该提交的内容?要做到这一点,你可以这样做:
$ git rev-parse HEAD:mysubmodule
1b6577014983eb68c56025e6d3b95c8b9b7fc511
...然后将其与:
进行比较$ cd mysubmodule
$ git rev-parse HEAD
4dd9ac74b6dc1d0df8de5029656663bd879a4773
但是,您可以更轻松地查看git status
的输出:
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
# (commit or discard the untracked or modified content in submodules)
#
# modified: mysubmodule (new commits)
“新提交”表示您的子模块位于已提交的版本之后,应使用git submodule update mysubmodule
进行更新。
您还可以从git submodule
的输出中看到这一点,如果需要更新子模块,那么与您的子模块对应的行将以+
开头。
您的问题的另一种解释是您的子模块位于分支foo
上,但您想知道分支foo
的尖端在远程存储库中的位置。要做到这一点,你可以这样做:
$ cd mysubmodule
$ git fetch origin
$ git rev-parse origin/foo