git rerere does not auto-commit autoupdated merge resolutions

五迷三道 提交于 2019-11-28 21:32:52

Even with the --rerere-autoupdate flag, git merge seems to be reluctant to automatically complete the merge without some human input. This being the case, it executes with an error status, and your integration tool refuses to proceed.

I do not know how your automatic merging is happening, namely, if you can change the git command that is executed. If you can, then you can execute the following commands.

git merge --no-ff branch-to-merge --rerere-autoupdate
if [[ $(git rerere diff) ]]
then
    git commit --no-edit
else
    $(exit 1)
fi
  • git rerere diff list files that need to be resolved after rerere
  • --no-edit is necessary to prevent opening the commit message editor
  • In case rerere was not able to cleanly merge all changes this statement will still execute with an error status, and the merge will not be committed.
    • The commit message will still contain the conflicting files
  • exit 1 needs to be inside $() unless you want to exit your shell (guess how I know this :-))
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!