您的位置:首页 > 运维架构 > Linux

git问题 warning: LF will be replaced by CRLF in README.md.

2017-05-15 15:44 525 查看
*

问题原因

*:

windows中的换行符为 CRLF, 而在Linux下的换行符为LF,所以在执行add . 时出现提示:warning: LF will be replaced by CRLF in README.md. The file will have its original line endings in ;

设置 core.autocrlf=true 后:检出时,git 会把文本文件的换行符转化为 CRLF(只转化纯 LF 的文件)提交时,把暂存区的内容(也就是我们对工作区做的改动)转化为 LF 然后放入版本库。转化暂存区的内容时,如果发现里面存在 LF 换行符,LF 会被转化成 CRLF,并给出题主提到的那条警告:”LF will be replaced by CRLF”这句警告的下面其实还有一句很重要的话:warning: LF will be replaced by CRLF in .

The file will have its original line endings in your working directory.

(翻译下就是:“在工作区里,这个文件会保持它原本的换行符。”)

简单来说,设置 core.autocrlf=true 后,我们工作区的文件都应该用 CRLF 来换行。如果改动文件时引入了 LF,或者设置 core.autocrlf 之前,工作区已经有 LF 换行符。提交改动时,git 会警告你哪些文件不是纯 CRLF 文件,但 git 不会擅自修改工作区的那些文件,而是对暂存区(我们对工作区的改动)进行修改。也因此,当我们进行 git add 的操作时,只要 git 发现改动的内容里有 LF 换行符,就还会出现这个警告。设置 core.autocrlf=true, 只要保持工作区都是纯 CRLF 文件,编辑器用 CRLF 换行,就不会出现警告了(题主提的问题 2)。git 默认让版本库里用 LF 换行,只要保持这条规则,多人协作就不会出什么大问题。git 的 Windows 客户端基本都会默认设置 core.autocrlf=trueLinux 最好不要设置 core.autocrlf,因为这个配置算是为 Windows 平台定制。如果 Windows 上设置 core.autocrlf=false,仓库里也没有配置 .gitattributes,很容易引入 CRLF 或者混合换行符(Mixed Line Endings,一个文件里既有 LF 又有CRLF)到版本库,这样就可能产生各种奇怪的问题(题主提的问题 1)。如果有换行符不匹配本地平台的情况,我还是建议你用 dos2unix 之类的工具转换下换行符,因为很多配置文件是严格要求文件编码和换行符的,谨慎一点比较好。

https://www.zhihu.com/question/50862500/answer/123197258

**

最佳解决方案

**

1)、直接设置core.autocrlf=false;

除了记事本编辑不可以,其他都可以

rm -rf .git // 删除.git

git config –global core.autocrlf false //禁用自动转换

2)、忽略
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  git linux 编辑器