我们有主git存储库和一个git子模块。对于这个问题,主存储库只有一个主分支,子模块有两个分支-- X和Y。
假设Coder A刚刚切换到子模块分支X,并应用了一些小的更改。
编码器B它在子模块分支Y上。
现在,A推送到远程,B拉扯--那么,即使E 122>A<代码>E 223
主动提交子模块提交,B的活动子模块提交(在其本地计算机上)似乎并不会自动更改为A在分支XE 221>上推送的提交。
相反,对于B,它们在分支Y上的版本保持活动状态。
如果B现在手动从存储库中提取分支并将分支设置为X,那么一切都会再次正常工作。
如何实现子模块更改/活动提交在从主存储库中提取时自动同步?
我们使用源树作为Git,如果这样做更容易解释的话。
发布于 2017-07-05 04:40:03
然后它不会像B的活动子模块提交(在它们的本地机器上)被自动更改为A在分支X上推送的提交,即使A主动提交了更改后的子模块提交
您需要确保从子模块提交和推送,然后从父回购添加/提交和推送(以便记录新的子模块SHA1)
Since Git 1.7.5,git pull
也应该更新子模块。
使用git submodule update --init --recursive
进行二次检查
但是不要忘记,“更新子模块”只会检出它的SHA1,而不是分支。除非是submodule is set to track a branch,而你做的是git submodule update --recursive --remote
。
即使这样,它也会拉出一个分支(X或Y),而不是两者兼而有之。
一位朋友刚告诉我们,我朋友机器上的回购装置可能坏了。所以我们从原产地重新克隆了它,现在一切都成功了。 我现在正在寻找带有子模块的跟踪分支,以避免“签出头”问题。你能推荐一下吗?
正如"True Nature of Submodules“中所解释的,子模块在开始时总是处于分离的头模式。
您仍然可以强制它跟随一个分支并更新自己:参见"git submodule tracking latest“。
这意味着以下命令将在提取所述子模块必须遵循的分支后更新子模块内容:
git submodule update --remote
https://stackoverflow.com/questions/44916800
复制相似问题