{:.no_toc}
- toc {:toc}
There is a git command to add a file to the staging area: git stage
. It is a synonym, not an alias, to git add
. However, there is no corresponding git unstage
to unstage a file. The following alias fills this void:
$ git config --global alias.unstage 'reset HEAD --'
This alias is from the official pro git e-book.
The git log
command has a lot of options. A very useful combination of options is the visual representation of the project history, similar to gitk
but without the GUI:
$ git config --global alias.lol \
'log --graph --decorate --pretty=oneline --abbrev-commit --all'
This set of options prints a pretty textual representation of the project history:
In case the fire alarm sounds in your office you are supposed to leave the building immediately. However, you don't want to leave your changes uncommitted to be consumed by fire, so you want to quickly push your work.
Print this out and tape it on the door, your git-capable colleagues will love it (from this repo):
There is a git workflow to save your progress without disrupting other peoples work, to avoid all colleagues pushing to the same branch.
# checkout new unique branch
git checkout -b fire/$USER
# stage and commit everything
git stage -A
git commit -m 'WIP: fire alert!'
# push it
git push origin fire/$USER
Since you want to avoid having to remember all of this when it really burns, you can create an alias that takes care of this:
$ git config --global alias.fire \
'!sh -c "git checkout -b wip/fire/$USER && \
git stage -A && \
git commit -m wip-fire-alert && \
git push origin wip/fire/$USER"'
Alternatively, you can use this shell script, name it git-fire
, make it executable and put it on your PATH
:
#!/bin/bash
FIRE_BRANCH="wip/fire/$USER-$(date +%s)"
git checkout -b "$FIRE_BRANCH" &&
git stage -A &&
git commit -m 'WIP: fire alert!' &&
git push origin "$FIRE_BRANCH"