gitdot status
gitdot add .bashrc
gitdot commit -m "update bashrc"
gitdot push
- Prior to the installation make sure to have committed the alias to the
.bashrc
or.zsh
:
alias gitdot='/usr/bin/git --git-dir=$HOME/.dotfiles/ --work-tree=$HOME'
- And that the source repository ignores the folder where it'll get cloned, so that it doesn't create weird recursion problems:
echo ".dotfiles" >> .gitignore
- Now clone the dotfiles into a bare repository in a "dotfiles" folder in $HOME:
git clone --bare <git-repo-url> $HOME/.dotfiles
- Define the alias in the current shell scope:
alias gitdot='/usr/bin/git --git-dir=$HOME/.dotfiles/ --work-tree=$HOME'
- Checkout the actual content from the bare repository to $HOME:
gitdot checkout
- The step above might fail with a message like:
error: The following untracked working tree files would be overwritten by checkout:
.bashrc
.gitignore
Please move or remove them before you can switch branches.
Aborting
This is because the $HOME folder might already have some stock configuration files which would be overwritten by Git. The solution is simple: a shortcut to move all the offending files automatically to a backup folder:
mkdir -p .dotfiles-backup && \
gitdot checkout 2>&1 | egrep "\s+\." | awk {'print $1'} | \
xargs -I{} mv {} .dotfiles-backup/{}
- Re-run the check out if there were problems:
gitdot checkout
- Set the flag showUntrackedFiles to no on this specific (local) repository:
gitdot config --local status.showUntrackedFiles no
Done!