许久前还不太会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文件设置里没有这一项啊,导致拉出的时候它不会改啊,得,难怪拉出去的内容被整行认定为不是一个内容,关键就在于换行符不同。