You are in the middle of some work. You have created a bunch of new files and edited some existing ones when your boss comes and tells you to deal with an emergency bug fix. You realize you need to switch branches but your work is incomplete and you don’t want to commit it just yet.

Stashing your changes is the best way to go. However, the default behavior of git stash is to stash only the tracked files. The untracked files will remain in your repo. Sometimes that is ok. You can have them there while you switch branches and deal with the emergency. But, in some occasions, their existence might interfere with other things (like changing the behavior of the software, or getting accidentally added to a commit).

I prefer to stash the untracked files every time I need to switch branches. That way I get a clean repo to work with. Less thinking required, and less room for error. It’s the safest option.

So how do you stash both tracked AND untracked files?

Using:

$ git stash --include-untracked # or the shorter alternative: $ git stash -u

“Will this include the files in my .gitignore ?”

No. This will only include the untracked files you see when you do git status . If you want to stash files included in .gitignore , use git stash --all .

“How do I see what I have just stashed?”