Git 应用补丁报错 “sha1 information is lacking or useless”

因为现场代码在客户局域网内,不能连接到公司网络,所以一般更新的时候都是打补丁, 然后在客户现场应用补丁,但是最近在应用补丁的时候出现了如下问题:

...
fatal: sha1 information is lacking or useless (config.xml).
...

这里使用的 GitExtension 的图形化界面管理版本库,进行补丁的生成和应用, GitExtension 默认使用 3way-merge 来应用补丁,生成和应用补丁的命令如下:

# 生成补丁
> git format-patch -s (commit_id)
# 应用补丁
> git am --3way --signoff 0001.patch

解决办法:

总的来说就是强制应用补丁,手动解决文件问题,然后在继续应用补丁即可

  • 执行 git am --3way --signoff --reject 0001.path 命令应用补丁, 并将补丁中不可应用的部分保存在 *.rej 文件中,例如:以上面的报错信息来说, 就会多出来一个 config.xml.rej 文件来标识不可应用的部分

  • 根据 *.rej 文件修改没有应用完全的文件,我在处理的时候就比较生猛, 直接删除 *.rej 文件,然后将修改后的文件覆盖

  • 然后将需要提交的文件添加到缓存区

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值