git submodule 的使用
Git 使用
2023-09-11 14:19:24 时间
当我们要把另一个仓库的代码作为子目录放到当前仓库时,为了防止代码冗余,我们应该使用 git 的子模块 submodule 功能。
引入
把 https://github.com/my/repo.git
引入当前项目,创建一个folder
文件夹来存放代码。
git submodule add https://github.com/my/repo.git folder
此时仓库里会有个 .gitmodules
文件,记录了子仓库信息。我们可以添加多个子仓库。
提交
对主仓库、子仓库都更新代码后,我们提交时,需要依次对两个仓库的 repo 进行提交。在主仓库里进行 git diff 会看到
--- a/folder
+++ b/folder
-Subproject commit 8ffcce923b69d314938ce5485f2ac022986aebcb
+Subproject commit 8ffcce923b69d314938ce5485f2ac022986aebcb-dirty
也就是说主仓库会记录当前该文件夹所用的子项目的 commit 号,所以应该先提交子仓库,再提交主仓库。
拉取
加上--recurse-submodules
参数可以在克隆时初始化并更新子模块。
git clone xx.git --recurse-submodules
-
如果用的是 zsh,自带的 alias gcl='git clone --recurse-submodules',也就是用
gcl xx.git
就可以了。 -
一些文章提到的
--recursive
参数也是一样的作用。
初始化和更新
如果项目拉取时没有加上上面参数,那么需要手动初始化和更新。
初始化并递归更新所有子模块:
git submodule update --init --recursive
也可以分开操作,初始化只需要执行一次:
git submodule init
每次需要更新子仓库时,运行:
git submodule update
删除
还没提交 git 记录的话,把下载的文件夹和 .gitmodules 中相关内容删除即可。否则:
git rm --cached folder
删除目录.gitmodules
删除相关内容.git/config
删除.git 中相关内容rm -rf .git/modules/folder
删除相关内容
相关文章
- [Git] 关于refs/for/ 和refs/heads/
- [翻译] USING GIT IN XCODE [4] 在XCODE中使用GIT[4]
- 从 Git 提交历史中「恢复」文件修改时间
- git与sourceTree
- python后端面试第六部分:git版本控制--长期维护
- [Practical Git] Configure global settings with git config
- [Practical Git] Navigate git command pager output with Unix less commands
- git revert revert
- git 使用
- 详解Git工作区、暂存区、历史记录区以及git reset、git revert、git checkout等撤销命令的区别
- SAP Spartacus 的 git flow 和发布流程
- git常用命令备忘
- 推荐!手把手教你使用Git(转)
- 推荐!手把手教你使用Git
- Git可视化极简易教程 — Git GUI使用方法
- Git使用总结
- git撤销merge,彻底学会git revert的用法
- Git 清空本地所有提交修改记录
- Git中的使用.gitignore忽略不想要提交的文件
- 【Git总结大全】git操作从入门到实战(总结篇)
- 【Git技巧】第六篇 git常用命令速查表
- 在Jenkins中将项目检出到子目录 (使用GIT)
- Git远程仓库(码云gitee)详解(八)
- git显示分支关系图
- 【Git】利用 GIT 做版本控制