git项目换行符LF与CRLF不同导致的更新问题
转载自jiayaoO3O's Blog。
遇到的问题
在windows中git clone一个代码仓库,拷贝到ubuntu环境下,出现了所有文件都被git记录已更改的问题,但肉眼看不出来文件不同。
原因是windows中默认换行用的CRLF(回车+换行),而linux环境下默认用的LF(换行),于是所有文件都被标注被更改。
解决方法
git有一个autocrlf配置,可以在我们提交时自动转换换行符,它有3个选项:
- true: 提交时转换为 LF,检出时转换为 CRLF
- false: 提交检出均不转换
- input: 提交时转换为LF,检出时不转换
另一个设置项safecrlf用于检查文件是否包含着混合换行符,也有3个选项:
- true: 拒绝提交包含混合换行符的文件
- false: 允许提交包含混合换行符的文件
- warn: 提交包含混合换行符的文件时给出警告
所以,如果我们要将已经加入git的大量CRLF结尾文件批量转换成LF结尾的文件,可以这样设置:
git config --global core.autocrlf input
git config --global core.safecrlf warn
这样设置之后,先将项目提交一次,这样所有的文件就都会被改成LF结尾.