问题描述
我在github远程创建了一个repository,然后在机器上新建一个文件夹,然后使用Git bash ,执行命令 git init
后,又创建了一个 gh-pages
分支,把别人的模板文件拷贝的这个仓库中,然后执行 git add -A
,结果Git bash 提示信息:warning: LF will be replaced by CRLF
、
原因分析
原因应该是我在Windows环境对文件进行操作,而我拷贝的文件原作者应该是在Linux系统是进行编辑的,因此导致此情况的发生,下面是官方的说明[点击这里看原文]:
格式化与空白是许多开发人员在协作时,特别是在跨平台情况下,遇到的令人头疼的细小问题。由于编辑器的不同或者Windows程序员在跨平台项目中的文件行尾加入了回车换行符,一些细微的空格变化会不经意地进入大家合作的工作或提交的补丁中。不用怕,Git 的一些配置选项会帮助你解决这些问题。
假如你正在Windows上写程序,又或者你正在和其他人合作,他们在Windows上编程,而你却在其他系统上,在这些情况下,你可能会遇到行尾结束符问题。这是因为Windows使用回车和换行两个字符来结束一行,而Mac和Linux只使用换行一个字符。虽然这是小问题,但它会极大地扰乱跨平台协作。
Git可以在你提交时自动地把行结束符CRLF转换成LF,而在签出代码时把LF转换成CRLF。用core.autocrlf
来打开此项功能,如果是在Windows系统上,把它设置成true,这样当签出代码时,LF会被转换成CRLF:
$ git config --global core.autocrlf true
Linux或Mac系统使用LF作为行结束符,因此你不想 Git 在签出文件时进行自动的转换;当一个以CRLF为行结束符的文件不小心被引入时你肯定想进行修正,把core.autocrlf
设置成input来告诉 Git 在提交时把CRLF转换成LF,签出时不转换:
$ git config --global core.autocrlf input
这样会在Windows系统上的签出文件中保留CRLF,会在Mac和Linux系统上,包括仓库中保留LF。
如果你是Windows程序员,且正在开发仅运行在Windows上的项目,可以设置false取消此功能,把回车符记录在库中:
$ git config --global core.autocrlf false
解决方案
由于我使用别的人模板文件是在Linux系统编辑的,Linux系统使用LF作为换行符,我只能将就把 core.autocrlf
设置成false
,这样才不会有警告,但是如果开始就在Windows上进行开发,应该将它设置成true
才对
参考资料