12

我已经在这几个小时了,虽然我有一种感觉我很接近,但我似乎无法弄清楚这一点。

我正在尝试制作一个脚本,该脚本采用 git 存储库,将该存储库中的子模块更新为指定版本,并提交该更改。

什么有效:

我可以找到存储库,获取子模块并检查我想要的提交。

什么不起作用:

我似乎无法添加更新的子模块哈希,所以我可以提交它。

我的代码:

repos = Repo('path/to/repos')
submodule = repos.submodule('submodule-name')
submodule.module().git.checkout('wanted commit')

diff = repos.index.diff(None)

此时我可以看到子模块更改。如果我检查 sourcetree,我可以在“未暂存的文件”中看到更改的子模块。问题是,我不知道如何进行更改,以便我可以提交。

我试过的:

  • 如果我使用 提交repos.index.commit(''),它会创建一个空提交。
  • 如果我尝试使用添加子模块的路径,则子模块中repos.index.add([submodule.path])的所有文件都将添加到存储库中,这绝对不是我想要的。
  • 如果我尝试使用添加子模块本身(根据文档应该可以)repos.index.add([submodule]),似乎什么都没有发生。
4

1 回答 1

6

有两种方法可以将新的子模块提交添加到父存储库。一种会git直接使用命令,另一种会在纯python中实现。

所有示例均基于问题中提供的代码。

简单的

repos.git.add(submodule.path)
repos.index.commit("updated submodule to 'wanted commit'")

上面的代码将调用git命令,这类似于git add <submodule.path>在 shell 中执行 a。

蟒蛇式

submodule.binsha = submodule.module().head.commit.binsha
repos.index.add([submodule])
repos.index.commit("updated submodule to 'wanted commit'")

IndexFile.add(...)实现添加binsha它在子模块对象中找到的任何内容。这一个将是父存储库的当前提交中的那个,而不是在子模块中签出的提交。可以将Submodule对象视为子模块的单个快照,它不会更改,也不知道对子模块存储库的更改。

binsha在这种情况下,将子模块对象的字段覆盖到其存储库中实际签出的字段似乎最简单,因此将其添加到索引将产生预期的效果。

于 2015-08-08T21:15:42.123 回答