git多平台换行设置引起的问题
来源:互联网 发布:话费好帮手软件 编辑:程序博客网 时间:2024/05/29 03:04
今天碰到一个git的问题,在windows下用msysgit,总是提醒有文件修改,需要add to index。但是用git diff查看,没有特别的不同,只是显示整个文件都被修改。于是用git checkout -- <file>试图放弃本地修改,但是不起作用,还是提示文件修改过。
以前也看过类似的文章,怀疑是windows下换行符引起的问题。用ultraedit查看文件的二进制编码,发现本地文件的换行符为0D0A,这个格式是windows的回车+换行。登录到linux机器查看相同的文件,发现linux机器上的相同文件换行符为0A。基本上可以认为是换行符引起的问题。
原来,git有一个很重要的属性设置
git config --get core.autocrlf
这个属性如果设置为true,在执行git checkout/merge操作时会自动的将换行符从0A(lf)变成0D0A(crlf),而进行add/commit时则相反;
我的msysgit里面core.autocrlf的设置为true。每次git checkout都会先换成index里面的版本(0A换行),然后由于设置了core.autocrlf=true又会快速的切换成0D0A。于是就有了总是提示文件修改的故事。
解决办法
git config --set core.autocrlf false
实际上,git本身首先会看git repo里面的.gitattributes设置,例如下面的设置会自动的对java文件进行换行符转换。(crlf->lf)
*.java text=auto
其次才会看core.autocrlf设置。所以最好在git code repo里面设置一下
* text=auto*.c text*.h text*.sln text eol=crlf*.png binary*.jpg binary
小结一下:
text 告诉git该文件是text,怎么处理要看eol设置(for 单独文件类型),或者core.eol设置(for 所有文件),以及其他设置选项。
text=auto 告诉git自动的进程换行符转换,git会自动判断文件是否是text文件类型。
[text] eol=crlf 告诉git对该类型文件进行换行符转换,转成crlf。
[text] eol=lf 告诉git对该类型文件进程换行符转换,转成lf
binary 告诉git对该类型文件不要进行换行符转换.
如果什么也没设置,看客户端core.autocrlf设置。
- git多平台换行设置引起的问题
- HTML代码换行引起的空格问题
- windows下Git的换行符设置
- JDK版本引起的问题及设置
- rabbitMq设置引起的生产问题
- ARM平台 结构体字节对齐引起的一个问题
- 2017 git的学习笔记之设置(忽略换行 权限)
- git在双xcode中使用可能引起的问题
- 多操作系统平台协同开发时 GIT 的注意事项: 不同操作系统中的换行符(不要使用git的换行符自动转换功能,并且,尽可能保证代码的换行符都是unix); 避免使用第三方插件(如 EGit );
- [转]多操作系统平台协同开发时 GIT 的注意事项: 不同操作系统中的换行符(不要使用git的换行符自动转换功能,并且,尽可能保证代码的换行符都是unix); 避免使用第三方插件(如 EGit );
- 2015-1-15_git引起的unix和windows的换行符问题
- 由Flex页面TextArea控件中回车换行引起的问题
- python与java文件处理中“换行符”引起的小问题
- 由“回车换行”引起的“空格”
- 一个换行符引起的死亡场景
- html代码换行引起的空格
- Git处理换行符问题
- 解决Java跨平台使用换行符的问题
- MFC Windows应用程序设计——学习笔记【1】
- list.h 简单运用
- Linux进程间通信——使用共享内存
- python爬虫
- 我也说说ThreadLocal
- git多平台换行设置引起的问题
- 32字产品口诀
- smail语法简析(2)
- STL 队列
- java进阶(三):反射(3)——数组的反射与集合的运用(ArrayList、HashSet)
- Python脚本实现文件内容替换
- 数据透视表Excel入门
- cocos2dx-3.0 中的物理引擎Box2D使用(四)
- unity 鼠标拖动物体移动