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

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

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


当前回答

如果您将提交推到远程,然后错误地修改了对该提交的更改,这将解决您的问题。在提交之前发出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

其他回答

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

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

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

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

这解决了我的问题。

通过以下方式查找修改后的承诺:

git log --reflog

注意:为了清楚起见,可以添加--patch来查看提交的主体。与git-relog相同。

然后通过以下方式将您的HEAD重置为之前的任何提交:

git reset SHA1 --hard

注意:用真正的提交哈希替换SHA1。还要注意,此命令将丢失任何未提交的更改,因此您可以在之前将其隐藏。或者,使用--soft来保留最新的更改,然后提交它们。

然后樱桃选择你需要的其他承诺:

git cherry-pick SHA1

你总是可以拆分提交,来自手册

使用git rebase-i commit ^启动交互式rebase,其中commit是要拆分的提交。事实上,任何提交范围都可以,只要它包含该提交。使用“编辑”操作标记要拆分的提交。在编辑提交时,执行git-resetHEAD^。结果是HEAD被重绕了一圈,索引也随之改变。然而,工作树保持不变。现在,将更改添加到第一次提交时所需的索引中。您可以使用gitadd(可能以交互方式)或gitgui(或两者都使用)来实现这一点。使用现在合适的提交消息提交当前索引。重复最后两个步骤,直到工作树干净。使用git-rebase继续rebase--Continue。

如果您将提交推到远程,然后错误地修改了对该提交的更改,这将解决您的问题。在提交之前发出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

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