我喜欢使用git diff -w来忽略空白差异。但是,我刚刚注意到,它甚至忽略了行中间的空白差异。我怎么能只忽略行开头(^)或结尾($)的空白差异呢?
当前回答
这是一个老问题,但仍然经常被看到/需要。我想发表这篇文章提醒像我这样的读者,OP问题中提到的空格与Regex的定义不一样,它包括换行符、制表符和空格字符——Git要求你明确。查看一些选项:https://git-scm.com/book/en/v2/Customizing-Git-Git-Configuration
如上所述,git diff -b或git diff——ignore-space-change将忽略行尾的空格。如果你希望这个设置是你的默认行为,下面这行代码会把这个意图添加到你的.gitconfig文件中,所以它总是忽略行尾的空格:
Git配置——全局核心。空白尾随空格
在我的例子中,我发现这个问题是因为我对忽略“回车空格差异”感兴趣,所以我需要这个:
Git diff—ignore-cr-at-eol or Git配置——全局核心。空格cr-at-eol从这里开始。
你也可以通过省略——global参数使其仅为该repo的默认值,并检查该repo的设置文件。对于我遇到的CR问题,如果.gitconfig文件[core]部分中的warncrlf或selflf = true签入后,它就会消失。
其他回答
终端使用:
git diff --ignore-space-at-eol
而不是你目前使用的:
git diff -w (--ignore-all-space)
作为开始的线…如果你想要一个内置的解决方案,那你就不走运了。
然而,如果你不介意自己动手的话,在某个地方有一个相当老的补丁,它增加了对“——ignore-space-at-sol”的支持。
这是一个老问题,但仍然经常被看到/需要。我想发表这篇文章提醒像我这样的读者,OP问题中提到的空格与Regex的定义不一样,它包括换行符、制表符和空格字符——Git要求你明确。查看一些选项:https://git-scm.com/book/en/v2/Customizing-Git-Git-Configuration
如上所述,git diff -b或git diff——ignore-space-change将忽略行尾的空格。如果你希望这个设置是你的默认行为,下面这行代码会把这个意图添加到你的.gitconfig文件中,所以它总是忽略行尾的空格:
Git配置——全局核心。空白尾随空格
在我的例子中,我发现这个问题是因为我对忽略“回车空格差异”感兴趣,所以我需要这个:
Git diff—ignore-cr-at-eol or Git配置——全局核心。空格cr-at-eol从这里开始。
你也可以通过省略——global参数使其仅为该repo的默认值,并检查该repo的设置文件。对于我遇到的CR问题,如果.gitconfig文件[core]部分中的warncrlf或selflf = true签入后,它就会消失。
推荐文章
- Git在不改变提交时间戳的情况下进行改基
- VS 2017 Git本地提交数据库。每次提交时锁定错误
- 如何在过去的一些任意提交之间注入一个提交?
- 从GitHub克隆项目后拉git子模块
- GitHub上的分叉和克隆有什么区别?
- 递归地按模式添加文件
- 我如何使用notepad++(或其他)与msysgit?
- 我怎么能显示线在公共(反向差异)?
- 如何将现有的解决方案从Visual Studio 2013添加到GitHub
- Git存储库中的悬垂提交和blob是什么?它们来自哪里?
- 我如何简单地从我最新的git提交创建一个补丁?
- Git显示“警告:永久添加到已知主机列表”
- 我如何检索一个回购的远程git地址?
- 如何列出提交,因为某些提交?
- 如何在不位于存储库的情况下执行Git命令?