Git Pre-Commit Hook-分支结帐不起作用

问题描述

我对Git预提交挂钩有疑问。

我的用例是:当我处于脱机状态时,我想在提交完成之前检出master分支。 master分支的检出需要通过外部工具完成。

要重现该问题,我签出一个提交以进入独立头部状态,然后执行一个提交:

git checkout 8060963376296d7d8286b0f7e37965e526442b4c
echo test >> file25.txt 
git add file25.txt
git commit -m "test commit"

Git显示以下错误消息,并且提交未完成:

fatal: cannot lock ref 'HEAD': is at b302d8f6806dffcb222f95ac10b4371dea6254c6 but expected 8060963376296d7d8286b0f7e37965e526442b4c

提交b302d8f6806dffcb222f95ac10b4371dea6254c6指向master分支。

我的预提交钩子仅包含一行:

exec "c:/temp/hook-test/checkout-branch.bat"

文件checkout-branch.bat也仅包含用于检出master分支的一行:

git checkout master

我的Git版本:

git --version
git version 2.21.0.windows.1

请注意:

  • 如果我直接在预提交挂钩中执行命令“ git checkout master”,则不会发生错误。但是对于我的用例,我必须调用一个外部应用程序
  • 上面的示例已简化-我删除了用于检测分离头模式的处理方法

有人知道如何解决该问题吗?

解决方法

钩子通常在稀缺的环境中运行,在这种环境中不可能一切皆有可能。 1 预先提交的钩子不应尝试更改将要提交的内容,并且不能更改要添加提交的分支。 1 预先提交的钩子 可以终止提交尝试,并且可以向用户打印建议,例如please check out a branch by name first导致提交尝试终止。因此,此处要做的就是检查此状态,进行投诉并使提交尝试失败。


1 即使您找到一些解决方法,通常也不是一个好主意。一种解决方法可能涉及运行其他管道命令,但存在以类似问题的方式混乱正常索引/当前分支链接的危险,该问题是git push通常不会推送到签出的分支。不要这样做!