Ben Kyd 585a5298ad based
2026-03-26 20:29:35 +00:00
2026-03-11 13:24:07 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00
2026-03-11 13:24:07 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00
2026-03-26 20:29:35 +00:00

dotfiles

Centralized database of how my machines should be set up. All Macs are identical to each other, all Arch machines are identical to each other. OS is the only axis of variation.

dotfiles/
  home/benk/            mirrors $HOME — files here get synced to the machine
  etc/                  mirrors /etc — applied with sudo on Linux
  packages/
    brew.txt            Homebrew formulae (all Macs)
    brew-casks.txt      Homebrew casks (all Macs)
    arch.txt            yay packages (all Arch machines)
  themes/
    catppuccin-iterm/   submodule: catppuccin/iterm
  setup.toml            declarative tooling config (fish + tmux plugins)
  bootstrap.py          the manager — run this

setup

git clone --recurse-submodules git@github.com:benkyd/dotfiles.git ~/dotfiles
cd ~/dotfiles
python3 bootstrap.py

Dependencies (rich, questionary) are auto-installed on first run.

usage

Running python3 bootstrap.py drops you into a TUI. Pick a mode:

  • Set up this machine — install packages, shell tooling, sync dotfiles. use this on a fresh machine.
  • Apply dotfiles — push repo → $HOME. skips packages.
  • Save changes — pull edits you made on this machine back into the repo.
  • Check status — see what's drifted. nothing is changed.

Or pass a mode directly to skip the TUI:

python3 bootstrap.py install
python3 bootstrap.py copy
python3 bootstrap.py pull
python3 bootstrap.py status
python3 bootstrap.py add ~/.config/something.conf   # start tracking a new file

per-file variation

If you've edited something on a work machine and don't want to clobber it or pull it back, the sync steps show a per-file checkbox for any file that's newer on the machine than in the repo. just uncheck what you want to skip.

OS-specific paths

Some paths only make sense on one OS and are excluded automatically:

  • Library/ — macOS only (iTerm2 prefs, etc.)
  • .config/wezterm/ — Linux only (iTerm2 is used on Mac)

themes

Catppuccin Mocha is the colour scheme. The iTerm2 colour preset lives at themes/catppuccin-iterm/colors/catppuccin-mocha.itermcolors. Import it via iTerm2 → Profiles → Colors → Color Presets → Import.

Description
Personal configuration files for various applications
Readme 46 MiB
Languages
Python 43.3%
Lua 30.8%
Shell 17.8%
Perl 4.2%
SCSS 3.8%
Other 0.1%