在依靠库的办理上,每种编程言语都会有自己独特的包办理机制,例如golang的mod办理。
其实还有一种更通用的,与言语无关的办理方式——git submodule 子模块办理。
这儿假设项目D,为其它多项目 项目A、项目B等所依靠,则可以使用git submodule来完成项目A、项目B对项目D的依靠办理,完成如下关系图:
创立子模块依靠
为项目创立子模块,只需一条简略指令。例如,为项目A增加项目D子模块:
git submodule add <项目D git 库房地址> <项目A映射子目录>
设置子模块依靠版别
子模块作为一个独立项目,其版别办理也是独立的。项目A最终依靠于项目D的某一个版别,要完成版别绑定,可以按如下步骤操作:
cd <项目A映射子目录>
git checkout <commit hash 1>
cd <项目A目录>
git add <项目A映射子目录>
git commit <...>
通过如上的绑定,项目A 就绑定了 项目Dcommit hash 1
这个版别。
删去子模块依靠
有时候,项目改变,或许需要免除子模块的绑定,例如要删去 项目A 对项目D的子模块依靠,可以依照如下步骤操作:
git rm --cached <项目A映射子模块>
rm -rf <项目A映射子模块>
vi .gitmodules # 删去.gitmodules中关于项目D的子模块描绘项
vim .git/config # 删去.git/config中关于项目D的子模块描绘项
rm -rf .git/module/<项目A映射子模块>
如此即可以完全删去 项目A中的项目D相关的子模块依靠信息。
总结
git submodule完成项目依靠如此简略,以至于小编在项目中,不由得很多使用,特别是私库的依靠办理。
希望我们也能测验,亲自领会它简略的设计思路和丝滑用法。