Git 隐藏部分暂存文件
Git stash partially staged file
有没有一种方法可以简单直接地存储部分暂存文件(使用 git add -p
创建)?我已经知道 git stash -p
的行为类似于添加,但具有隐藏功能,但我已经上演了我想保存以备后用的内容。
也许还有更好的方法来做我想做的事。
我只想保存我所做的不属于该分支的更改,我想稍后在另一个分支中应用。更改尚未提交。
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
,则在申请时选择是否使用I
提交 (git stash apply --index
),或者干脆将其完全丢弃 (git stash apply
)。 --keep-index
标志,如果你在存储创建时使用它,意味着其他东西:而不是 git reset --hard
,Git 读取 I
提交到你的工作树中。
[edit] 实际上,最简单的方法可能是:
git commit
一个相当简单的方法,使用通常的隐藏命令,将是:
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 ...”的提交包含您在 运行ning 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
有没有一种方法可以简单直接地存储部分暂存文件(使用 git add -p
创建)?我已经知道 git stash -p
的行为类似于添加,但具有隐藏功能,但我已经上演了我想保存以备后用的内容。
也许还有更好的方法来做我想做的事。 我只想保存我所做的不属于该分支的更改,我想稍后在另一个分支中应用。更改尚未提交。
git stash
命令使 两次 提交:
一次提交包含索引中的每个文件,就像您 运行
git commit
一样(除了此提交不在任何分支上)。 (这是 thegit 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
,则在申请时选择是否使用I
提交 (git stash apply --index
),或者干脆将其完全丢弃 (git stash apply
)。 --keep-index
标志,如果你在存储创建时使用它,意味着其他东西:而不是 git reset --hard
,Git 读取 I
提交到你的工作树中。
[edit] 实际上,最简单的方法可能是:
git commit
一个相当简单的方法,使用通常的隐藏命令,将是:
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 ...”的提交包含您在 运行ning 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