最近一个月才开始使用Git,遇到了一些问题,正好做个记录,和大家分享一下。
在通过git push origin HEAD:refs/for/分支名 提交review代码时,遇到以下报错:
Merged commit is not allowed to push to current repository due to the repository's setting。
这句话的意思是:远端仓库的一些设置,不允许直接merge commit的代码。所谓的merge commit,指的就是在使用merge命令时,实际上是同时也帮你进行了commit了,有的代码仓库不允许直接提交这种方式的commit。
解决办法是:
1、使用git reset丢弃掉本次的merge,再次merge时,使用git merge --squash命令进行merge(--squash选项表示仅进行文件的合并,不commit,这样的merge其实就相当于对文件直接进行增删改查的操作,而不commit)。merge之后,再使用git commit -m "日志" 命令提交当前修改,然后再git push origin HEAD:refs/for/分支名即可。
2、如果不想reset,也可以创建一个本地分支跟踪远程分支:
git checkout -b test origin/要合并的目标远程分支名
然后再执行git merge --squash命令
然后在git commit -m "日志"
最后git push origin HEAD:refs/for/分支名