How to undo the last commit in git, but keep my changes as unstaged?

14,032

Solution 1

This sounds like a job for git reset --soft, whose help (git help reset) says this:

--soft
    Does not touch the index file nor the working tree at all
    (but resets the head to <commit>, just like all modes do).
    This leaves all your changed files "Changes to be
    committed", as git status would put it.

So the commit is undone, but the files still look the way they did before. Nothing is staged to the index.

Solution 2

I would leave off the --soft in the other two answers and go with a simple git reset @^ (or git reset HEAD^ in older versions of git), which will default to git reset --mixed @^. The difference is that a soft reset leaves the files staged for commit, which is not what it sounds like you want to do. If you really want to undo the commit, you should also probably unstage the changes, which is what the default does. I find this much more useful in the general case than a soft reset, which is probably why mixed is the default.

Solution 3

As Peter says, I'd go with git reset --soft which should leave both your index, and working directory in tact.

In your case, if you want to go back 1 commit, you can use git reset --soft HEAD~ to point the branch at the parent commit of the current HEAD; your index and working directory will still contain your altered files.

A handy article about reset: http://git-scm.com/blog/2011/07/11/reset.html

Share:
14,032

Related videos on Youtube

kramer65
Author by

kramer65

Updated on September 14, 2022

Comments

  • kramer65
    kramer65 over 1 year

    I've made a commit, but now it is kind of difficult to see what I all changed. I can off course do a git diff, but I'd rather undo the last commit and keep all my changes in tact so that my IDE (PyCharm) simply shows me which files have been changed.

    So is there a way to undo the last commit (really remove it) but still keep my changes in tact? All tips are welcome!

    • Drew Noakes
      Drew Noakes about 10 years
      Small point: you don't really ever remove commits from the git history. Rather, you remove pointers (i.e. branches) to them. Eventually they will be garbage collected. If you mess something up and want to go back, you can find these dangling commits in the reflog.
    • blueberry_chopsticks
      blueberry_chopsticks over 2 years
      I'd also recommend getting familiar with the built in git explorer in the JetBrains (PyCharm, etc) IDEs, as they will show you a changes you've made in a particular commit without having to "uncommit" your changes. This solution might work if you've just committed something, but imagine what would happen if you needed to go back to something committed last month!
  • kramer65
    kramer65 about 10 years
    I just ran git reset --soft, but when I run git hist I still see my last commit in there. So I guess this is not a solution to my problem. Any other ideas?
  • Peter Westlake
    Peter Westlake about 10 years
    The commit is still in the history, but HEAD no longer points to it. It is a dangling reference, and will be garbage-collected.
  • kramer65
    kramer65 about 10 years
    As a tip; a finally succeeded by doing git reset --soft <hash of last commit>. Inserting the has finally solved it for me. Thanks anyway!
  • chetstone
    chetstone almost 8 years
    This should be the accepted answer-- simpler and exactly what the OP wanted.
  • Harry
    Harry almost 4 years
    Geez, man, you alone have solved the problem, THIS should be the accepted and most upvoted answer. Without HEAD~ at the end git reset --soft did nothing.
  • Chris
    Chris almost 4 years
    Glad it helped =D