- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我似乎找不到使用 git add -p
的好方法,但告诉 git 忽略所有空白更改。我不想重置我的本地更改。
情况:我在本地进行了所有更改,并将它们分组到单独的提交中。然后我尝试了一个 minifyer,并用他们的缩小版本覆盖了我所有的 css 文件。我尝试“取消缩小”所有内容,但它仍然搞砸了 git diff——因为有太多空白更改——而且我似乎无法让我的 repo 协议(protocol)回到我可以看到实际变化的地方。
感谢您的帮助!
最佳答案
这是最简单的方法。如果您不想在您的工作目录中重置和读取,则没有一行直接的方法。你应该这样做,这是一个很好的方法,一步一步解释:
git diff -w --no-color | git apply --cached --ignore-whitespace && git checkout -- . && git reset && git add -p
git diff -w --no-color
创建一个没有终端格式和颜色的差异
git apply --cached --ignore-whitespace
应用 diff 忽略空白,并为其编制索引
git checkout -- .
删除未索引的“空白”更改
git reset
将索引重置为仅非空白更改
git add -p
以补丁模式添加非空白更改
( source here )
这部分解决了您的问题,无需 stash 或重置。您可以通过以下方式仅“区分并应用”非空白更改:
git diff -w --no-color | git apply --cached --ignore-whitespace
这是另一种方式,但请注意,这里打补丁有点乱,您需要缓冲并手动更改 diff 以去除空格。如果您使用 VIM,可以使用以下快速分步命令来缓冲、快速查找、删除并最终应用干净的差异:
:r !git diff -w --no-color
这会用你的 diff 创建一个新缓冲区
:set ft=diff
(可选)如果你想要语法高亮使用这个
现在您需要手动删除您不想暂存的内容,然后
:w !git apply --cached --ignore-whitespace
应用当前固定差异
并最终使用 :!git commit -m "your fixed commit"
提交这个差异
这是第一次迭代。您需要清除缓冲区,读取未暂存的更改并重复:
:bd! | set ft=diff | r !git diff -w --no-color
继续前进,最终,您将只剩下要提交的空白更改。
如果你不想使用 VIM:
这可能不是最快的方法,但它很实用,如果您不喜欢第一种方法,它可以解决问题。
(来源和类似问题 here )
关于css - Git add -patch...但忽略空格更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44424041/
我正在尝试使用 Android SDK 中的 Draw9Patch 工具,但在使用 Draw9Patch 打开我的图像后,它立即将我的所有图像区域显示为“坏补丁”。我手动绘制了定义可拉伸(stretc
我有一个运行补丁命令的构建工具,如果补丁命令返回非零值,它将导致构建失败。我正在应用一个可能已经或可能尚未应用的补丁,所以我使用 -N选项 patch ,它应该跳过。但是,当它确实跳过时,patch返
patching file chrome/browser/gpu_process_host_ui_shim.cc Unreversed patch detected! Skipping patch.
尝试查看哪些模型最适合api(更新少,但对象结构可能经常更改,高读取应用程序) 我有这样的资源 Epic(ID、名称、描述、开始日期、结束日期、状态、故事) 故事(ID、名称、说明、开始日期、结束日期
我创建了新问题,因为我觉得上一个问题已经得到解答,这属于一个新的地方。 我跑 bitbake core-image-minimal我收到以下错误: ERROR: systemd-1_232-r0 do
我正在使用 ColdFusion 10 与 PayPal 的服务器和 for some requests 进行通信我需要执行 HTTP PATCH 请求 are not supported by CF
我试图了解这两种模拟方法之间的区别。有人可以帮助区分它们吗?对于这个例子,我使用 passlib 库。 from passlib.context import CryptContext from un
WebTarget webTarget = httpClient.target(url); Invocation.Builder invocationBuilder = webTarget.reque
当提到“提交补丁”时,补丁这个词究竟是什么意思? 我已经看到它被大量使用,尤其是在开源世界中。它是什么意思,提交补丁到底涉及什么? 最佳答案 这是一个文件,其中列出了已更改的代码文件之间的差异。它通常
对于 matplotlib.patches,patch.contains_point(xy) 方法似乎与 patch.get_path().contains_point(xy) 不同,至少在拥有之后将
这是什么RFC 5789说: The PATCH method requests that a set of changes described in the request entity be ap
在 Draw 9-patch 中,一切看起来都很好。 但是,我的 SDK 说 9-patch png 格式不正确。因为我有类似 11-patch png 的东西。因为我不希望小抓取区域被缩放。如何让它
我创建了一个使用 javax.xml.ws.Endpoint 来创建 REST 端点的类: @WebServiceProvider @ServiceMode(value = javax.xml.ws.
语境 我有一个 spring boot (version 2.2.6.RELEASE) web 项目。 从这个 Web 应用程序(我称之为“APP1”)我想使用来自另一个 Web 应用程序的 PATC
在为我的应用程序编写单元测试时,我一直使用 @mock.patch 和 @patch.object 装饰器。但是现在,当我使用装饰器进行一些单元测试时,我收到错误消息“TypeError: stati
我在使用@mock.patch.object 函数时观察到 nosetests 的一个非常奇怪的行为: 当我同时运行多个测试时,我得到的结果与单独运行它们时不同。具体来说,在某些情况下,当我一起运行多
我正在使用 RestSharp v107。 我想更新测试用例的迭代路径。我可以使用 Postman 更新它,但使用 RestSharp 我收到“BAD Request”-“您必须在请求正文中传递有效的
我已经阅读了 GNU 项目中关于开源和其他许可证的文章。某些许可证允许您将更改发布为补丁,而不是完整的源代码(例如 Q 公共(public)许可证或 gnuplot 许可证)。这是什么意思?这样的补丁
有谁知道免费的优质补丁程序?您知道,可以将其中包含旧程序的目录放入其中,然后将其与具有新版本的目录进行比较,然后吐出一个补丁,这仅仅是两者之间的区别? 另外,我正在寻找可以修补整个目录的东西,而不仅仅
由于我当时一直在使用 Subversion 和 shell 工具,git-gui这些都是不可能的。是否有任何 shell 工具可以交互式地逐行应用补丁? 最佳答案 尝试通过 --dry-run选项 p
我是一名优秀的程序员,十分优秀!