git - 使用 Git 复制子模块

标签 git git-submodules

我在 Git 中有一个项目,它有几个子模块,我需要下载这些子模块和可用的文件才能使用主项目,为了让子模块工作,我需要它们自己的子模块可用等。因此,为了进行设置,我使用 git submodule update --init --recursive 递归初始化子模块。

但是,我注意到我的许多子模块都有共享的依赖关系,在伪代码中看起来像这样(alpha -> beta 表示 alpha 有子模块 测试版)

my project -> submodule a -> submodule m
           -> submodule b -> submodule m
                          -> submodule n -> submodule x
           -> submodule c -> submodule x

我的问题是:是否有任何方法可以仅使用 git 来避免这种重复,同时仍然为每个子模块保留(至少一份)文件?

我可以想象一个带有符号链接(symbolic link)的解决方案,但如果 git 为我处理这个会更好,而且我不确定自己放入符号链接(symbolic link)是否会在更新子模块时引起问题。

理想情况下,我愿意将其简化为:

my project -> submodule a -> symlink(submodule m)
           -> submodule b -> symlink(submodule m)
                          -> symlink(submodule n)
           -> submodule c -> symlink(submodule x)
           -> submodule m
           -> submodule n -> symlink(submodule x)
           -> submodule x

提前感谢您的任何建议!

最佳答案

这不是 git 内置的,但你绝对可以像你说的那样使用符号链接(symbolic link)来做到这一点。您可能想看看 git new-workdir (来自 git 的 contrib 目录),它基本上是这样做的。它不知道与子模块有任何关系,但子模块不知道它是一个子模块 - 知道这些东西的是父仓库。我没试过这个,但我很确定你可以像这样使用它:

# remove the target first (new-workdir will refuse to overwrite)
rm -rf submodule_b/submodule_m

#               (original repo)         (symlinked repo)
git new-workdir submodule_a/submodule_m submodule_b/submodule_m

它通过符号链接(symbolic link)基本上所有的 .git 目录来工作;没有符号链接(symbolic link)的值得注意的是 HEAD;这两个目录可以 checkout 不同的内容,但共享相同的引用和对象。

从这里开始你应该会很好。当您在 super 模块中运行 git submodule 命令时,它只是进入子模块并在那里运行适当的命令,所有这些都将按预期工作。

对于这样的符号链接(symbolic link)存储库,您通常需要注意的一件事是它们共享同一组分支,因此如果它们都有相同的分支 checkout ,并且您在其中一个提交,另一个将变得不同步。不过,对于子模块,这通常不会成为问题,因为除非您进行干预,否则它们基本上始终处于分离的 HEAD 状态。

关于git - 使用 Git 复制子模块,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4115817/

相关文章:

git - 如何一次将一个当前分支 merge 到多个后续分支?

git - MAC + git gui->软件包 "Tcl": have 8. 5.9版本冲突,需要8.6

git - 尝试执行 git-commit 或 git-status 时如何修复 'bus error'

git - 如何重命名带有子模块的 git 存储库?

git - git 如何处理将另一个存储库克隆到子目录中?

git - '!'不排除 .gitignore 中的文件

git - 在 Git Revert 命令之后我不能使用命令行/git

git - 更新 Git 子模块失败

git - 一个目录中有两个 git 存储库?

git - `--name` 选项没有 't work with ` git submodule add` 命令