git自动转换换行符问题

在git上传、更新或者新增文件时会处理文本文件的换行符号。换行符在windows中默认为CRLF即"\r\n",在linux中为LF即"\n"。如果不特殊配置如果仓库的文件换行符为LF,下载到windows会变成CRLF,下载到linux上还是LF。上传时windows环境的CRLF会转换成LF后上传。一般使用也没什么问题。在使用maven的openapi-generator-maven-plugin插件生成openAPI定义文件的代码的时候,生成的文件换行符为LF。有时定义文件只改了一个接口,在重新生成接口代码时,虽然文本内容只改动了一个文件,但是在提交时会显示所有文件都修改了,而其他文件只是换行符号不一致。这里本来就只需要对比确认一个文件的差异,但现在显示有差异的文件有几十个。这在代码提交时就大大的增加了比对的工作量。

有两种解决方案,一个时让maven插件生成的代码使用CRLF换行,一个是使git将文本换行符设置为LF。

前一种没有找到maven插件有这种设置的参数。git有设置换行符的参数,设置方式有多种。这里只需要设置特定目录下的文本换行符,在这个目录下增加.gitattributes文件。

复制代码
*.java text eol=lf
复制代码
上述参数设置意思是java类型文件按文本文件处理,文本换行符为lf。设置之后重新启动idea,文件的换行符号变成了lf,然后插件重新生成代码,此时git对比就只显示有内容产生变动的文件。
相关推荐
EleganceJiaBao1 天前
【Git】Git reset 完整指南:真正理解 HEAD、暂存区与工作区
git·github·reset
我最爱吃鱼香茄子1 天前
【保姆级】Git配置用户名和邮箱(全局/局部)解决提交记录不识别、贡献图不亮问题
git·gitee·github·小白教程·git配置·程序员开发工具
weixin_571667411 天前
git fork 并建立自己的dev分支 保持与源仓库的联系
git
master3361 天前
git仓库通过脚本完成多个远程仓库同步
大数据·git·elasticsearch
用什么都重名1 天前
Git 合并两个无共同历史的分支:从报错到解决全记录
git·gitlab
2601_961875241 天前
花生十三资料网盘|百度云|下载
数据库·windows·git·svn·eclipse·github
小香猪66881 天前
Git 日常操作完全指南:提交、冲突、分支、账户配置一站式教程
git
OsDepK2 天前
移动编程OSMDE随时命令行进行Git
ide·git
小李不困还能学2 天前
用git GUI往远程仓库中添加文件/文件夹
git