git submodule子模块的使用

news2024/12/26 21:15:05

子模块的使用

添加子模块

  1. 添加子模块

    git submodule add <子仓库URL> <子仓库路径>

    例子: git submodule add http://192.168.100.181/guideir/poco.git 3rdparty/poco

  2. 若子模块存在好几个分支,可以在添加子模块时,指定分支

    git submodule add -b <分支名> <子仓库URL> <子仓库路径>

    例子:git submodule add -b build_V1.9.4_ar9341 http://192.168.100.181/guideir/poco.git 3rdparty/poco

    执行此命令后可以在 .gitmodules 文件中看到如下配置:

    [submodule "poco"]
    	path = 3rdparty/poco
    	url = http://192.168.100.181/guideir/poco.git
    	branch = build_V1.9.4_ar9341
    

下载子模块

使用 git clone 下载代码时,如果使用普通的 git clone来克隆项目,会发现项目的子模块文件夹中内容为空

可以使用以下两种方式来克隆子项目:

  1. 克隆主项目时候,使用 git clone --recurse-submodules <主仓库URL> 递归克隆子模块

    例子:git clone --recurse-submodule https://gitee.com/oweni/config-test.git

    git clone --recurse-submodule是 Git 2.13 版本引入的,为了提高命令的可读性。在之前的版本中,可以使用git clone --recursive`指令,无论是哪种写法,都会递归地克隆主仓库及其所有子模块

  2. 若已经克隆完成主项目,但是此时子模块文件夹为空,可以在主仓库目录中使用 git submodule update --init指令下载子模块

    例子:

    1. 下载主仓库代码: git clone https://gitee.com/oweni/config-test.git
    2. 在主仓库目录使用: git submodule update --init 或者 git submodule update --init --recursive 递归下载子模块
  3. 若已经下载完成子模块,发现子模块不是最新代码,可以在主仓库目录使用: git submodule update --remote 或者 git submodule update --remote --recursive 指令将子模块更新到子模块的最新节点;

    注意git submodule update 是将子仓更新到主仓库当前引用的节点,注意,主仓库当前引用的节点,并不一定是子仓库的最新节点;而git submodule update --remote是将子仓库更新到子仓库的最新节点,所以通常在执行完git submodule update --remote指令后,也许主仓库会提示子仓库有新提交,此时在父仓库中add + commit + push当前改动,将主仓库引用的子仓库节点更新到最新

修改子模块代

1.正常情况,进入子仓库,使用git status 查看当前是否处于某个分支,如果是处于正常的分支,那么可以直接进行添加和提交,和普通的提交流程一样

$ git add .
$ git commit -m "commit"
$ git push origin master

2.异常情况,如果进入子仓库,发现子仓库的状态为 头指针分离于 XXXX(commit id),此时有两种解决方案提交:

方案一

1.使用 git addgit commit来添加和提交修改到本地

git add <change files>
git commit -m "fix some bugs"

2.推送修改到子仓库的远端,在头指针分离的情况下,如下提交:

git push origin HEAD:master
//推送当前修改到远端的master分支上

3.回到父仓库中,提交对子模块的更新

cd ..	//回到上级目录(父仓库)
git add son  //son为子仓库的目录
git commit -m "update son submodule"
git push origin master
方案二

解决方法是:在子模块中先git checkout master,然后在git merge <detached branch name/number>,最后git push -u origin master即可。如图:
在这里插入图片描述

解释下出现 头指针分离的原因:

这里有个概念,就是主repo中的子模块被拉到本地时默认是一个子模块远程仓库master分支的detached branch。这个分支是master的拷贝,但它不会被推送到远端。如果在子模块中做了修改,并且已经addcommit,那你会发现当你想要push的时候会报错:Updates were rejected because a pushed branch tip is behind its remote。这便是所谓的detached branch的最直接的体现。

删除子模块

使用git submodule deint指令来删除子模块

提供一个例子,删除trunk/3rdparty/ffmpeg子模块,之后再引入trunk/3rdparty/ffmpeg子模块

1.git submodule deinit -f trunk/3rdparty/ffmpeg,删除 trunk/3rdparty/ffmpeg子模块

​ 此时本地代码目录trunk/3rdparty/ffmpeg中的代码会被删除,但是此文件夹会存留

2.手动删除.git/modules/目录中相关子模块的文件夹

rm -rf .git/modules/trunk/3rdparty/ffmpeg/

3.执行git rm trunk/3rdparty/ffmpeg, 删除此子模块在git中的记录,

此操作会删除以下两个内容:

  • .gitmodule文件中关于这个子模块的配置
[submodule "trunk/3rdparty/ffmpeg"]
	path = trunk/3rdparty/ffmpeg
	url = ssh://git@192.168.100.181:2222/guideir/ffmpeg.git
	branch = build_V4.2.1_ar9341
  • 本地代码目录trunk/3rdparty/ffmpeg目录

执行完以上三个步骤,则子模块被完全清除干净,接下来再添加子模块

4.添加子模块

git submodule add -b build_V4.2.1_ar9341 ssh://git@192.168.100.181:2222/guideir/ffmpeg.git trunk/3rdparty/ffmpeg

注意事项:

  • 如果没有执行删除操作中的第2步,则添加子模块时会报错:在这里插入图片描述
  • 如果没有执行删除操作中的第3步,则添加子模块时会报错在这里插入图片描述
    git pro

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2116553.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

全国糖酒会,就这5个字。“会天下美味”

“全国糖酒会&#xff0c;会天下美味”&#xff0c;是全国糖酒会的品牌口号。这个品牌口号来的非常偶然。 两年前&#xff0c;全国糖酒会准备更新标志之时&#xff0c;也设计了一个品牌口号。新标志发布前几天&#xff0c;临时作了调整&#xff0c;最终变成了“全国糖酒会&…

Day92 代码随想录打卡|动态规划篇---斐波那契数

题目&#xff08;leecode T509&#xff09;&#xff1a; 斐波那契数 &#xff08;通常用 F(n) 表示&#xff09;形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始&#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0&#xff0c;F(1) 1 F(n)…

C++11线程池、多线程编程(附源码)

Test1 示例源码展示&#xff1a; #include<iostream> #include<thread> #include<string> using namespace std;void printHelloWord(string s) {cout << s << endl;//return; } int main() {string s;s "wegfer";thread thread1(p…

【动手学深度学习】08 线性回归 + 基础优化算法(个人向笔记)

1. 线性回归 一个简化的模型&#xff1a; 我们可以这样来定义线性模型&#xff1a;注意这里先转置变成了列向量线性模型可以被看成时一个单层的神经网络&#xff1a;单层是因为单层参数 - 用一个函数来衡量预估质量&#xff1a;损失函数 在训练的时候寻找最小化的损失的参数 w…

Vivado编译报错黑盒子问题

1 问题描述 “Black Box Instances: Cell **** of type ** has undefined contents and is considered a back box. The contents of this cell must be defined for opt_design to complete successfully.” 检查工程代码提示的模块&#xff0c;该模块为纯手写的Veril…

使用AI赋能进行软件测试-文心一言

1.AI赋能的作用 提高速度和效率缺陷预测与分析 2.AI互动指令格式--文心一言 角色、指示、上下文例子、输入、输出 a 直接问AI 针对以下需求&#xff0c;设计测试用例。 需求&#xff1a; 1、账号密码登录系统验证账号和密码的正确性。 验证通过,用户登录成功,进入个人中心;验…

【优选算法】---前缀和

前缀和 一、【模板】一维前缀和二、【模板】二维前缀和三、寻找数组的中心下标四、除自身以外数组的乘积五、和为K子数组六、和可被 K 整除的子数组七、连续数组八、矩阵区域和 一、【模板】一维前缀和 一维前缀和&#xff0c;链接 1、预处理出来一个前缀和数组 注意&#xf…

C#学习 深入理解委托、匿名方法、Lamda表达式、Linq;

目录 一.委托 1.1 什么是委托 1.2 委托的使用 二.匿名方法和Lamda表达式 2.1 什么是匿名方法 2.2 Lambda表达式 三.Linq 3.1 Linq理解 3.2 Linq的扩展方法 一.委托 1.1 什么是委托 委托和类一样&#xff0c;是具有特定参数列表和返回值类型的方法函数的…

VSCode连接docker

1.启动ssh服务 vim /root/.bashrc 或者 vim ~/.bashrc /usr/sbin/sshd #启动ssh服务~代表主目录&#xff0c;cd ~会返回root目录 cd / 返回最根上的目录 为了防止每次打开容器都要输入此指令&#xff0c;我们直接在 ~/.bashrc文件最后一行添加sshd启动命令即可。 打开终端…

javase小项目--图书管理系统

前面我们已经学习到了javase的基本语法结构-继承&#xff0c;多态&#xff0c;接口&#xff0c;接下来就让我们大家一起来利用这些来手动实现一个小项目——简洁的图书管理系统 目录 1.思路 1.book类 1.book 2.booklist 2.user类 user AdminUser NormalUser 3.ioperat…

如何使用Pytorch-Metric-Learning?

文章目录 如何使用Pytorch-Metric-Learning&#xff1f;1.Pytorch-Metric-Learning库9个模块的功能1.1 Sampler模块1.2 Miner模块1.3 Loss模块1.4 Reducer模块1.5 Distance模块1.6 Regularizer模块1.7 Trainer模块1.8 Tester模块1.9 Utils模块 2.如何使用PyTorch Metric Learni…

传统CV算法——基于harris检测算法实现角点检测

角点 角点是图像中的一个特征点&#xff0c;指的是两条边缘交叉的点&#xff0c;这样的点在图像中通常表示一个显著的几角。在计算机视觉和图像处理中&#xff0c;角点是重要的特征&#xff0c;因为它们通常是图像中信息丰富的区域&#xff0c;可以用于图像分析、对象识别、3D…

JavaScript 循环控制语句-break和continue

break循环 首先i0&#xff0c;判断i是否<5,满足条件&#xff0c;判断i是否等于3&#xff0c;i不等于3&#xff0c;输出i0&#xff0c;i的值加1&#xff0c;判断i是否<5&#xff0c;判断i是否等于3&#xff0c;i不等于3&#xff0c;输出i1&#xff0c;i的值加1&#xff0c…

【H2O2|全栈】关于HTML(6)HTML基础(五 · 完结篇)

HTML基础知识 目录 HTML基础知识 前言 准备工作 标签的具体分类&#xff08;五&#xff09; 本文中的标签在什么位置中使用&#xff1f; 表单&#xff08;二&#xff09; 下拉选择菜单 文本域 案例 拓展标签 iframe框架 案例 预告和回顾 后话 前言 本系列博客介…

EasyExcel模板导出与公式计算(下)

目录 环境要求 功能预览 需求分析 导入依赖 制作模板 编写代码 格式优化 最终效果 总结 在上一篇 EasyExcel模板导出与公式计算&#xff08;上&#xff09;-CSDN博客 文章中我们知道了在若依中使用自带的Excel注解来实现表格数据的导出&#xff0c;并且通过重写相关接…

C++复习day07

一、继承 1.什么是继承&#xff1f;继承的意义是什么&#xff1f; 继承的概念 继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段&#xff0c;它允许程序员在保持原有类特性的基础上进行扩展&#xff0c;增加功能&#xff0c;这样产生新的类&#xff0c…

C++ STL 适配器

系列文章目录 模板特例化&#xff0c;偏特化&#xff0c;左右值引用 https://blog.csdn.net/surfaceyan/article/details/126794013 C STL 关联容器 https://blog.csdn.net/surfaceyan/article/details/127414434 C STL 序列式容器(二) https://blog.csdn.net/surfaceyan/arti…

项目实战系列三: 家居购项目 第四部分

购物车 &#x1f333;购物车&#x1f346;显示购物车&#x1f346;更改商品数量&#x1f346;清空购物车&&删除商品 &#x1f333;生成订单 &#x1f333;购物车 需求分析 1.会员登陆后, 可以添加家居到购物车 2.完成购物车的设计和实现 3.每添加一个家居,购物车的数量…

比较顺序3s1,3s2,4s1之间的关系

(A,B)---6*30*2---(0,1)(1,0) 分类A和B&#xff0c;让B全是0。当收敛误差为7e-4&#xff0c;收敛199次取迭代次数平均值&#xff0c;3s1为 3s2为 4s1为 3s1&#xff0c;3s2&#xff0c;4s1这3个顺序之间是否有什么联系 &#xff0c; 因为4s1可以按照结构加法 变换成与4s1内在…

Linux相关概念和重要知识点(2)(用户、文件和目录、inode、权限)

1.root和普通用户 在Windows里面&#xff0c;管理员Administrator是所有用户里面权限最高的&#xff0c;很多文件都会提示请使用管理员打开等。但在整个Windows系统中&#xff0c;管理员的权限并不是最大的&#xff0c;System优先级更高&#xff0c;因此我们系统中的某些文件是…