Git实战遇到的坑之一:库与库合并被自动转换换行符摆了一道

许久前还不太会Github的时候,自己做了了一个库,引用了别人的代码并修改,最近打算把那位作者最新的代码拿来和自己合并一样,因为当初不是fork这位作者的库,所以有点麻烦,google了半天,发现git原来有可以给自己加多个远程库然后再合并的招数,立马尝试,结果到合并的时候傻眼了,明明是文本文档,但是git根本没法识别其中相同的内容和不同的内容,而是整理的认为他们就是不同的内容。这还合并个鬼,百思不得其解下,自己做实验发现建了两个库,用同样的方式,合并的很正常啊,为啥就是那位作者的库就是没法和捏?于是逐步定位。终于发现要害在于那位作者的库里的.gitattributes文件有这么一个设置

*        text=auto

在git文档 https://www.kernel.org/pub/software/scm/git/docs/gitattributes.html 里有这么个描述

When text is set to "auto", the path is marked for automatic end-of-line normalization. If Git decides that the content is text, its line endings are normalized to LF on checkin

也就是说如果设置了这个选项,你提交的所有被Git认为是文本的文件,都会把结尾符转换层LF再给你签入。


这个选项在签入时给你改成LF,迁出的时候会给你改回来。但是。。。但是我自己的那个库里的gitattributes文件设置里没有这一项啊,导致拉出的时候它不会改啊,得,难怪拉出去的内容被整行认定为不是一个内容,关键就在于换行符不同。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值