- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个类似于 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/
I have a question about adding files in git. I have found multiple stackoverflow questions about
我是 visual studio 的新手,来自 Delphi。 我有一个充满 .cs 文件的目录树(根是\Common)。 我还有一个充满应用程序的目录树(根目录是\Applications) 最后,
这个问题在这里已经有了答案: Array's lookup time complexity vs. how it is stored (4 个答案) Time complexity for java
谁能告诉我这两者有什么区别: ALTER TABLE x1 ADD INDEX(a); ALTER TABLE x1 ADD INDEX(b); 和 ALTER TABLE x1 ADD INDEX(
为什么有时我们使用 getChildren() add() 而其他时候我们直接使用 add() es: https://docs.oracle.com/javafx/2/get_started/for
如何使用 bootstrap css 在输入下方添加跨度?我需要做这样的事情: 最佳答案 是这样的吗? http://jsfiddle.net/swm53ran/205/ 您可以使用纯 CSS 来实现
问题 np.add(X, 2*Y, out=X) 比 np.add(X, Y, out=X); np.add(X, Y, out=X).使用 np.add(X, Y, out=X); 是一种实际做法吗
当我跑 git add --intent-to-add .所有未跟踪的文件将其状态从“未跟踪的文件”( git status -s 显示 ?? )更改为“未暂存以进行提交的更改”( git statu
我不知道 .add 之间有什么区别和 .sink.add ? 例子: StreamController myStreamController = StreamController(); stream
getContentPane().add() 和 add() 的意思一样吗? public class TestFrame extends JFrame{ public TestFrame()
git add . 和 git add * 会完成完全相同的事情吗? 最佳答案 不,不会。 * 是一个 glob 模式,不会匹配以 开头的文件。 例如,假设这是当前目录,我有 2 个新文件要添加 fo
git的分支与合并的两种方法 git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别 git add . :他会
git add [--all | -A] 之间有什么区别?和 git add . ? 最佳答案 此答案仅适用于 Git 版本 1.x。对于 Git 版本 2.x,请参阅其他答案。 总结: git ad
我刚刚安装了最新的 Wix v3.7。我创建了一个 VS 2010“Excel 2010 加载项”项目,并在同一个解决方案中创建了一个 Wix“安装项目”。 问题是,当我尝试从 Wix 项目中引用 A
YUI.add 和 YUI().add 有什么区别? 最佳答案 在第一种情况下,您要注册一个模块可以加载到 YUI 沙箱中,在第二种情况下,您要构建一个沙箱,然后进行注册(这是一种非常不典型的用法)。
测试代码时,任何输入到列表中的值在按下“enter”后都会消失。 我对编程和网络开发非常陌生。请具体一点,以便我理解。 function addItem(){ var item = documen
我正在浏览 python 的 dis 包。我尝试了代码以查看它是如何工作的 >>> def get(): ... x=4 ... y=x+3 ............ this lin
我已经对我的文件夹进行了版本控制 git init git add . git commit -m 'Initial commit' 我应该怎么做 git add 对于我在 .? 中创建的每个新文件
当我执行 $ git add * 时,有时我意识到 git 不会将已删除的文件添加到舞台上,如果删除或添加它,我需要手动指示,但我想不通找出 $ git add --all 有什么区别。因此,如果星号
这个问题在这里已经有了答案: Difference between "git add -A" and "git add ." (12 个答案) 关闭 6 年前。 目前,当我想提交并将内容推送到远程
我是一名优秀的程序员,十分优秀!