1、背景

这两天在维护公司一个老旧项目,编译是用bat批处理+python实现的,但是把最新的代码拉下来后发现编译不过去,提示bat指令有错误,并且是很离谱的错误,但是回退到之间的稳定版本,命令行编译是没有任何问题的,经过两天N多次试错失败后终于发现了一些端倪:最新的代码文件都是LF(line feed)的回车换行方式,但是我在windows下开发,应该是CRLF(carriagereturnlinefeed)的换行方式,反推查看之前稳定版本的换行格式都是CRLF,猜测应该是换行模式导致的编译问题。

问:LFCRLF是什么?

  • 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模式,重新拉取代码,编译通过!

文章目录