首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Git子模块-如何在从主回购中提取子模块时保持子模块的更新

Git子模块-如何在从主回购中提取子模块时保持子模块的更新
EN

Stack Overflow用户
提问于 2017-07-05 04:02:20
回答 1查看 3.9K关注 0票数 3

我们有主git存储库和一个git子模块。对于这个问题,主存储库只有一个主分支,子模块有两个分支-- XY

假设Coder A刚刚切换到子模块分支X,并应用了一些小的更改。

编码器B它在子模块分支Y上。

现在,A推送到远程,B拉扯--那么,即使E 122>A<代码>E 223主动提交子模块提交,B的活动子模块提交(在其本地计算机上)似乎并不会自动更改为A在分支XE 221>上推送的提交。

相反,对于B,它们在分支Y上的版本保持活动状态。

如果B现在手动从存储库中提取分支并将分支设置为X,那么一切都会再次正常工作。

如何实现子模块更改/活动提交在从主存储库中提取时自动同步?

我们使用源树作为Git,如果这样做更容易解释的话。

EN

Stack Overflow用户

回答已采纳

发布于 2017-07-05 04:40:03

然后它不会像B的活动子模块提交(在它们的本地机器上)被自动更改为A在分支X上推送的提交,即使A主动提交了更改后的子模块提交

您需要确保从子模块提交和推送,然后从父回购添加/提交和推送(以便记录新的子模块SHA1)

Since Git 1.7.5git 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“。

这意味着以下命令将在提取所述子模块必须遵循的分支后更新子模块内容:

代码语言:javascript
运行
复制
git submodule update --remote
票数 2
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44916800

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档