前言

简单清晰的代码结构有利于项目代码的管理。OneOS-Lite使用git submodule的方式来进行代码的管理。

其中,OneOS-Lite仓库为主存储库。而内核kernel,以及组件components和驱动drivers都将作为子模块的形式和OneOS-Lite主仓库关联管理。

检索子模块

该命令git submodule可以查看主仓库中,已有的子模块或子仓库。

$ git submodule
-ba2c4170016ff14db298c5e87134704996c5aff5 thirdparty/cJSON
-e99c7b71349f74804eb215c59fa426bf5a357d8f thirdparty/telnetd

拿以上举例:

  • -代表该子模块仓库源码文件还未检入(空文件夹),没有-代表已检入;
  • e99c7b71349f74804eb215c59fa426bf5a357d8f代表该子模块组件和OneOS-Lite所关联的版本id;
  • thirdparty/telnetd代表该子模块仓库对应的目录和其组件名称。

获取子模块

使用git clone是不会把子模块仓库源码文件检入的,只会把拉取下来对应子模块组件的空文件夹。这时,如果需要使用某个子模块组件,可以使用以下命令:

git submodule init
git submodule update xxx(子模块组件名,可通过git submodule查看已有的贡献组件)

举个栗子:

$ git submodule init
Submodule 'thirdparty/cJSON' ([email protected]:luoshunyuan/cJSON.git) registered for path 'thirdparty/cJSON'
Submodule 'thirdparty/telnetd' ([email protected]:luoshunyuan/telnetd.git) registered for path 'thirdparty/telnetd'
$ git submodule update thirdparty/telnetd
Cloning into 'D:/xiaoneng/oneos-2.0-test/thirdparty/telnetd'...
Authorized users only. All activity may be monitored and reported.
Submodule path 'thirdparty/telnetd': checked out 'e99c7b71349f74804eb215c59fa426bf5a357d8f'

如果需要获取所有子模块仓库,可以直接使用git submodule update

关联子模块

通过项目根目录下的一个.gitmodules文件,可以发现已经关联的子仓库,每添加一个子模块仓库就会新增一条记录。内容如下:

[submodule "thirdparty/telnetd"]
    path = thirdparty/telnetd
    url = [email protected]:luoshunyuan/telnetd.git
[submodule "thirdparty/cJSON"]
    path = cJSON
    url = [email protected]:luoshunyuan/cJSON.git

继续关联新的子模块可以使用如下git命令,这里以telnetd为例:

git submodule add [email protected]:luoshunyuan/telnetd.git thirdparty/telnetd

如果需要更改子仓库,可先在对应的子仓库目录中,打开git命令行,进入对应贡献组件的git仓库管理,并执行代码提交操作:

因为修改了子模块仓库代码并提交了,但是主仓库的指针依旧指向那个老的子仓库的commit id,如果不提交这个修改的话,别人拉取主项目并且使用git submodule update更新子模块还是会拉取到修改前的代码。

因此,这时候需要把主项目进行提交更新。

删除废弃组件

当某些子仓库不需要了,需要废弃,删除的时候,git没有直接删除子模块的命令,所以只能逐步删除相关文件:

  1. 在版本控制中删除子模块:

    git rm -r thirdparty/cJSON

  2. 在编辑器中删除.gitmodules相关内容:

    [submodule "thirdparty/cJSON"]
        path = thirdparty/cJSON
        url = [email protected]:luoshunyuan/cJSON.git
  3. 在编辑器中删除.git/config相关内容:

    [submodule "thirdparty/cJSON"]
        url = [email protected]:luoshunyuan/cJSON.git
        active = true
  4. 删除.git下的缓存模块:

    rm -rf .git/modules/thirdparty/cJSON
  5. 提交修改:

    git commit -am "delete submodule"
    git push

关注&&联系

gitee: https://gitee.com/cmcc-oneos/OneOS-Lite

docs: https://oneos-lite.com/

公众号:CMCC-OneOS

03-05 23:22