刚开始用IDEA, 不小心选错了换行符配置. 且代码中存在大量的tab和4space混用情况.
git diff后各种难看的Ctrl+M.
下面说说如何统一替换掉Ctrl+M(windows回车符)
git diff master | grep '+++' | awk -F'b/projname' '{print "projname"$2}' | xargs -I {} sed -i '' "s/^M//g" {}
首先通过git diff 和grep找到被修改或者新添加的文件. 通过awk获取文件名. 之后通过xargs执行sed命令.
xargs -I {} 中, -I 可以指派替代符. 将传入变量替换到后面命令中.
sed -i 是替换文件模式, '' 实际是新文件的扩展名, 但是我们希望在源文件上直接修改, -i 指定空就可以.
"s/^M//g"
是将^M替换为空字符.
这里需要注意, ^M 需要通过[Ctrl+v]-[Ctrl+m]来输入.