如何解决 Git 仓库嵌套问题

用了很久 Git ,今天却被 Git 嵌套问题卡住了。本文将围绕“如何解决 Git 仓库嵌套”问题展开讨论,并提供解决方案。

一、问题描述

Git 仓库嵌套使用后,被嵌套的 Git 仓库不能被外层 Git 仓库检测到。

这也就意味着你在被嵌套的 Git 仓库中的更改,外层仓库是无感知的。导致这个问题的原因可能如下:

  • 在代码中引入其他 Git 仓库;
  • Clone 别人的 Demo 并做修改;

不看场景的解决方案就是耍流氓。

二、场景一:在代码中引入其他 Git 仓库

这种情况,需要使用 submodule,过程如下:

1
2
3
4
git submodule add https://github.com/chenfengyanyu/fmap-demo.git

# 或者使用 clone
git clone --recursive https://github.com/chenfengyanyu/fmap-demo.git

这个操作类似于 Clone ,但是会在父仓库下面新建 .gitmodules 文件,我们看一下内容:

1
vi .gitmodules

大致如下:

1
2
3
[submodule "fmap-demo"]
path = fmap-demo
url = https://github.com/chenfengyanyu/fmap-demo.git

然后做正常提交就可以了。

需要注意的是,这样的操作只能提交一个引用,类似:fmap-demo @ 90758cf,打开的话,会跳到项目源地址。

三、场景二:Clone 别人的 Demo 并做修改

那么有时候,我们可能会 Clone 到一段代码来作为项目的脚手架,这时候嵌套的话,肯定不希望改子仓库的时候,父仓库毫无感知。那么这种情况如何处理呢?

github

首先,进入子仓库,也就是被嵌套的 Git 仓库,删除 .git 目录:

1
rm -rf .git

可以这么理解,一个项目不应该有俩 Git 地址,所以断开子仓库的原有联系,也就是删除 .git 目录。

然后,将你添加的项目拖出当前项目文件,进行提交。之后,再将项目拖回来,返回项目根目录,执行 add 操作:

1
git add fmap-demo

这里必须要选择子项目进行 add,此时 add .add * 都无效。

之后正常 commitpush,就可以了。

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值