我无意中修改了之前的承诺。提交应该是单独的,以保存我对特定文件所做的更改的历史记录。
有没有办法撤销最后的承诺?如果我执行类似gitreset-hardHEAD^的操作,第一次提交也会被撤销。
(我还没有推送到任何远程目录)
我无意中修改了之前的承诺。提交应该是单独的,以保存我对特定文件所做的更改的历史记录。
有没有办法撤销最后的承诺?如果我执行类似gitreset-hardHEAD^的操作,第一次提交也会被撤销。
(我还没有推送到任何远程目录)
当前回答
您可以执行以下操作来撤消git提交-修改
git reset—软头^git签出文件_from_old_commit_onbranchgit拉动原点your_branch_name
====================================
现在,您的更改与之前相同。所以你已经完成了gitcommit的撤销-修改
现在您可以执行gitpushorigin<your_branch_name>,以推送到分支。
其他回答
可能值得注意的是,如果您仍然在编辑器中看到提交消息,您可以删除提交消息,它将中止gitcommit--modify命令。
使用HEAD@{1}的这些答案对我来说都不可行,所以下面是我的解决方案:
数字刷新
d0c9f22 HEAD@{0}: commit (amend): [Feature] - ABC Commit Description
c296452 HEAD@{1}: commit: [Feature] - ABC Commit Description
git重置--软c296452
您的登台环境现在将包含您意外与c296452提交合并的所有更改。
也许可以使用git-relog在修改前和修改后获得两个提交。
然后使用git diff before_commit_id after_commit_id>d.diff获取修正前和修正后的差异。
接下来使用git checkout before_commit_id返回提交前
最后使用git-apply.diff应用您所做的真正更改。
这解决了我的问题。
如果您将提交推到远程,然后错误地修改了对该提交的更改,这将解决您的问题。在提交之前发出git日志以查找SHA。(这假设remote被命名为origin)。现在使用SHA发出这些命令。
git reset --soft <SHA BEFORE THE AMMEND>
#you now see all the changes in the commit and the amend undone
#save ALL the changes to the stash
git stash
git pull origin <your-branch> --ff-only
#if you issue git log you can see that you have the commit you didn't want to amend
git stash pop
#git status reveals only the changes you incorrectly amended
#now you can create your new unamended commit
简单解决方案解决方案可行:如果您的HEAD提交与远程提交同步。
在本地工作区中再创建一个分支,并使其与远程分支保持同步。Cherry从新创建的分支上执行的分支(gitcommit--modify)中选择HEAD提交。
精心挑选的提交将只包含最新的更改,而不包含旧的更改。您现在可以重命名此提交。