我无意中修改了之前的承诺。提交应该是单独的,以保存我对特定文件所做的更改的历史记录。

有没有办法撤销最后的承诺?如果我执行类似gitreset-hardHEAD^的操作,第一次提交也会被撤销。

(我还没有推送到任何远程目录)


当前回答

这晚了将近9年,但没有看到这个变体提到完成相同的事情(这是其中一些的组合,类似于顶级答案(https://stackoverflow.com/a/1459264/4642530).

搜索分支上所有分离的标头

git reflog show origin/BRANCH_NAME--date=相对

然后找到SHA1哈希

重置为旧SHA1

git reset—硬SHA1

然后将其向后推。

git推送原点BRANCH_NAME

完成。

这将使您完全恢复到原来的提交状态。

(包括先前覆盖的分离提交头的日期)

其他回答

也许可以使用git-relog在修改前和修改后获得两个提交。

然后使用git diff before_commit_id after_commit_id>d.diff获取修正前和修正后的差异。

接下来使用git checkout before_commit_id返回提交前

最后使用git-apply.diff应用您所做的真正更改。

这解决了我的问题。

使用上次提交签出到临时分支git分支临时HEAD@{1}重置上次提交数字复位温度现在,您将拥有您提交的所有文件以及以前提交的文件。检查所有文件的状态。git状态从git阶段重置提交文件。git重置myfile1.js(依此类推)重新附加此提交gitcommit-C HEAD@{1}将文件添加并提交到新提交。

使用HEAD@{1}的这些答案对我来说都不可行,所以下面是我的解决方案:

数字刷新

d0c9f22 HEAD@{0}: commit (amend): [Feature] - ABC Commit Description 
c296452 HEAD@{1}: commit: [Feature] - ABC Commit Description 

git重置--软c296452

您的登台环境现在将包含您意外与c296452提交合并的所有更改。

使用ref日志:

git branch fixing-things HEAD@{1}
git reset fixing-things

然后,您应该只在工作副本中保存所有以前修改过的更改,然后可以再次提交

要查看以前索引的完整列表,请键入git-relog

可能值得注意的是,如果您仍然在编辑器中看到提交消息,您可以删除提交消息,它将中止gitcommit--modify命令。