2

我们目前正在重构代码,以便在我们公司的不同项目之间共享。此共享代码将作为Git 子模块包含在其他项目中。

我们担心的一件事是在项目的某些阶段(例如:我们应该稳定/代码冻结的点)从子模块引入超级项目的更改。

我以前从未使用过子模块,但据我所知,子模块引用了另一个 repo 中的特定提交,所以只要你不更新项目中的子模块,你基本上就可以了。

我的另一个队友建议,每当我们进入项目的“稳定阶段”(例如:完成开发)时,我们应该创建子模块的一个分支并指向它。我认为这是一种开销并且似乎是错误的(共享项目不应与使用它的其他项目进行版本锁定)。

所以,总结一下,我的问题是:

  1. 是否应该采取任何措施来保护超级项目免受子模块更新(重大更改)的影响?
  2. 是否存在已知的工作流程,其中进入稳定阶段的超级项目也会创建其子模块的新分支以指向?(链接会很棒)。
4

1 回答 1

2

是否应该采取任何措施来保护超级项目免受子模块更新(重大更改)的影响?

否:在子模块中进行的任何修改(并推送到其上游 repo)都不会影响父 repo:它仍然会引用相同的gitlink父 repo 索引中的特殊条目)。

是否存在已知的工作流程,其中进入稳定阶段的超级项目也会创建其子模块的新分支以指向?

否:子模块是固定的 SHA1。

于 2015-09-03T09:14:39.810 回答