我无意中修改了之前的承诺。提交应该是单独的,以保存我对特定文件所做的更改的历史记录。
有没有办法撤销最后的承诺?如果我执行类似gitreset-hardHEAD^的操作,第一次提交也会被撤销。
(我还没有推送到任何远程目录)
我无意中修改了之前的承诺。提交应该是单独的,以保存我对特定文件所做的更改的历史记录。
有没有办法撤销最后的承诺?如果我执行类似gitreset-hardHEAD^的操作,第一次提交也会被撤销。
(我还没有推送到任何远程目录)
当前回答
这晚了将近9年,但没有看到这个变体提到完成相同的事情(这是其中一些的组合,类似于顶级答案(https://stackoverflow.com/a/1459264/4642530).
搜索分支上所有分离的标头
git reflog show origin/BRANCH_NAME--date=相对
然后找到SHA1哈希
重置为旧SHA1
git reset—硬SHA1
然后将其向后推。
git推送原点BRANCH_NAME
完成。
这将使您完全恢复到原来的提交状态。
(包括先前覆盖的分离提交头的日期)
其他回答
简单解决方案解决方案可行:如果您的HEAD提交与远程提交同步。
在本地工作区中再创建一个分支,并使其与远程分支保持同步。Cherry从新创建的分支上执行的分支(gitcommit--modify)中选择HEAD提交。
精心挑选的提交将只包含最新的更改,而不包含旧的更改。您现在可以重命名此提交。
您需要做的是创建一个新的提交,其详细信息与当前HEAD提交相同,但父级与先前版本的HEAD相同。gitreset-soft将移动分支指针,以便下一次提交发生在与当前分支头所在位置不同的提交之上。
# Move the current head so that it's pointing at the old commit
# Leave the index intact for redoing the commit.
# HEAD@{1} gives you "the commit that HEAD pointed at before
# it was moved to where it currently points at". Note that this is
# different from HEAD~1, which gives you "the commit that is the
# parent node of the commit that HEAD is currently pointing to."
git reset --soft HEAD@{1}
# commit the current tree using the commit details of the previous
# HEAD commit. (Note that HEAD@{1} is pointing somewhere different from the
# previous command. It's now pointing at the erroneously amended commit.)
# The -C option takes the given commit and reuses the log message and
# authorship information.
git commit -C HEAD@{1}
这晚了将近9年,但没有看到这个变体提到完成相同的事情(这是其中一些的组合,类似于顶级答案(https://stackoverflow.com/a/1459264/4642530).
搜索分支上所有分离的标头
git reflog show origin/BRANCH_NAME--date=相对
然后找到SHA1哈希
重置为旧SHA1
git reset—硬SHA1
然后将其向后推。
git推送原点BRANCH_NAME
完成。
这将使您完全恢复到原来的提交状态。
(包括先前覆盖的分离提交头的日期)
使用上次提交签出到临时分支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提交合并的所有更改。