Git stash 部分暂存文件

Posted

技术标签:

【中文标题】Git stash 部分暂存文件【英文标题】:Git stash partially staged file 【发布时间】:2021-07-23 22:11:59 【问题描述】:

有没有办法以简单明了的方式存储部分暂存文件(使用git add -p 创建)?我已经知道 git stash -p 的行为类似于 add 但带有存储功能,但我已经上演了我想保存以备后用的内容。

也许还有更好的方法来做我想做的事。 我只想保存我所做的不属于此分支的更改,稍后我想在另一个分支中应用它。更改尚未提交。

【问题讨论】:

您可以git reset -p 取消登台大佬。我认为没有人教过 git 如何将单个帅哥置于“这是上演的,但现在不是,但我想稍后再放回去”的状态, 【参考方案1】:

[edit] 实际上,最简单的方法可能是:

git commit

一种相当简单的方法,使用常用的 stash 命令,是:

git stash -k     # stash your changes but keep the index
git stash        # stash again (only you index)
git stash pop --index stash@1  # restore your repo to how it was

您的***存储现在将拥有您的索引(并且只有您的索引)。


实际上,创建一个存储(常规存储)已经将您的索引存储在一个单独的位置。

要查看这个:运行git stash,然后运行git log --graph --oneline stash

$ git stash
$ git log --oneline --graph stash
*   f94915d (refs/stash) WIP on master: 963f4f4 Merge branch 'fork'
|\  
| * f45cef3 index on master: 963f4f4 Merge branch 'fork'
|/  
*   963f4f4 (HEAD -> master) Merge branch 'fork'
...

名为“index on ...”的提交包含您在运行git stash 时拥有的索引的内容。

您可以将该提交用作常规提交;如您所见,它是实际存储的第二个父级(stash^2,在我的示例中为 f94915d^2)。


git stash 有其他子命令,用于编写脚本。

例如:git stash create 将创建要存储在存储中的提交,但不会更新名为 stash 的引用或其 reflog:

$ git stash create
8bdb3b5accb08a8e16ec88a49682fcbf10d29ccf   # <- you want to do something with this commit

索引的内容是thathash^2。所以另一种方法是:

# will create a banch 'myindex' containing your current index :
$ git branch myindex $(git stash create)^2

【讨论】:

【参考方案2】:

git stash 命令进行 两次 次提交:

一个提交包含索引中的每个文件,就像您运行 git commit 一样(除了此提交不在任何分支上)。 (这是I 提交,在the git stash documentation。)

另一个提交包含您工作树中的每个跟踪文件,就像您运行 git add -u 然后 git commit (除了这个提交也不在任何分支上,并且有多个父提交,让 Git 考虑它是一个合并提交,即使它不是git merge 的产物)。 (这是W 提交。对于git stash -p,这个W 提交具有不同的内容,尽管它仍然像往常一样包含每个文件。)

在某些存储区(使用-a-u 生成的存储区)也有第三次提交,在第二次提交之前进行(也许这使得第二次提交成为第三次提交?),但我们不需要在这里关心。

这两个提交中的第一个 - 索引提交 - 包含包含您的补丁的文件。您可以简单地从这个暂存副本中批量提取文件,例如使用git show stash^2:path/to/file.ext。您可以使用 git diff 将隐藏的副本转换为针对隐藏的父提交(即当前提交)的差异(补丁):

git diff stash^ stash^2 -- path/to/file.ext

不过,一般来说,如果您只是想将某个文件 path/to/file.ext 的现有索引副本转换为补丁,我会使用 git diff --cached -- path/to/file.ext 而根本不会打扰 git stash

请注意,如果您确实使用git stash,则在应用时您可以选择是使用I 提交(git stash apply --index),还是使用只需将其完全丢弃(git stash apply)。 --keep-index 标志,如果你在创建存储时使用它,则意味着其他东西:Git 读取 I 提交到你的工作树中,而不是 git reset --hard

【讨论】:

以上是关于Git stash 部分暂存文件的主要内容,如果未能解决你的问题,请参考以下文章

git stash 常用三种模式

git stash

git stash

Git 工具 - 储藏(Stashing)

git stash 保存当前工作状态

git stash 暂存