diff --git a/content/posts/2008-04-23-git-using-the-stash.md b/content/posts/2008-04-23-git-using-the-stash.md index 42f8eab..fde7971 100644 --- a/content/posts/2008-04-23-git-using-the-stash.md +++ b/content/posts/2008-04-23-git-using-the-stash.md @@ -9,50 +9,69 @@ tags: - stash --- -I bet the following has happened to you: you are happily working on a project and are in the middle of something. You are not ready to commit your changes, because you your tests don't pass yet. Then your client calls with a bug report that needs to be fixed right now. (You know how clients can be.) +I bet the following has happened to you: you are happily working on a project +and are in the middle of something. You are not ready to commit your changes, +because you your tests don't pass yet. Then your client calls with a bug report +that needs to be fixed **right now**. (You know how clients can +be.) -So, what do you do? Throw away your current changes to make the patch? Checkout a clean copy of your project to make the changes? No! You just stash your changes away, and make the patch! Afterward you grab your changes back and continue work. +So, what do you do? Throw away your current changes to make the patch? Checkout +a clean copy of your project to make the changes? No! You just stash your +changes away, and make the patch! Afterward you grab your changes back and +continue work. -Git features The Stash, which is as much as a good place to store uncommitted changes. When you stash you changes, the will be stored, and your working copy will be reverted to HEAD (the last commit revision) of your code. +Git features _The Stash_, which is as much as a good place to store uncommitted +changes. When you stash you changes, the will be stored, and your working copy +will be reverted to HEAD (the last commit revision) of your code. -When you restore your stash, you changes are reapplied and you continue working on your code. +When you restore your stash, you changes are reapplied and you continue working +on your code. -Stash your current changes +**Stash your current changes** -
$ git stash save 
-Saved "WIP on master: e71813e..."
+ $ git stash save + Saved "WIP on master: e71813e..." -List current stashes +**List current stashes** -Yes, you can have more than one!! The stash works like a stack. Every time you save a new stash, it's put on top of the stack. +Yes, you can have more than one!! The stash works like a stack. Every time you +save a new stash, it's put on top of the stack. -
$ git stash list
-stash@{0}: WIP on master: e71813e..."
+ $ git stash list + stash@{0}: WIP on master: e71813e... -Note the stash@{0} part? That's your stash ID, you'll need it to restore it later on. Let's do that right now. The stash ID changes with every stash you make. stash@{0} refers to the last stash you made. +Note the `stash@{0}` part? That's your stash ID, you'll need it to restore it +later on. Let's do that right now. The stash ID changes with every stash you +make. `stash@{0}` refers to the last stash you made. -Apply a stash +**Apply a stash** -
$ git stash apply stash@{0}
+ $ git stash apply stash@{0} -You may notice the stash is still there after you have applied it. You can drop it if you don't need it any more. +You may notice the stash is still there after you have applied it. You can drop +it if you don't need it any more. -
$ git stash drop stash@{0}
+ $ git stash drop stash@{0} -Or, because the stash acts like a stack, you can pop off the last stash you saved: +Or, because the stash acts like a stack, you can pop off the last stash you +saved: -
$ git stash pop
+ $ git stash pop If you want to wipe all your stashes away, run the 'clear' command: -
$ git stash clear
+ $ git stash clear -It may very well be that you don't use stashes that often. If you just want to quickly stash your changes to restore them later, you can leave out the stash ID. +It may very well be that you don't use stashes that often. If you just want to +quickly stash your changes to restore them later, you can leave out the stash +ID. -
$ git stash
-...
-$ git stash pop
+ $ git stash + ... + $ git stash pop -Feel free to experiment with the stash before using it on some really important work. +Feel free to experiment with the stash before using it on some really important +work. -Please leave a comment if you like this article, and would like to see more Git related stuff here on Ariejan.net. \ No newline at end of file +**Please leave a comment if you like this article, and would like to see more +Git related stuff here on Ariejan.net.**