BigW Consortium Gitlab

stash.md 1.34 KB
Newer Older
1 2 3 4
---
comments: false
---

Sean Packham committed
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
# Git Stash

----------

We use git stash to store our changes when they are not ready to be committed
and we need to change to a different branch.

* Stash
```
git stash save
# or
git stash
# or with a message
git stash save "this is a message to display on the list"
```

* Apply stash to keep working on it
```
git stash apply
# or apply a specific one from out stack
git stash apply stash@{3}
```

----------

* Every time we save a stash it gets stacked so by using list we can see all our
stashes.

```
git stash list
# or for more information (log methods)
git stash list --stat
```

* To clean our stack we need to manually remove them.

```
# drop top stash
git stash drop
# or
git stash drop <name>
# to clear all history we can use
git stash clear
```

----------

* Apply and drop on one command

```
  git stash pop
```

* If we meet conflicts we need to either reset or commit our changes.

* Conflicts through `pop` will not drop a stash afterwards.

----------

## Git Stash

1. Modify a file
2. Stage file
3. Stash it
4. View our stash list
5. Confirm no pending changes through status
5. Apply with pop
6. View list to confirm changes

----------

## Commands

```
# Modify edit_this_file.rb file
git add .

git stash save "Saving changes from edit this file"

git stash list
git status

git stash pop
git stash list
git status
```