This repository hosts my personal dotfiles as well as machine provisioning and workflow scripts. This repository come with no warranty. It may wipe your boot disk, eat your pet, etc. I like to experiment with my setup and this repository reflect that. Use it at your own risk.
$ mkdir -p $HOME/.dotfiles $ cd $HOME/.dotfiles $ curl -sSL https://git.sr.ht/~sirn/dotfiles/archive/master.tar.gz | tar -xvzf - --strip-components=1 $ ./bootstrap.sh
The primary endpoint of this repository is
bootstrap.sh, which is a shell script written in POSIX sh. The script is used to setup packages, configuring current user environment, and configuring the system.
bootstrap.sh script has few configurations available, namely:
bootstrap.sh script itself does nothing but handling arguments and dispatching to an appropriate entrypoint script located in
libexec/bootstrap at each lookup path location. The script to be executed will depends on the name of the profile and the operating it is running.
For example, running a
pkg profile (
-p pkg) on macOS that has lookup path of
-l /foo -l /bar) will result in
/bar/libexec/bootstrap/pkg_darwin.sh getting called.
bootstrap.sh will also pass flavors as script arguments and the entrypoint script may selectively install packages according to the flavor.
I like to make my system reproducible. I mostly work on iPad Pro, by using Blink.sh to remote into a workspace running FreeBSD or OpenBSD depending on the phase of the moon. I also work on macOS sometimes, and I like to be able to run a single command to get everything in sync.
bootstrap.sh script is in fact evolved from Ansible! Ansible has serve this repository well for several years, however to use Ansible to bootstrap the current system from scratch require some sort of shell script to bootstrap Ansible and the packaging system itself.
This led to a problem: I need to have half of the bootstrap process in shell script and another half in Ansible. For example, in case of Darwin (macOS), I need to install SDK, install MacPorts, install Python 3 and install Ansible from a shell script to be able to provision a local machine.
One day, I thought, why don't I try to do everything in shell script? POSIX sh, even, to ensure compatibility. The result is the current incarnation of this repository.
.dotpriv is a private dotfiles repository that supplement this repository using lookup path mechanism described in How it works. It contained configurations not published here due to privacy and security reasons.