gpt4 book ai didi

git - 如何撤消 "git add"以保留先前暂存的版本? (索引有历史吗?)

转载 作者:太空狗 更新时间:2023-10-29 14:48:42 26 4
gpt4 key购买 nike

我有一个类似于 How to undo 'git add' before commit? 的问题,但有一个重要的区别:

背景:

我正在运行一些生成文件的代码,完成后我会将这些文件添加到我的存储库中。生成文件的代码是新代码,并且在不断变化,因此我有时会多次运行它,并进行更改。

在此过程中,我将生成的文件添加到索引中,以便它们在最后为一次大提交做好准备。这也允许我检查我对代码的更改是否会在输出中创建更改,如果是,这些更改是什么。但是...我不小心对一个文件运行了另一个 git add,该文件同时出现在 Changes to be committed 部分(作为 new file) Changes not staged for commit 部分(作为 modified)。我打算在它上面运行 git diff,但我滑倒并重新添加了它,所以现在我没有办法区分它(据我所知),所以...

问题:

有没有办法撤消仅最后一次暂存操作,这样以前添加的版本将仍然/再次出现在索引中,修改后的文件将再次出现在我的工作树中,以便我可以区分它?

这些都没有提交或任何东西,因为我的目标是在我完成这一小轮开发后一起提交。我真的很喜欢 git 通常可以在提交新文件之前向我显示对新文件的更改......但是......我错过了那个机会,现在想知道是否有办法恢复它。 ?

到目前为止,我所查找的内容似乎能够让我回到上次提交(无文件)或文件的当前状态(无论如何我都有),但不能让我回到从索引到以前的版本,这从来都不是提交的一部分。任何关于这是否可能的提示(即使是不可能的可靠答案,最好能解释为什么会这样)将不胜感激。

最佳答案

没有直接的方法可以获取文件的最后一个暂存版本。索引文件没有版本控制,这就是您应该使用 commit 的原因。将来你可以考虑更频繁地进行临时提交(例如使用 commit --amend)然后至少你以前的版本会在你的 reflog 中(例如 git log -g ).

但是,所有文件的所有暂存版本都将添加到 git 对象数据库中。您应该能够使用 git fsck --lost-found 找到它们。这会将所有“悬挂”的 blob 写入 .git/lost-found/other。不幸的是,它们没有任何特定顺序或具有原始文件名,但任何丢失的 blob 都应该在某处。

关于git - 如何撤消 "git add"以保留先前暂存的版本? (索引有历史吗?),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10773420/

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