Imagine that you are working on a part of a project and it starts getting messy. There has been an urgent bug that needs your immediate attention. It is time to your changes and switch branches. The problem is, you don’t want to do a commit of a half-done work. The solution is . save `git stash` "Stashing is handy if you need to quickly switch context and work on something else but you're mid-way through a code change and aren't quite ready to commit." By . Bitbucket Stashing Let's say you currently have a couple of local modifications. Run , to check your current state: `git status` ``` $ git status # On branch master # Changes to be committed: # (use "git reset HEAD <file>..." to unstage) # modified: index.html # Changes not staged for commit: # (use "git add <file>..." to update what will be committed) # modified: assets/stylesheets/styles.css ``` We need to work on that urgent bug. First, we want to save out unfinished work changes without committing them. This is where comes as a savior: `git stash` ``` $ git stash Saved working directory and index state WIP on master: bb06da6 Modified the index page HEAD is now at bb06da6 Modified the index page (To restore them type "git stash apply") ``` Your is now clean and all uncommitted local changes have been saved! At this point, you're free to make new changes, , , and perform any other Git operations. working directory create new commits switch branches By default, stashes are identified as "WIP" – work in progress, on top of the branch and commit they are created from. Re-applying Your Stash is a temporary storage. When you're ready to continue where you left off, you can restore the saved state easily: . Git stash `git stash pop` Popping your stash removes the changes from your stash and reapplies the last saved state. If you want to in the stash as well, you can use instead. keep the changes `git stash apply` Additional Tips and Tricks There are a couple of other things you can do with a stash. Let's take a look! Saving stashes Save a stash with a : . message `$ git stash save <message>` Try this out by adding to your styles and stash it with a nice comment. CSS-line high Stashing untracked files This is the only way to save : or untracked files `$ git stash -u` `$ git stash --include-untracked`. List multiple stashes When you or , Git will create a Git commit object with a name and then save it in your repo. You can view the you made at any time! . `git stash` `git stash save` list of stashes `$ git stash list` ``` $ git stash list stash@{0}: On master: Modified the index page stash@{1}: WIP on master: bb06da6 Initial Commit ``` Partial stashes You can choose to just a single file, a collection of files, or individual changes from within files: or . stash `$ git stash -p` `$ git stash --patch` are a must in the Ruby on Rails projects, but they might not be always complete. Stash only the part that is ready to go! RSpec tests Viewing stash diffs There are two ways to view a stash: to view the of a stash - or view only the - . full diff `$ git stash show -p` latest stash `$ git stash show` ``` $ git stash show index.html | 1 + style.css | 2 ++ 2 files changed, 3 insertions(+) ``` Creating a branch from the stash Create a to apply your stashed changes to, and then pop your stashed changes onto it: . new branch `$ git stash branch <branch_name> <stash_id>` This is another way to save your stash before moving on with the project. Remove your stash Use it with caution, it maybe is difficult to revert. The only way to revert it is if you didn't close the terminal after deleting the stash. If you no longer need a , you can delete it with: . Or you can of your stashes from the repo with: . particular stash `$ git stash drop <stash_id>` delete all `$ git stash clear` Hope this article helped you to get a better understanding how stashing works. Be sure to test it out! Previously published at Kolosek's blog.