A collection of dotfiles, scripts and configurations from @nickgerace.
Before starting, ensure that bash
and just
are installed on your macOS or Linux system.
The "install" recipe will install zsh
if you opt to install packages, so it is not required to start.
Tip
You can use the devShell
from the flake to get the base depedencies.
You will also need to ensure that this repository resides in the $HOME/src/
directory.
You may need to create it by executing mkdir $HOME/src
.
Warning
Running the following command may overwrite files if you are coming from an existing configuration. Please read the source code, starting from the justfile, before executing the recipe.
Warning
If you are using NixOS or nix-darwin, please read this section!
- If you are using NixOS and would like to install packages via the installation script, remove the import code for si-device-compliance. The linked location is the only location in the repository containing the compliance code.
- For both NixOS and nix-darwin, if you decide to install packages in addition to the dotfiles, you will likely need to change the relevant configuration files. Not only would the hardware configurations need to change, but also the hostnames, the compliance check code, etc.
- For both NixOS and nix-darwin, if you are only installing dotfiles and not packages, you can skip the rest of this section.
Recommendation: use the Nix-related stuff for inspiration rather than using the configurations "as-is". The dotfiles are portable, but the configurations are not without edits.
Once everything looks good, execute the following and you will be presented with some options that you'll need to choose:
just install
The invoked just
recipe runs an idempotent-ish bootstrap script, so you should be able to execute it multiple times.
That being said: caution is advised.
Once the initial just
recipe is ran, you can update packages and more using the update
recipe.
just update
Alternatively, if you run sz
or reload your shell, you can run the update function.
update
Note
The above commands only update packages with the current dotfiles in place.
If you'd like to re-link dotfiles, run just install
again.
This section contains questions and answers regarding these dotfiles.
These dotfiles rely on zsh
as the interactive shell.
These dotfiles require neither oh-my-zsh
nor starship
to be installed.
Only zsh
needs to be installed as all shell-based dotfiles are custom and configured manually.
The script only sets up dotfiles by default. However, for certain Linux distributions and macOS, you can optionally install packages and setup the base system (e.g. install an opinionated set of base packages with a package manager). This is referred to "bootstrapping" in the script.
WSL2 is supported for dotfiles setup, but packages will not be installed for supported distros when running the installer.
Files not recently in use may be out of date. This is a "living" repository, meaning that scripts and dotfiles more frequently in use will be more likely to be kept up to date. Anything not recently or frequently in use will be removed from the repository (eventually).