gpt4 book ai didi

git - 排除 git diff 中删除的行

转载 作者:行者123 更新时间:2023-12-02 02:44:05 25 4
gpt4 key购买 nike

我对一个函数进行了多项更改,并使用 git add -p 暂存了其中一项。在提交它之前,我想检查一下这个更改是否确实做了它应该做的事情。

因此我想完全按照暂存区中的原样打印代码,以便我可以复制此函数并在单独的文件中对其进行测试。

gitk 中会有这个有用的单选按钮,我可以在其中选择 New version 而不是 Diff。但是,我不能在这里使用 gitk,因为我是通过 ssh 连接到没有图形用户界面的计算机。

如果更改已经提交,我可以使用 git show HEAD:myfile (尽管这会打印整个文件,这远远超出了我目前感兴趣的范围)但我不知道如何指定暂存区域而不是 HEAD。

我对两者都感兴趣:

  1. 如何打印带有上下文行但没有删除行的暂存更改?
  2. 如何在 git show 中指定暂存区域以便打印整个文件?

我找到了 this answer但是 -e 没有记录在 git diff --help 中,当尝试使用它时我得到 error: invalid option: -e.

当然我可以提交更改,在 git show HEAD:myfile 的输出中搜索它们,然后在必要时使用 git commit --amend 更改提交,但是我觉得一定有更简单的方法。

最佳答案

称为暂存区 的东西也称为索引。因此文件的暂存副本也是文​​件的索引副本。要引用特定文件的索引副本,请使用前导冒号语法::<em>digit</em>:<em>filename</em> ,例如 :0:myfile :

git show :0:myfile

索引在暂存槽 0 中保存文件的 1 个副本,或在暂存槽 1、2 和 3 中保存(最多)三个文件副本。后者仅在 merge 期间发生,同时解决冲突.由于您不在冲突 merge 的中间,因此您的文件仅存在于第零阶段。您可以省略数字和第二个冒号来表示“暂存槽零”:

git show :myfile

(比较 git show HEAD:myfile ,它从 HEAD 提交中提取文件的副本,或 git show <em>hash</em>:myfile ,它从给定的提交哈希中提取文件的副本。所有这些都在内部工作,文件的 Git 化副本,采用特殊的 Git-only、提交文件只读格式——已复制到索引中的文件已经采用这种形式。)

diff HEAD针对索引提交,使用:

git diff --cached

请注意,这会比较 HEAD 中的每个 文件针对索引中的每个 文件。索引中的大多数文件已经与 HEAD 中的副本匹配, 当然。特别是,如果您这样做了:

git checkout master
<edit some file>
git add [options] just-one-file

然后每个文件除了 just-one-file索引/暂存区中的文件与 HEAD 中的对应文件匹配, 因此 diff 将只显示一个文件。

如果索引中有多个文件与其 HEAD 不同同行,可以限制git diff使用路径名进一步输出:

git diff --cached -- myfile

例如。 (这仍将显示所有已删除的。)

(有一个常见的误解,认为暂存区仅包含 文件。事实并非如此——它实际上包含每个 文件,准备提交,根本次 — 但由于许多教程中描述暂存区域的方式以及 git diff 没有向您显示未更改文件的任何内容,它可能看起来 一开始就是这样。要查看暂存区中所有文件的列表以及有关它们的信息,请使用 git ls-files --stage。请注意,此列表可能很长!)

关于git - 排除 git diff 中删除的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57025220/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com