今天用在记得电脑提交代码,发现在push的时候
git push origin xxx:refs/for/xxx
提示错误,错误信息如下:
remote: Resolving deltas: 100% (6/6)
remote: Counting objects: 42105, done
remote: Processing changes: refs: 1, done
remote: ERROR: [xxx] missing Change-Id in commit message footer
remote:
remote: Hint: To automatically insert Change-Id, install the hook:
remote: gitdir=$(git rev-parse --git-dir); scp -p -P xxx
remote: And then amend the commit:
remote: git commit --amend
remote:
To ssh:xxx
! [remote rejected] xxx -> refs/for/xxx ([xxxxx] missing Change-Id in commit message footer)
error: failed to push some refs to 'ssh://xxx'
其中关键信息:missing Change-Id in commit message footer
有点懵,不过顺着他的提示可以看到是缺少了commit-msg文件。自己偶然用自己的电脑,确实是忘记添加该文件了。
怎么办呢?可以自己生成一个,怎么生成呢?他的提示都告诉你了,直接按照他的提示来:
输入命令
gitdir=$(git rev-parse --git-dir); scp -p -P xxx
然后就会自动生成commit-msg文件了,可以自己用命令行看(ls .git/hooks/commit-msg),或者去文件夹里面看(在项目的.git文件夹的hooks里面)
之后接着按照他的提示输入命令:
git commit --amend
这样就补全了Change-Id了,可以通过命令查看提交信息
git log
或者不用查看直接push即可