Right inside the git docs, is states that the git reflog
command runs git reflog show
by default which is an alias for git log -g --abbrev-commit --pretty=oneline
This epiphany deepens my understanding of git, and lets me understand that most
git log
flags might also work with git log -g
.
full or short format
Here are some git commands for you to try out on your own that are all pretty similar, but vary in how much information they show.
# These show only first line of the commit message subject, the hash, and index
git reflog git log -g --abbrev-commit --pretty=oneline
# similar to git log, this is a fully featured log with author, date, and full
# commit message
git log -g
add files
If I am looking for a missing file, I might want to leverage --name-only
or
--stat
, to see where I might have hard reset that file, or deleted it.
git reflog --stat git log -g --stat --abbrev-commit --pretty=oneline
git reflog --name-only git log -g --name-only --abbrev-commit --pretty=oneline
example
Here is an example where I lost my docker-compose.yml
file in a git reset, and got it back by finding the commit hash with git reflog
and cherry picked it back.
❯ git reflog --name-only
0404b6a (HEAD -> main) HEAD@{0}: cherry-pick: add docker-compose
docker-compose.yml
3cfcab9 HEAD@{1}: reset: moving to 3cfc
readme.md
9175695 HEAD@{2}: cherry-pick: add docker-compose
docker-compose.yml
3cfcab9 HEAD@{3}: reset: moving to 3cfc
readme.md fd74df3 HEAD@{4}: commit: add docker-compose docker-compose.yml
3cfcab9 HEAD@{5}: reset: moving to HEAD
readme.md
3cfcab9 HEAD@{6}: commit (initial): add readme
readme.md
This just proves that its harder to remove something from git, than it is to get it back. It can feel impossible to get something back, but once its in, it feels even more impossible to get it out.