简单的答案是你可以做到,但长答案是这样的:
Git store snapshots of ALL 在每个提交操作系统中存储 repo 的内容,如果您只想使用其中的一部分,您基本上只需要签出所需的部分你需要,当你提交时,你需要拥有当前提交的所有内容。
所以你也可以这样做,但这样做你不会得到任何东西。
您提到您听说过 submodulkes。
这里是关于子模块/子树的完整解释
您可以尝试阅读有关子模块的信息。
Submodules 始终允许将外部存储库嵌入到源代码树的专用子目录中指向一个特定的提交。
git submodule
像您目前所做的那样,将您的大项目分解为子项目。
现在将每个子项目添加到您的主项目中:
git submodule add <url>
将投影添加到您的存储库后,您必须对其进行初始化和更新。
git submodule init
git submodule update
从 Git 1.8.2 开始,添加了新选项 --remote
git submodule update --remote --merge
fetch将在每个子模块中merge them in从上游获取最新更改,并且check out子模块的最新版本。
正如the docs 描述的那样:
--remote
此选项仅对更新命令有效。不要使用超级项目记录的 SHA-1 来更新子模块,而是使用子模块的远程跟踪分支的状态。
这相当于在每个子模块中运行 git pull。
但是,在 C 中的 bug 修复会影响与父层共享的代码的情况下,我将如何推送提交?
再次重申:使用子模块会将您的代码作为其内容的一部分放在主项目中。将其本地放在文件夹中或将其作为子模块的一部分之间的区别在于,在子模块中,内容被管理(提交)到不同的独立存储库。
这是子模块的图示 - 另一个项目中的项目,其中每个项目都是一个独立的项目。
git subtree
Git 子树允许您插入任何存储库作为另一个存储库的子目录
与submodule 非常相似,但主要区别在于代码的管理位置。在子模块中,内容被放置在一个单独的 repo 中并在那里进行管理,这允许您将其克隆到许多其他 repo。
subtree 将内容作为根项目的一部分进行管理,而不是在单独的项目中。
您无需写下如何设置它以及了解如何使用它,您只需阅读这篇将解释一切的优秀文章。
https://developer.atlassian.com/blog/2015/05/the-power-of-git-subtree/