If you have been using Git for the past few months/years and you’re still struggling with it daily, you landed at the correct place. I expect a little exposure as a prerequisite. Honestly admitting, I ain’t saint & neither a certified expert in Git, but I’ve learned a lot during my quest in resolving issues. I’ll try to make this post from beginners’ to an advanced level. Consider this as a Git FAQ. For the sake of convenience, I’ll be breaking the blog in multiple parts. So, stop panicking!
Git Panic
Novice
This blog isn’t a walkthrough or TL;DR for some best practice that we follow around in MayaData, that will be covered probably in some other blog. This blog consists of the workaround or the fixes of some gitty situation where people start panicking and screws-up the working directory.
-
Switching your branch when your workspace is dirty or there are some uncommitted changes. Example:
$ git checkout master
error: Your local changes to the following files would be overwritten by checkout:
app/utils/util.js
Please commit your changes or stash them before you switch branches.
Aborting
Fix:
Method 1:
If you need these changes later, stash them and check out the branch. You can pop changes anytime on any branch you want.
$ git stash
Saved working directory and index state WIP on eslint--fix: b6579b1 [eslint] Run eslint app/ --fix
$ git checkout master
Switched to branch 'master'
To get the changes back again
$ git stash pop
Method 2:
If you don’t want any of those changes and want to discard them.
$ git checkout -- .
ProTip: If you want to discard some file and stash some, use both in the combination of git checkout -- path/to/filename followed by git stash.
- Left few files during committing and don’t want to create a new for the same
Let’s assume you did changes in 5 files and forgot to 1 file during committing and now you have an incomplete commit & don’t want to commit again.
Add the files and commit again with --amend flag.
$ git add app/index.js # index.js is missing from commit
$ git commit --amend
ProTip: git commit --amend can be used for removing unwanted files from the commit as well as rewriting the commit message.
- Moving a single commit
If you want to move commit from branch to branch
$ git cherry-pick commit-hash
- Committed on the wrong branch or committed before switching branch
This happened with me most of the time when I was working on multiple projects simultaneously. To fix this soft reset, you branch with the latest commit(the one you committed), checkout to the desired branch & then commit again
$ git reset HEAD --soft
$ git checkout my-feature-branch
# Now stage files and commit again
ProTip: To reuse your previous commit message do git commit --reuse-message=HEAD@{1} or for a shorter version of this git commit -C HEAD@{1}
- fatal: bad revision while cherry-picking a commit!
This happens when your local git remains oblivious of the existence of the commit. To fix this, fetch all the branches, and then cherry-pick again.
$ git fetch -a
$ git cherry-pick 1acb2e
-
Too many untracked files
The scenario when you have so many untracked files in git and you want to get rid of it, git checkout -- . won’t work, not even git stash will work. rm -rf will work, but that may involve too many steps. Then how to get rid of all the untracked files in one shot.
$ git clean -fd
Bonus: Git lifehacks
# The elegant git log
$ git log --all --graph --decorate --oneline --simplify-by-decoration
# Unstage and remove paths only from the index
$ git rm --cached
# View diff on staged file
$ git diff --staged
I hope you find this blog useful during your quest. In the next follow-up blog, I’ll write about Rebase: went wrong, multiple scenarios, and their fixes. Till then, GodSpeed!
Game changer in Container and Storage Paradigm- MayaData gets acquired by DataCore Software
Don Williams
Don Williams
Deploy WordPress on AWS Using OpenEBS
Ranjith Raveendran
Ranjith Raveendran
Container Attached Storage (CAS) vs. Shared Storage: Which One to Choose?
Kiran Mova
Kiran Mova