微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Git stash 部分暂存文件

如何解决Git stash 部分暂存文件

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

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

解决方法

git stash 命令使 两次 提交:

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

  • 另一个提交保存工作树中的每个跟踪文件,就好像您先运行 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,则在 apply 时您可以选择是否使用 I 提交({{1 }}),或者干脆把它完全扔掉 (git stash apply --index)。 git stash apply 标志,如果您在存储创建时使用它,则意味着其他含义:Git 将 --keep-index 提交读取到您的工作树中,而不是 git reset --hard

,

[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 的引用及其引用日志:

$ 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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?