Caution
A wild west of stuff that used to be in the readme, or are notes I wrote for myself. If you got here on an anchor link, that section should be relevant at least. But large chunks are just copy pasted paragraphs that have probably totally lost their initial context by now.
This follows the flat splat pattern of just saying "$HOME
is a repo".
Rather than cloning into something like ~/dotfiles
and using some install.sh
script or stow
, this adopts the pattern that $HOME
is this repository. The magic, is a .gitignore
of just *
, coupled with the intentionality of git add -f
'ing the files that I want tracked here. Using a subfolder and moving config into it and symlinking that back out to home wouldn't reduce the amount of clutter in $HOME
, and it doesn't prevent changes from affecting change to the config files in the subfolder, so there's essentially limited to no benefit to using a subfolder and symlinking into $HOME
(as well as intentionality of adding files to track just transitions from -f
'ing the add
to mv
'ing the file and symlinking it, so there's no less overhead either), especially when I would like to use this across multiple environments that will behave differently with symlinks, including the shadow-realm of being in the context of wsl
when open on a Windows home folder with this checked out!
This is not a unique pattern, but it's not the most common either. On the gh dotfile io tutorial page, Drew's blog post appears to be the only example that suggests / outlines this approach, and it's worth a read.
There are however several ways in which this follows a very specifically modified version of the "$HOME
is a repo" pattern.
... only if you are cloning this. Later on I discuss a very rigid process of adopting these settings as a submodule, which is antithetical to "$HOME
is a repo", but provides a methodology of adopting "core" configuration, while also checking in "extended" configuration, by using the ~/.includes/
files. This is primarily done to facilitate use-cases where you want to keep configuration checked in, but it can't or shouldn't be hosted in a public repository.
... extensible, if you're happy to not check-in your extended configuration (by design). You can clone this, following the steps outlined below that describe how to do the initial setup of your local copy, over the top of an existing $HOME
. Once you have it cloned, it will only track changes to files that are already being tracked, as the .gitignore
of just *
allows us to only track what we intentionally forcefully add. That's not the end though. There's places that "extensible" configuration files might look to try and find files that are optionally sourced or to hook-in, if they exist.
You should read both the ~/.include/.pre/README.md
and the ~/.include/.post/README.md
for examples or suggestions of extensions to place in either folder. The first example you might find necessary, for example, is to create an ~/.include/.post/.bashrc
and add a line that does ssh-add-unloaded-key "Name_of_your_main_ssh_key"
, to have your main ssh key used most frequently loaded. Why not keep something like that in the "core" ~/.bashrc
? Well, on different machines, a different key might be the most frequently used, and if multiple keys that are valid for the same host are added, only the first one that's accepted by a host will be tried for authenticating. So it's easiest across multiple machines that adopt these configs to allow something like that to exist in the "extended" config. Similar reasons exist everything else.
A #TODO
is to add scripts that generate the recommendations contained in ~/.include/.pre/README.md
and the ~/.include/.post/README.md
, but for now, their recommendations are the expected starting point.
The process of using the ~/.include/
configuration files as a way of extending the "core" configuration, with the expectation of not checking in anything under ~/.include/
, lends itself to the possibility of making use of this repository as a submodule in another repository, and symlinking the contents in this onto $HOME
. This is discussed in more detail below.
This is only a #TODO
if I ever have to use a windows device for work again, until then, I can't be bothered.
- If
~
is empty:
cd ~ && git clone https://github.com/Skenvy/dotfiles.git .
- If
~
is NOT empty:
cd ~ && git init && git remote add origin https://github.com/Skenvy/dotfiles.git && git fetch && cp -r .git/refs/remotes/origin/* .git/refs/heads/ && git remote set-head origin -a && REMOTE_HEAD=$(git name-rev origin/HEAD --name-only) && rm .git/refs/heads/* && git checkout -b $REMOTE_HEAD origin/$REMOTE_HEAD -f
- If
~
is NOT empty, and you want to use onlygit
:
cd ~ && git init && git remote add origin https://github.com/Skenvy/dotfiles.git && git fetch && git remote set-head origin -a && HEADSHA=$(git rev-parse origin/HEAD) && git remote set-head origin -d && REMOTE_HEAD=$(git name-rev $HEADSHA --name-only) && git checkout -b main $REMOTE_HEAD -f
- If
~
is NOT empty, and you want to use onlygit
, and you want to use ssh:
cd ~ && git init && git remote add origin [email protected]:Skenvy/dotfiles.git && git fetch && git remote set-head origin -a && HEADSHA=$(git rev-parse origin/HEAD) && git remote set-head origin -d && REMOTE_HEAD=$(git name-rev $HEADSHA --name-only) && git checkout -b main $REMOTE_HEAD -f
- If
~
is NOT empty, you want to use ssh, and force the cutover to these settings:
rm -rf .git/ && cd ~ && git init && git remote add origin [email protected]:Skenvy/dotfiles.git && git fetch && cp -r .git/refs/remotes/origin/* .git/refs/heads/ && git remote set-head origin -a && REMOTE_HEAD=$(git name-rev origin/HEAD --name-only) && rm .git/refs/heads/* && git checkout -b $REMOTE_HEAD origin/$REMOTE_HEAD -f
To use these configs as an extensible base, where you can track this repository and use its contents, you should add this repository as a submodule in your own dotfiles repository, and symlink its contents into $HOME
. This lets you use and stay up-to-date with changes to this, but also allows you to commit any additional files you need, provided they wont just get symlinked over by following this process.
Important
This is specifically geared to my use case of wanting to maintain personal, public, dotfiles that I utilise on personal machines, that I can also utilise on any work machine, for which it would be convenient to use a private repository such that I can commit the .include/*
hooks relevant for work that shouldn't be public, but that I don't want to lose to the ether. This method allows for maintaining these personal, public, dotfiles, that I can submodule into a private, work specific, dotfiles repository, symlink into $HOME
, and commit any .include/*
hooks as they grow.
Of course, this goes against the intentional lack of symlinks in this flat splat of the "$HOME
is a repo" design, but I'm ok with that. You might say that forking this, and tracking this as an upstream would be simpler, but that lacks that immediacy of seperation between "what am I editting in 'my changes on top of this'?" and "am I editting something that I'll need to move back upstream?" -- whereas working with a module lets me see the small changeset of hooks for what they are, and immediately know from a git status
if I need to relocate config changes.
Images are stored in the wiki and sourced in the html of the readme. git clone [email protected]:Skenvy/dotfiles.wiki.git
, then you can find the images in (dotfiles.wiki)/.meta/banners/
and access them via https://raw.githubusercontent.com/wiki/Skenvy/dotfiles/.meta/banners/