Git - 子模块

做为一名程序员,大家对 ** Git ** 肯定都不陌生,最近项目中用到了 Git 子模块,今天,给大家讲一下 ** Git ** 子模块。

通常,一个大型工程总会被分拆为一些子工程。这既有利于工程开发难度的降低,也有利于使用现成的方案或者第三方方案作为子工程。git submodule 就是完成这样一种子工程拆分与整合的工具。下面开始简单介绍一下 git submodule 的用法。

什么是 Submodule?

git Submodule 是一个很好的多项目使用共同类库的工具,他允许类库项目做为 ** repository ** ,子项目做为一个单独的 git 项目存在父项目中,子项目可以有自己的独立的 ** commit push pull 。而父项目以 Submodule 的形式包含子项目,父项目可以指定子项目 header,父项目中会的提交信息包含 Submodule 的信息,再 ** clone 父项目的时候可以把 **Submodule **初始化。

在项目中使用Submodule

  • 在项目中添加 Submodule,使用 git submodule add + 仓库地址,例如
git submodule add git@github.com:jjz/pod-library.git pod-library
  • 查看当前状态
git status
On branch master
 Changes to be committed:
       new file: .gitmodules 
       new file: pod-library

可以看到多了两个需要提交的文件:.gitmodules 和 pod-library
**.gitmodules ** 内容包含 Submodule 的主要信息,指定 reposirory 的路径

[submodule "pod-library"] 
path = pod-library 
url = git@github.com:jjz/pod-library.git

可以看到记录了子项目的目录和子项目的 git 地址信息。

  • 另外,这两个文件都需要提交到父项目的git中。
git add .gitmodules pod-ibrary
git commit -m "pod-library submodule"
git submodule init
  • 修改Submodule

    首先需要确认有对Submodule的commit权限,如果没有权限,则不能提交提交代码到父项目上。

  • 进入 Submodule 目录里面

cd pod-library/
  • 修改其中的一个文件,并且查看改动
git status
modified: pod-library/UseAFHTTP.h
  • 提交Submodule的更改内容
git commit -a -m'test submodule'
  • 然后 push 到远程服务器
git push
  • 然后再回到父目录,提交Submodule在父项目中的变动
cd ..
git status
modified: pod-library (new commits)

可以看到 pod-library 中已经变更为 Submodule 最新的 commit id

Subproject commit 330417cf3fc1d2c42092b20506b0d296d90d0b5f
  • 需要把 Submodule 的变动信息推送到父项目的远程服务器
git commit -m'update submodule'
git push

这样就把子模块的变更信息以及子模块的变更信息提交到远程服务器了,从远程服务器上更新下来的内容就是最新提交的内容了。

  • 更新 Submodule
    更新Submodule有两种方式
  1. 在父项目的目录下直接运行
git submodule foreach git pull
  1. 在Submodule的目录下面更新
cd pod-library
git pull
  • 克隆 Submodule
    clone Submodule 有两种方式 一种是采用递归的方式 clone 整个项目,一种是 clone 父项目,再更新子项目。
  1. 采用递归参数 --recursive
git clone git@github.com:jjz/pod-project.git --recursive

执行结果

loning into 'pod-project'...
remote: Counting objects: 57, done.
remote: Compressing objects: 100 % (45 / 45), done.
remote: Total 57(delta 13), reused 49(delta 8), pack - reused 0
Receiving objects: 100 % (57 / 57), 18.79 KiB | 0 bytes / s, done.
Resolving deltas: 100 % (13 / 13), done.
Checking connectivity...done.
Submodule 'pod-library' (git @github.com: jjz / pod - library.git) registered
for path 'pod-library'
Cloning into 'pod-library'...
remote: Counting objects: 34, done.
remote: Compressing objects: 100 % (25 / 25), done.
remote: Total 34(delta 8), reused 30(delta 7), pack - reused 0
Receiving objects: 100 % (34 / 34), 12.95 KiB | 0 bytes / s, done.
Resolving deltas: 100 % (8 / 8), done.
Checking connectivity...done.
Submodule path 'pod-library': checked out '330417cf3fc1d2c
42092 b20506b0d296d90d0b5f '

可以看到 init Submodule 会自动被 clone 下来

  1. 先 clone 父项目,再初始化 Submodule
    执行
git clone git@github.com:jjz/pod-project.gitcd pod-project
git submodule init

会看到

Submodule 'pod-library' (git@github.com:jjz/pod-library.git) 
registered for path 'pod-library'

然后更新 Submodule

git submodule update

看到输出结果为

  Cloning into 'pod-library'...
  remote: Counting objects: 34, done.
  remote: Compressing objects: 100 % (25 / 25), done.
  remote: Total 34(delta 8), reused 30(delta 7), pack - reused 0
  Receiving objects: 100 % (34 / 34), 12.95 KiB | 0 bytes / s, done.
  Resolving deltas: 100 % (8 / 8), done.
  Checking connectivity...done.
  Submodule path 'pod-library': checked out '330417cf3fc1d2c42092b20506b0d296d90d0b5f'

所以,用两种方法都能初始化 Submodule

  • 删除 Submodule
    git 并不支持直接删除 Submodule,需要手动删除对应的文件:
cd pod-project
git rm --cached pod-library
rm -rf pod-library
rm .gitmodules

更改 git 的配置文件 config

vim .git/config

可以看到 Submodule 的配置信息:

[submodule "pod-library"] 
    url = git@github.com:jjz/pod-library.git

删除submodule相关的内容,然后提交到远程服务器

git commit -a -m 'remove pod-library submodule'

Submodule 有在项目开发的过程中有很大的用处,希望文章对大家有帮助。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 使用场景 基于公司的项目会越来越多,常常需要提取一个公共的类库提供给多个项目使用,但是这个library怎么和gi...
    姜家志阅读 18,607评论 1 26
  • git子模块的使用 git子模块可以用于项目包含另一个项目的情况,也许是第三方库或被多个项目引用的基础框架。此次学...
    看似平淡阅读 3,053评论 0 0
  • 写在前面: 1、使用Git Submodule可能遇到的坑(http://blog.devtang.com/201...
    Funnyer阅读 5,849评论 0 0
  • 好几年前脑子里就住进了一个童话 主角是一只 雪白的 放电影的 熊 在森林深处一个祥和的小村中 电影放映员熊君每天负...
    深藏攻与名阅读 296评论 0 1
  • 今天是一个值得纪念的日子,二零一柒年二月二十二日。今天下雪了,是儿子生命中第一场雪。 儿子五岁了,一直以来都欠他一...
    6cb106582cd2阅读 743评论 0 3