Or in other words, welcome to my configs! This contains everything I personally use and need in order to use a new machine.
Helpers for setting up a system ready for usage.
The main script here is distribute_symlinks
.
It "spreads" symlinks across the system targeting e.g. config
.
What you're probably here for.
Program-specific configuration.
Graphics and accompanying art.
Mostly managed with Git LFS in order to avoid blowing up repo size.
Nix shells, resources and other things that are usually not touched directly.
Protip: You can launch any shell in lib/nix/shell
using the shell
function as defined in this repo's zshrc
!
Things that should be on $PATH
,
i.e. that should be runnable without specifying their full path.
While they are categorized into folders here,
all folders in there (recursively) end up flattened on $PATH
.
The categories are:
Anything that is called by "automations", for example window manager hotkeys or shell helpers.
You usually don't need to call them directly on the terminal.
Facilitate interaction with elusive,
see system/elusive
for details.
Don't perform any meaningful work on their own. Usually expose some interesting variables and functions.
For example, path/lib/_initenv
takes care of configuring $PATH
such that everything
in here can be found,
but needs to be source
d from another shell for that.
System maintenance commands.
Currently just NixOS generation management.
Cute small scripts that make frequent tasks easier.
For example, path/script/clean
cleans the filesystem of build directories and redundant PDFs.
Pretend to be a program. Maybe even are that program just with some spice added!
Utilities for building a NixOS configuration.
While you don't have to use it in order to use the other elements here, it takes care of setting up all services, installing all programs and the works.
Note
This will install all configs without asking,
overwriting previous configs with the same name.
Did I mention that the scripts used are hardcoded to /home/multisn8
as the home path for the time being?
Yeah, this tells a lot about when it should be used by you — never,
at least not without extensive change.
Take these configs as reference, not as template.
Examine where I went wrong in your opinion, and do it better.
A script automating all this may be provided in future.
- Install NixOS onto disk
- Set up a
multisn8
user - Set up the
nixos-unstable
channel - Update all channels
- Clone this repository to
~/zero/core
- Run
bootstrap/distribute_symlinks.py
- Symlink
$(pwd)/system
to/etc/nixos
- Run
nixos-generate-config
- Adjust
configuration.nix
to use modules fromgeneralized
as desired - Run
sudo nixos-rebuild boot && reboot
Example configuration.nix
:
# vim: ts=2 sw=2 et
{ config, pkgs, lib, ... }:
{
imports =
[
./hardware-configuration.nix
./generalized.nix
./desktop.nix
];
generalized = {
hostName = "no";
wireless.wlan = true;
externalInterface = "wlan0";
ssd = true;
ssh = true;
xorg = true;
wayland = true;
audio = true;
profileGuided = true;
video.driver = "nvidia";
};
# Before changing this value read the documentation for this option
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
system.stateVersion = "24.05"; # Did you read the comment?
}
Note: Untested. At your own risk.
mkdir -p ~/zero
git clone https://github.com/MultisampledNight/core ~/zero/core
cd ~/zero/core
./bootstrap/distribute_symlinks.py --only-user --user $USER
You'll need to get the Neovim plugins from somewhere else though then.
Open-source is awesome. If something doesn't work, I can try to look into it and possibly even help fixing it.
At some point I'd like for everything in my config to be fully open-source. The exceptions stopping that at the moment are:
- CUDA: I still have an Nvidia GPU, and in order to use it meaningfully, I unfortunately need CUDA. It starts breaking though, maybe I'll get something else soon.
- Steam (and all applications installed through it): Most games aren't open-source.
The codename for the system I use for constructing VMs! Check the elusive README for details.
Usually the folder ~/zero
.
Where all of the stuff that is made for me stores stuff for me.
Imagine it like a "system" folder that contains information for the system
itself.
I'm not following the XDG spec here to avoid having other software pollute my state. However, you're free to ask if a mechanism could be made standalone — I'm very much interested in keeping software which is used by others standards-compilant.
zero
starts with the letter z
,
so it's always listed at the bottom
of descendingly alphabetically sorted lists.
It also serves semantically well for being the identity element of addition of the real numbers. After all, this folder is what makes this system my system. It is the basis I build my reality on.
(Fun fact: zero
used to be named zukunftslosigkeit
,
German for "lack of future".
That was both too long and too depressing.)
Usually the folder ~/zero/core
.
The defining heart of my system.
It is this very repository you're looking at and
configures everything in and around my system.
This is an Undertale reference. I refuse to elaborate further. Please do go play Undertale if you haven't yet. It is an awesome game. It might reveal a lot about you.