gitGit

Git Submodule的使用

2016-11-05  本文已影响129人  长仙人

是什么?

submodule子模块,简单来讲就是Git仓库中的子仓库。

想一想是不是遇到过这样的情况,有一个模块是通用的,需要被使用到多个项目;或者你的项目中要使用github上的一个开源模块。这样的模块要怎么在你的项目中保持同步更新甚至是提交呢?答案就是submodule。

怎么用?

1. 新增submodule

git submodule add $giturl $foldername

其中$giturl表示git仓库地址,$foldername表示submodule的目录名,例如:

git submodule add git://github.com/xx/A.git A

注:下面示例全部以 A 当做submodule所在目录

完成后,将文件变化提交即可。

2. clone有submodule的git仓库

git clone $giturl
git submodule init
git submodule update

3. submodule A作者有更新,如何同步到我的项目?

  1. 更新submodule A

     cd A
     git pull
    
  2. 回到主git仓库,查看状态,并提交

     cd ..
     git status
    
     //输出结果有这样的内容,意思是submodule A有修改。add并提交即可
     modified:   A (new commits)
    
     git add .
     git commit -m 'update submodule'
     git push
    
  3. 你的同事或者协作的开发者,如何更新?

     git pull
     git submodule update
    

这个些操作和status的内容一开始可能很难理解,这里要讲一下关于submodule的设计理念:

所以,如果你要更新submodule必须做上面的操作步骤。而你操作完成后,你的git仓库中submodule的commit号得到更新。这样,与你协作的开发者,就可以直接git pull得到最新的submodule commit号,git submodule update获取submodule该commit的代码。

4. 我是主git仓库的开发者,同时也是submodule A的作者,如何在主git仓库修改A并同步?

如果你理解了上面说的设计理念,那么这个操作非常简单。

  1. 修改A目录中的内容

  2. 提交并同步A

     cd A
     git add .
     git commit
     git push
    
  3. 此时,你就处于3.2的状态,按照3.2操作即可。

5. 几个submodule都想更到最新

有个简便操作

    git submodule foreach git pull

这样所有submodule都更到最新了,add commit即可。

上一篇 下一篇

猜你喜欢

热点阅读