中label换行问题_如何巧妙处理 Git 多平台换行符问题(LF or CRLF)
选自《旷世的忧伤》
作者:旷修
http://blog.konghy.cn/2017/03/19/git-lf-or-crlf/
禁止二次转载
自从工作以后,基本上没有接触过 Windows 系统,偶尔使用 Windows 也是因为要写文档,Linux 下勉强可以用 WPS Office,但是格式与同事的不兼容,也算是迫不得已。而对我自己来说,大部分的文档都用 Mardown 来搞定。在很长一段时间里,我是很鄙视 Windows 的。
使用 Windows 系统时的诸多体验是让人讨厌的。感觉其大部分软件都很笨重,软件装得多了,磁盘就不够用了。不喜欢安装一个软件时捆绑安装一大堆无用的软件。不喜欢一些软件时不时的广告弹窗。
一些人说,玩 Linux 大部分时间都花在了折腾上,是的,的确是这样。首先是,Linux 的桌面不尽如人意,但它也可以很漂亮。Linux 是可以做高度定制的,从桌面环境到应用软件。我会经常尝试使用不同的发行版本,每重装、升级一次系统都要换上自己喜欢的桌面(做一堆的美化),配置 shell 环境,装上自己常用的软件,卸载掉一些不用的软件。有时候还会把系统玩蹦,然后一切都得重来一遍。而之前用 Windows 的时候,我也喜欢折腾,要找一个漂亮的主题换上,要把部分特殊目录的图标改了,等等。反正,我是有些强迫症的。
使用计算机的人,对操作系统的选择,大部分的原因还是源于习惯和需求。前段时间,由于工作上的需要,要在 Windows 上做一些工作。用过 Linux,也用过 Mac OSX 后,再回归 Windows,感觉我已经不再排斥。或许是因为生活阅历、工作经验、年轮等的增长消磨了内心的一些偏激,让一些东西变得不再重要,更加懂得去包容。
目前,在开发中,使用 Git 作为版本管理工具还是比较流行的,大量的开源项目都在往 Github 迁移。Windows 上有 Git bash 客户端,基于 MinGW,有很多 GNU 工具可用,体验还不错。
在做完工作后,我尝试 git add .
,想着这块工作可以告一段落了,而事实是:
$ git add .fatal: CRLF would be replaced by LF ...
一脸懵逼,Google 一下吧,看看是什么原因。发现,这已经是一个非常经典的问题了:
早就听说过这个问题,总算是亲自踩到这个坑里了。
文本文件所使用的换行符,在不同的系统平台上是不一样的。UNIX/Linux 使用的是 0x0A(LF)
,早期的 Mac OS 使用的是 0x0D(CR)
,后来的 OS X 在更换内核后与 UNIX 保持一致了。但 DOS/Windows 一直使用 0x0D0A(CRLF)
作为换行符。
跨平台协作开发是常有的,不统一的换行符确实对跨平台的文件交换带来了麻烦。最大的问题是,在不同平台上,换行符发生改变时,Git 会认为整个文件被修改,这就造成我们没法 diff
,不能正确反映本次的修改。还好 Git 在设计时就考虑了这一点,其提供了一个 autocrlf
的配置项,用于在提交和检出时自动转换换行符,该配置有三个可选项:
•true: 提交时转换为 LF,检出时转换为 CRLF•false: 提交检出均不转换•input: 提交时转换为LF,检出时不转换
用如下命令即可完成配置:
# 提交时转换为LF,检出时转换为CRLFgit config --global core.autocrlf true# 提交时转换为LF,检出时不转换git config --global core.autocrlf input# 提交检出均不转换git config --global core.autocrlf false
如果把 autocrlf 设置为 false 时,那另一个配置项 safecrlf
最好设置为 ture。该选项用于检查文件是否包含混合换行符,其有三个可选项:
•true: 拒绝提交包含混合换行符的文件•false: 允许提交包含混合换行符的文件•warn: 提交包含混合换行符的文件时给出警告
配置方法:
# 拒绝提交包含混合换行符的文件$ git config --global core.safecrlf true# 允许提交包含混合换行符的文件$ git config --global core.safecrlf false# 提交包含混合换行符的文件时给出警告$ git config --global core.safecrlf warn
到此,还并未解决我遇到的问题。实际上,我们有两种办法解决。
一种是将配置项改为如下的形式:
$ git config --global core.autocrlf false$ git config --global core.safecrlf false
这种方式是不推荐的,虽然代码能被提交,但是项目中的文件可能会包含两种格式的换行符。而且会有如上提到的问题,文件被视为整个被修改,无法 diff,之所以使用版本控制工具,最重要的原因之一就是其 diff 功能。
另一种办法是,手动将文件的换行符转化为 LF,这可以通过编辑器来完成,大部分编辑器都可以将文件的换行符风格设置为 unix 的形式。也可以使用 dos2unix
转换工具来完成,Windows 上 Git bash 客户端自带了该工具。其他系统上也可以安装该工具,例如 Ubuntu 上安装:
$ sudo apt-get install dos2unix
有了该工具,可以批量的把项目中的文件都转化一遍:
$ find . -type f | xargs dos2unix
或者
$ find . -type f -exec dos2unix {} +
如果涉及到在多个系统平台上工作,推荐将 git 做如下配置:
$ git config --global core.autocrlf input$ git config --global core.safecrlf true
也就是让代码仓库使用统一的换行符(LF),如果代码中包含 CRLF 类型的文件时将无法提交,需要用 dos2unix
或者其他工具手动转换文件类型。当然,可以根据自己的需要进行更为合适的配置!
到此,问题解决。
参考资料:
•http://toub.es/2012/05/28/fatal-crlf-would-be-replaced-lf•https://github.com/cssmagic/blog/issues/22
推荐阅读
GitHub 要进入中国啦!
建议收藏!写给程序员的 MySQL 面试高频 100 问
清晰易懂!有关 NumPy 和数据表达的可视化介绍
什么是 Python Launcher?
废旧 Android 手机如何改造成 Linux 服务器
喜欢文章,点个在看
中label换行问题_如何巧妙处理 Git 多平台换行符问题(LF or CRLF)相关推荐
- git 换行问题_后端必备的 Git 分支开发规范指南
作者:稻草叔叔来源:https://juejin.im/post/5b4328bbf265da0fa21a6820 Git 是目前最流行的源代码管理工具.为规范开发,保持代码提交记录以及 git 分支 ...
- python字符串换行连接_零基础学python_03_字符串(拼接+换行+制表符)
字符串拼接 在编码的过程很多时候都会用到字符串的拼接,例如,你可能想将姓和名存储在不同的变量中,等要显示姓名时再将它们合而为一: first_name = "li" last_na ...
- android 换行乱_浅谈Android textview文字对齐换行的问题
今天忽然发现android项目中的文字排版参差不齐的情况非常严重,不得不想办法解决一下. 经过研究之后,终于找到了textview自动换行导致混乱的原因了----半角字符与全角字符混乱所致!一般情况下 ...
- bat脚本中获取上级目录_转载 批处理bat命令--获取当前盘符和当前目录和上级目录...
批处理命令获取当前盘符和当前目录 %~d0 是当前盘符 %cd% 是当前目录 可以用echo %cd%进行打印测试 以下例子是命令行编译Visual Studio编写的程序: @echo off se ...
- Git 多平台换行符问题(LF or CRLF)
2019独角兽企业重金招聘Python工程师标准>>> 自从工作以后,基本上没有接触过 Windows 系统,偶尔使用 Windows 也是因为要写文档,Linux 下勉强可以用 W ...
- python中label函数_图像分析函数:skimage.measure中的label、regionprops
算法解释详细,有算法执行过程动态GIF图的:https://blog.csdn.net/icvpr/article/details/10259577 算法文字解释的简介易懂的:https://www. ...
- C#在WinForm开发中Label换行方法
很多朋友都会在开发WinForm中遇到Label要显示的内容太长,但却不能换行的问题.这里我总结了几种方法,供大家参考. 第一种是把Label的AutoSize属性设为False,手动修改Label的 ...
- Flex中label换行
Flex中label换行有两种情况 在AS中赋值: label.text="Online\r\nResources" 在mxml中赋值: text="Online Res ...
- el-table中label换行,以及表头表格内容换行
无论你使用\n还是<br/>都无法实现换行,今天给大家介绍两种换行的方式: 方法1: 如果el-table-column不是渲染的,而是写死的,例如 这时可以把label内容当成变量在la ...
最新文章
- 多任务训练的模式结构扩散
- 火爆 GitHub!这个 AI 神器究竟有什么魅力?
- confirm弹窗确定按钮换文字_弹窗设计的5条基本原则(转载)
- 安装阴阳师出现错误“选择的驱动器或UNC共享不存在或不能访问“怎么解决?
- AIX性能管理指南-luoqiangb@dc
- 视频光端机各种视频接口的传输距离是多少?
- 进程间通信之消息队列
- oracle的查询数据(检索数据)
- UVA10258 ZOJ1837 Contest Scoreboard【结构排序】
- matlab:绘制box函数和高斯函数曲线并进行傅里叶变换
- 基于WebRTC开源框架的实时视频聊天项目,搭建私人实时通信服务
- 欧姆龙CP1H的PLC步进功能图编程实例
- 假如时光倒流我会这么学java
- 【论文阅读】Speicher: Securing LSM-based Key-Value Stores using Shielded Execution
- w7计算机不显示移动硬盘,Win7移动硬盘在电脑上不显示盘符的解决办法
- Docker 安装 Elasticsearch 7.12.1
- 小程序测试之微信开发者工具
- Keep your fork synced
- windows 2008虚拟机的安装方法
- 基于51单片机的酒精浓度检测仪设计
热门文章
- linux C 中的volatile使用【转】
- puppet之判断和class
- 【效率技巧】利用TI计算器的程序映射功能 kbdprgm1()~9() 简化GTC程序调试操作
- 在linux系统下挂接(mount)光盘镜像文件、移动硬盘、U盘以及Windows网络共享和UNIX...
- git merge 步骤
- [原创]MYSQL周期备份shell脚本
- 自己用到的相关Linux命令,谨以记录
- 【体系结构】Oracle体系结构的独特理解
- linux之rsync远程同步文件
- Java中J.U.C扩展组件之Fork,join