This repository contains the dotfiles that I use on my macOS machines.
I am able to share most of my dotfiles, but certain private dotfiles contain
personal information and I am unable to share those ones at this time. The
private dotfiles are contained within the private subdirectory of the
repository, which is a submodule that points to a private GitHub repository.
In addition to the private dotfiles being stored in a non-public repository,
they are also encrypted within that repository.
-
Install
brew. -
Install
chezmoi:brew install chezmoi
-
Initialize
chezmoiusing my dotfiles:chezmoi init --ssh github.com/cathyjf
This
chezmoi initcommand will automatically clone this repository and itsprivatesubmodule. To skip cloning the private dotfiles, add the--recurse-submodules=falseargument. -
Apply the dotfiles (including the private dotfiles) to the home directory:
chezmoi apply
To apply only the public dotfiles, use:
chezmoi apply --exclude encrypted
One advantage of applying only the public dotfiles is that it will not be necessary to authenticate to decrypt my GPG key.
After the public dotfiles have been applied at least once, a fish function named chezmoi-private will be available. This function takes all of the same arguments as the chezmoi program, but it operates on the private dotfiles instead of on the public dotfiles.
Examples:
- Run
chezmoi-private managedto see a list of all of the private dotfiles managed bychezmoi. - Run
chezmoi-private diffto see pending changes to the private dotfiles. This will require authentication to decrypt my GPG key.
-
The Brewfile in this repository specifies some packages from my cathyjf/homebrew-misc repository.
-
My dotfiles specify cathyjf/keychain-interpose as the default agent for
gpg(1).