I am working on a git repository with a master branch and another topic branch. I have switched to topic branch and modified a file. Now, if I switched to master branch that
The modified files are not put in the repository until you add and commit them. If you switch back to your topic branch and commit the file, then it won't appear on the master branch.
This is the default behaviour of git.
You can use -f flag to checkout to do "clean checkout" if you like.
You can do the following things to overcome this issue.
-f
option to ignore the changes.If you want to save the changes:
git stash
, switch the branch, do your work, switch back to the
original branch and do git stash apply
.If you want to temporarily store your changes to one branch while you go off to do work on another, you can use the git stash
command. It's one of the amazing little unsung perks of using git. Example workflow:
git stash #work saved
git checkout master
#edit files
git commit
git checkout git-build
git stash apply #restore earlier work
git stash
stores a stack of changes, so you can safely store multiple checkpoints. You can also give them names/descriptions. Full usage info here.
Why is that the file is shown as modified in master branch even though it was modified in git-build branch?
The key to remember is that the file was not modified in the git-build branch. It was only modified in your working copy.
Only when you commit are the changes put back into whichever branch you have checked out