记录一个困扰两天的问题:git 换行符LF与CRLF转换问题
1、背景
这两天在维护公司一个老旧项目,编译是用bat批处理+python实现的,但是把最新的代码拉下来后发现编译不过去,提示bat指令有错误,并且是很离谱的错误,但是回退到之间的稳定版本,命令行编译是没有任何问题的,经过两天N多次试错失败后终于发现了一些端倪:最新的代码文件都是LF(line feed)的回车换行方式,但是我在windows下开发,应该是CRLF(carriagereturnlinefeed)的换行方式,反推查看之前稳定版本的换行格式都是CRLF,猜测应该是换行模式导致的编译问题。
问:LF和CRLF是什么?
- LF:"\n",Linux的换行符;
- CRLF:"\r\n",Windows的换行符。
2、解决方案
Git关于换行模式的设置如下
git config --global core.autocrlf false
git config --global core.safecrlf true
含义:
AutoCRLF
提交时转换为LF,检出时转换为CRLF
git config --global core.autocrlf true
提交时转换为LF,检出时不转换
git config --global core.autocrlf input
提交检出均不转换
git config --global core.autocrlf false
SafeCRLF
拒绝提交包含混合换行符的文件
git config --global core.safecrlf true
允许提交包含混合换行符的文件
git config --global core.safecrlf false
提交包含混合换行符的文件时给出警告
git config --global core.safecrlf warn
3、结果
git设定为拉取代码时强制转换为windows下的crlf模式,重新拉取代码,编译通过!
本作品采用 知识共享署名-相同方式共享 4.0 国际许可协议 进行许可。