Git Submodule 嵌套子模块

Git Submodule 嵌套子模块

摘要:本文介绍了包含有git Submodule的常用操作,包含创建Submodule,拉取,提交等常用开发操作.

1. 在仓库中增加Submodule

在.git的同级目录下执行:

git submodule add <url>

注意:要确保协同开发主仓库的所有人员,都可以访问<url>;

在仓库中增加完毕submodule后,要执行提交(commit)和推送(push)操作;

2. 查看子模块状态

先设置显示子模块的简明信息:

git config status.submodulesummary 1

查看状态,包含子模块的信息:

git status

查看子项目的日志记录:

git log -p --submodule

查看空间中某一submodule状态:

git diff --cached <submodule_package_file_name>

查看空间中全部submodule状态:

git diff --cached --submodule

3. 克隆含有Submodule的项目

  • 方法一:

克隆项目,默认带有空的Submodule文件夹:

git clone <url> [<rename>]

初始化Submodule:

git submodule init

更新Submodule中的内容至当前版本:

git submodule update
  • 方法二:
    克隆项目的同时,检出所有嵌套的子模块;
git clone --recurse-submodules <url> [<rename>]

4. 在包含子模块的项目上工作

4.1 从子模块的远端拉取上游修改

  • 方法一:
    远程抓取+合并:
git fetch <url> [<branch-name>:<branch-name>]
git merge <branch_name>
  • 方法二:
    将远程git内容同步至本地的一个游离分支上;
git submodule update --remote [<submodule-name>]

需要建立分支temp继承游离分支HEAD:

git branch temp HEAD

在master分支中合并temp分支:

git checkout master
git merge temp
  • 方法三:
    将远程内容合并到本地submodule所处的分支上:
git submodule update --remote --merge
  • 方法四:
    将本地分支变基到远程submodule的最新状态:
git submodule update --remote --rebase

4.2 从项目远端拉取上游更改

git pull <remote-name> --recurse-submodules

如果 .gitmodules 文件中记录的子模块的 URL 发生了改变:

# 将新的 URL 复制到本地配置中
git submodule sync --recursive
# 从新 URL 更新子模块
git submodule update --init --recursive
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Git submoduleGit 的一个功能,可以将一个 Git 仓库作为另一个 Git 仓库的目录进行管理。通过使用模块,我们可以在一个 Git 仓库中使用另一个 Git 仓库的组件。 使用 git submodule 的步骤如下: 1. 在父项目中添加模块:使用命令 `git submodule add <模块仓库地址> <模块存放路径>` 将模块添加到父项目中。 2. 克隆模块:使用命令 `git submodule init` 初始化模块,然后使用命令 `git submodule update` 克隆模块的内容。 3. 切换到模块分支:通过 `cd <模块路径>` 进入模块目录,然后使用 `git checkout <分支名>` 切换到模块所在的特定分支。 4. 更新模块:在父项目中使用命令 `git submodule update --remote` 可以更新模块为最新的提交。 5. 提交模块修改:在父项目中修改了模块后,需要切换到模块目录,进行提交和推送操作。 使用模块的好处是可以将项目作为独立的仓库进行开发和维护,同时在父项目中方便地使用和更新模块。使用模块可以实现项目的模块化和复用,提高代码的可维护性和可重用性。 需要注意的是,使用模块时需要注意模块的分支和版本控制,因为模块可能会更新,需要及时更新父项目中的模块。同时,在多人协作开发中,也需要注意在提交父项目时确保模块的修改也已经提交。 总之,使用 Git submodule 可以方便地在父项目中使用模块的组件,提高代码管理的灵活性和可重用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值