添加子模块
$ git submodule add <url> <path>
url
为想要添加的子模块路径path
为子模块存放的本地路径
示例,添加 r-tinymaix 为子模块到主仓库 ./sdk/packages/online-packages/r-tinymaix
路径下,命令如下所示:
$ git submodule add https://github.com/RiceChen0/r-tinymaix.git ./sdk/packages/online-packages/r-tinymaix
等命令执行完毕后,在本地路径就可以看到子模块内容了:
此时报了一个警告:
warning: in the working copy of '.gitmodules', LF will be replaced by CRLF the next time Git touches it
这是因为在文本处理中,Windows平台中使用 CR/LF(回车/换行)
作为换行符,Linux平台中仅使用 LF(换行)
作为换行符,这个问题可以通过以下方式解决:
$ git config --global core.autocrlf true
查看子模块
$ git submodule
可以看到子模块信息:
c5029b773b0511d32cca78275b7c8f1fb5eb34a8 sdk/packages/online-packages/r-tinymaix (heads/main)
更新子模块
$ git submodule update
提交子模块
查看仓库状态:
$ git status
可以看到有新文件添加进来:
这里我自己添加了一个 Sconscript
文件,将它也添加进来,执行命令:
$ git add .
提交到仓库、推送到远端:
$ git commit -m "add r-tinymaix"
$ git push origin HEAD:master
博主仓库没有远端,就不 push
了~
删除子模块
简单粗暴式
- 删除子模块目录及源码:
- 删除
.gitmodules
文件中子模块相关条目:
- 删除
.git/config
配置项中子模块相关条目:
- 删除
.git/module/
目录下子模块相关内容:
官方优雅式
根据官方文档,可使用卸载子模块命令:
$ git submodule deinit <sub-module>
如果添加上参数 --force
,则子模块工作区内即使有本地的修改,也会被移除。