本文最后更新于:2024年5月7日 下午

项目中经常使用别人维护的模块,在git中使用子模块的功能能够大大提高开发效率,本文主要讲解子模块相关的基础命令,详细使用请参考man page。

子模块的添加

命令如下:

1
git submodule add <url> <path>
  • 其中:

    • url为子模块的路径
    • path为该子模块存储的目录路径。
  • 执行成功后,git status会看到项目中修改了.gitmodules,并增加了一个新文件(为刚刚添加的路径)

  • git diff --cached查看修改内容可以看到增加了子模块,并且新文件下为子模块的提交hash摘要

  • git commit提交即完成子模块的添加

子模块的使用

克隆项目后,默认子模块目录下无任何内容。需要在项目根目录执行如下命令完成子模块的下载:

1
2
git submodule init
git submodule update

或:

1
git submodule update --init --recursive
  • 执行后,子模块目录下就有了源码,再执行相应的makefile即可。

子模块的修改

涉及子模块修改一般是指 子模块名称(相对位置) 或仓库地址的修改,修改流程如下:

  1. 进入包含submodule的项目目录中,使用命令 git submodule 查看当前submodule的状态。

  2. 使用命令 git config -f .gitmodules --get submodule.[path].url 获取当前submodule的URL,其中[path]是指submodule所在的路径。

    例如我的子模块在项目的 algo/test 下那么命令为:

    1
    git config -f .gitmodules --get submodule.algo/test.url
  3. 使用命令 git submodule deinit [path] 将submodule从父项目中删除。

    1
    git submodule deinit algo/test
  4. 使用命令 git rm [path] 删除子模块文件夹及其所有内容,同时将其从Git index中移除。请注意:这不会影响子模块实际存储库中的任何内容。

    1
    git rm algo/test
  5. 更新.gitmodules文件中子模块配置信息

1
git config -f .gitmodules submodule.[path].url [new URL]
  1. 重新初始化子模块并拉取代码
1
git submodule update --init --recursive

子模块的更新

子模块的维护者提交了更新后,使用子模块的项目必须手动更新才能包含最新的提交。

在项目中,进入到子模块目录下,执行 git pull更新,查看git log查看相应提交。

完成后返回到项目目录,可以看到子模块有待提交的更新,使用git add,提交即可。

删除子模块

有时子模块的项目维护地址发生了变化,或者需要替换子模块,就需要删除原有的子模块。

  • 删除子模块较复杂,步骤如下:

  • rm -rf 子模块目录 删除子模块目录及源码

  • vi .gitmodules 删除项目目录下.gitmodules文件中子模块相关条目

  • vi .git/config 删除配置项中子模块相关条目

  • rm .git/module/* 删除模块下的子模块目录,每个子模块对应一个目录,注意只删除对应的子模块目录即可

执行完成后,再执行添加子模块命令即可,如果仍然报错,执行如下:

1
git rm --cached 子模块名称

完成删除后,提交到仓库即可。

参考资料



文章链接:
https://www.zywvvd.com/notes/tools/git/git-submodule/git-submodule/


“觉得不错的话,给点打赏吧 ୧(๑•̀⌄•́๑)૭”

微信二维码

微信支付

支付宝二维码

支付宝支付

git submodule 添加、使用、修改和删除
https://www.zywvvd.com/notes/tools/git/git-submodule/git-submodule/
作者
Yiwei Zhang
发布于
2021年9月27日
许可协议