git

.gitattributes

功能:识别为文本或二进制、文本文件换行符转换、合并策略、差异显示等

文本与二进制

Git 对文本与二进制文件的处理是不同:

  • 文本文件会显示出修改的差异,并且在合并时会按照行进行合并
  • 二进制文件不显示修改的差异,在合并时会提示文件冲突,需要人工介入

Git 内部会自动根据扩展名识别文本与二进制文件,但是一些文本文件是由机器产生的,Git 会将其视作文本文件而自动进行合并,这会导致文件损坏,并且这种情况很难察觉

推荐将所有文件取消文本属性,然后根据项目的需要将部分文件开启文本属性

1
2
3
* -text

Assets/*.java text

换行符转换

Git 默认会对文本文件进行换行符转换,默认情况下在提交时转换为 LF,检出时根据当前平台转换为 LF 或 CRLF。建议 Git 仓库有自己独立的设置,不受 Git 全局配置的影响,否则文件的内容在不同的机器上会出现不同

比如 统一设置 C# 文件换行符为 Windows 换行符 CRLF

1
Assets/*.cs text eol=crlf

模板

gitignore.io

gitattributes.io