现在的情况是这样的。我有一个包含多个子模块的git存储库。顶级目录和所有子模块都包含Visual Studio 2010解决方案。
顶层存储库依赖于子模块是最新的,子模块每次更新时都需要重新构建。因为有任意数量的子模块,所以我想要做的是在git中创建某种更新后钩子来编译刚刚更新的子模块。
所以我的问题是:更新子模块时会调用什么钩子(如果有的话)?看起来结账后可能是我想要的,但我不确定。
我们正在使用TortoiseGit和Git for Windows(msysgit)作为后端,如果这会有所不同的话。
发布于 2011-05-01 20:05:06
这应该可以作为 parent repo上的post-update hook
您需要监视.gitmodules文件中的任何更改,以便检测该文件中的任何更改(表明父存储库的另一个克隆已经更改子模块并在父存储库中提交了新的引用)。
然后,您可以:
如果您想要使您的子模块保持最新,请检测哪些子模块具有changed
但这假设父存储库的克隆已被修改为引用您的子模块的新提交。
如果您的子模块是独立于任何父存储库进行更新的,那么在父存储库的签出/更新时,相同的post-update挂钩(仍然在父存储库上)需要:
如果您想要使子模块保持最新,请在每个子模块中执行fetch
(即已更改)的更改的新SHA1
您可以在每个子模块上设置更新后挂钩,但当您在父存储库中添加或删除子模块时,上述方法的伸缩性更好,因为它将检测过程集中在一个地方(父存储库的post-update挂钩)。
https://stackoverflow.com/questions/5847195
复制相似问题