如何解决是否可以使git子模块仅允许更新具有标签的提交?
我有一个项目,在该项目上,我可以强制自己标记和“释放”子模块,然后才能允许父级更新。有时,我忘记了,不得不追溯地这样做。我想知道是否有一种方法可以强制执行一个规则,即子模块只能更新为已在子调制回购中标记的提交?
解决方法
没有直接在子模块本身中进行操作的好方法(尽管您可以编写自己的Git钩子来帮助您在子模块中进行任何工作时提醒您)。但是您可以编写预提交脚本,以提醒您何时在 superproject 中进行新提交。
在预提交挂钩中,您将:
- 将当前提交(
HEAD
)与建议的新提交(索引内容)进行比较; - 查看是否有任何更改涉及 gitlink 条目:索引条目,其
mode
为160000
(即gitlink); - 如果是,请检查相应的子模块:测试超级项目索引中的提交哈希是否对应于该子模块中的标记提交。
要比较current-commit-vs-index,请运行:
git diff-index --cached HEAD
产生类似于以下内容的输出:
:100644 100644 ee6fb78cd4a415358558373f176e2bbb7e5e603f 3e4b8b8874e67bda27ebee646c97989e0aa98c5e M Vagrantfile
:100644 100644 b7ad08494ad84d9d816b7d84f4e75ddf9a6549a2 e12f4afad5e59623b3cf07af459cb1f096c14c25 M defaults.yml
:100644 100644 9e69570de9caa3e8f1979d9fcf8ad8ddf3992291 c28dd95ca0a7033a224a35302c6ccbbf1612c3a3 M dev.yml
:100644 100644 e3588c8e7fc19f075f0f83a5e3df3e71e4ee9152 6655fa801bcf442a1b8b8b1a269391cb0807d0bd M local.yml
对于每行具有:160000 160000
的行(以上各行均不行),旧的哈希在左侧,新的哈希在右侧,因此您可以通过{{1} }或使用Python脚本查找有趣的条目。请注意,文件名与该行的其余部分之间用制表符分隔(出于发布目的,请扩展到上面的空格),如果您使用的是Python或类似的工具,则可能需要将awk
添加到{{ 1}}命令,以使输出更易于机器读取。有关详细信息,请参见the documentation。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。