我有一个脚本可以检出一个仓库,检查子模块,然后打印一些有关子模块的信息,以便用户知道他们正在处理哪些标签/分支。
我自己工作站上的输出如下所示:
Entering 'SubModuleA',
* feature/some_feature_branch,
Branch is,
feature/some_feature_branch,
Tag is,
undefined,
Entering 'SubModuleB'
* (detached from 1.1.9)
Branch is
HEAD
Tag is
1.1.9^0
在此示例中,主仓库指向子模块A的特征分支和子模块B的标记。
但是当我使用ansible在其他工作站或VM上运行此代码时,输出看起来不同:
Entering 'SubModuleA',
* (detached from 1234abcd),
Branch is,
HEAD,
Tag is,
undefined,
Entering 'SubModuleB'
* (detached from a1b23c4d)
Branch is
HEAD
Tag is
1.1.9^0
代码如下所示:
git submodule foreach 'git branch | grep \* ; echo Branch is && git rev-parse --abbrev-ref HEAD ; echo Tag is && git name-rev --tags --name-only $(git rev-parse HEAD) '
这有点像我发现的其他一些例子,但是我找不到这种信息,但是我找不到一致的东西。
剧本中状态检查之前的命令是
git submodule init
git submodule update
我不确定为什么我会得到不同的结果。有什么能够可靠地打印子模块的分支名称和标签名称吗?
答案 0 :(得分:2)
我认为你混淆的根源是,关于子模块状态的唯一信息git是提交ID。考虑一个具有多个分支的现有存储库,例如,这个:
克隆它:
$ git https://github.com/githubtraining/hellogitworld.git
$ cd hellogitworld
现在,获取指定分支的提交ID(例如,' master'):
$ git rev-parse master
ef7bebf8bdb1919d947afe46ab4b2fb4278039b3
现在,查看提交ID:
$ git checkout ef7bebf8bdb1919d947afe46ab4b2fb4278039b3
并运行git status
:
$ git status
HEAD detached at ef7bebf
nothing to commit, working directory clean
正如您所看到的,即使您已签出了提交ID
对应于一个命名分支,git
不知道(因为你
直接找到提交ID,而不是通过查找
名称)。
如果您克隆包含的存储库,则会发生这种情况 子模块。子模块通过提交ID 检出,而不是 任何命名分支。这实际上是一个关键特征:它确保 你总是得到相同的提交,即使分支进展 链接存储库。
您可以使用git describe
命令获取名称
在这种情况下分支。例如:
$ git describe --all
heads/master
要获得--all
,需要git describe
标记
考虑分支名称和标签。