Merged commit is not allowed to push to current repository due to the repository‘s setting问题

最近一个月才开始使用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/分支名

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值