ToB企服应用市场:ToB评测及商务社交产业平台

标题: Git 子模块 [打印本页]

作者: 莫张周刘王    时间: 2023-6-28 23:42
标题: Git 子模块
1 概览

使用 Git 管理源代码,进行子模块操作时,此文可作为参考(Lookup Cheat-Sheet)
2 何时使用 submodules

合适的场景:
与其使用 submodules,不如使用 subtrees 的场景:
SubmodulesSubtrees更复杂 (尤其对初学者)更简单另一个仓储的一个提交引用链接代码提交会合并到器皿项目的提交历史中能够单独被访问(存在于中心服务器中的独立仓储)去中心化(直接通过器皿项目访问)需要更多的步骤来操作克隆,拉取,推送都与之前相同(当然也有针对子树的命令)不占用器皿项目仓储大小直接占用器皿项目仓储容量3 使用技巧及规范

3.1 为仓储添加和配置子模块
  1. # 添加子模块并跟踪名称为 branch_name 的分支,不加 -b 将会对后续子模块的跟踪产生影响
  2. git submodule add -b branch_name URL_to_Git_repo optional_directory_path
复制代码
3.1.1 一般原则

注:除了直接用文本编辑器修改 .gitmodules 文件以外,还可以通过命令进行修改(参考如下示例)。
  1. # 查看现有的 submodule 属性
  2. git config --file=.gitmodules -l
  3. # 修改 submodule 属性
  4. git config --file=.gitmodules submodule.modulename.branch branch_name
  5. git config --file=.gitmodules submodule.modulename.path path/to/submodule
  6. git config --file=.gitmodules submodule.modulename.url URL_to_Git_repo
复制代码
3.2 从一个已经设置好子模块的仓储获取子模块
  1. # 克隆仓储时,同时克隆仓储的子模块,相当于进行了子模块的初始化和更新
  2. git clone --recursive URL_to_Git_repo
复制代码
  1. # 克隆仓储后,初始化并更新子模块,子模块就会引用子模块仓储默认分支下最新一次提交
  2. git submodule update --init
复制代码
  1. # 子模块设置变更、子模块变更(新增、更名、删除等)
  2. git pull
  3. git submodule sync
  4. git submodule update --init
复制代码
3.2.1 对子模块仓储直接进行代码编写
  1. # 签出分支,使子模块具备拉取最新修改并直接连通父仓储推送的能力
  2. git submodule foreach "git checkout $(git config -f $toplevel/.gitmodules submodule.$name.branch || echo main)"
复制代码
  1. # 子模块远程有更新,需要获取。以下命令等同于进入子模块目录执行 `git pull`。如果本地有未提交的修改,均需要合并操作,有冲突无法合并则获取会失败。
  2. git submodule update --remote --merge
复制代码
  1. # 推送代码到远程分支
  2. git push --recurse-submodules=on-demand
复制代码
3.2.2 不更改子模块代码

使用 detached HEAD,子模块链接的是提交 commit 的哈希值 hash。无法拉取或提交代码,只能通过更新仓储的子模块版本,再通过 git submodule update 命令更新子模块。
3.3 删除已有子模块
  1. # 从 .git/config 中删除子模块
  2. git submodule deinit -f path/to/submodule
  3. # 从器皿项目(父项目)的 .git/modules 目录中删除子模块文件夹
  4. rm -rf .git/modules/path/to/submodule
  5. # 从 .gitmodules 中去掉子模块入口并删除子模块所在物理路径 path/to/submodule 下的所有文件
  6. git rm -f path/to/submodule
复制代码
3.4 常用命令解析
  1. # 为所有子模块执行 git 命令,-q 参数静默模式,--recursive 循环操作所有子模块(包括子模块的子模块引用)
  2. git submodule foreach "git command"
复制代码
  1. # 更新子模块
  2. # --remote 从子模块远程分支更新(最新),不加此参数则从父仓储的子模块版本链接更新(对应提交哈希值)
  3. # --recursive 循环操作所有子模块(包括子模块的子模块引用)
  4. # --merge,合并远程分支的修改,有冲突需要解决冲突。不会 detach HEAD。
  5. # --rebase,撤销本地提交,临时保存并保留本地修改,应用远程修改,再将本地修改合并,合并时同样需要解决冲突。不会 detach HEAD。
  6. git submodule update
复制代码
注:对于 --remote 而言
3.5 常用 git 设置(推荐进行配置)

  1. # 查看现有 git 设置
  2. git config --global -l
  3. # 修改现有 git 设置
  4. git config --global status.submoduleSummary true
  5. git config --global diff.submodule log
  6. git config --global alias.spush "push --recurse-submodules=on-demand"
复制代码
  1. [status]
  2.         submoduleSummary = true
复制代码
  1. [diff]
  2.         submodule = log
复制代码
  1. [alias]
  2.         sdiff = "!git diff && git submodule foreach 'git diff'"
  3.         spull = "!git pull && git submodule sync && git submodule update --init"
  4.         smerge = "submodule update --remote --merge"
  5.         srebase = "submodule update --remote --rebase"
  6.         scheckout = "submodule foreach 'git checkout $(git config -f $toplevel/.gitmodules submodule.$name.branch || echo main) && git pull'"
  7.         spush = "push --recurse-submodules=on-demand"
复制代码
4 参考链接


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4