Add documentation 🤯
Say whaaaaat?
This commit is contained in:
parent
25011a3353
commit
c9156044f8
37
README.md
Normal file
37
README.md
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
# Geoffrey Frogeye's dotfiles
|
||||||
|
|
||||||
|
This repo holds most of my systems configuration.
|
||||||
|
It is built on top of the Nix ecosystem
|
||||||
|
|
||||||
|
## Directory structure
|
||||||
|
|
||||||
|
- `os`, `hm`, `nod`: Re-usable configuration for [NixOS](https://nixos.org/), [home-manager](https://github.com/nix-community/home-manager/#home-manager-using-nix), [Nix-on-Droid](https://github.com/nix-community/nix-on-droid#nix-on-droid) respectively
|
||||||
|
- `<module-name>`: Module. Used to separate configuration in separate logical units.
|
||||||
|
- `default.nix`: Entrypoint for that module. Contains Nix configuration for the module.
|
||||||
|
- `<other file>`: Extra files: scripts to be installed, or ... whatever.
|
||||||
|
- `default.nix`: Entrypoint for that system. Import all the modules.
|
||||||
|
- `<other file>`: Files non-conforming to the structure above because I'm hurrying to have everything working before cleaning.
|
||||||
|
- `dk`: Re-usable configuration for [disko](https://github.com/nix-community/disko#disko---declarative-disk-partitioning)
|
||||||
|
- `<name>.nix`: Partitionning scheme configuration. Don't assume a specific context, it will be imported as Disko and NixOS config.
|
||||||
|
- `options.nix`: Definition of options exposed to all systems (even though if not relevant for all, it's for simplicity sake).
|
||||||
|
- `<profile-name>` (e.g. `curacao`): Configurations for my different devices
|
||||||
|
- `options.nix`: Common options configuration. Don't assume a specific context (for reasons unclear, I'm sure I can do something with that).
|
||||||
|
- `hardware.nix`: NixOS configuration for that specific device.
|
||||||
|
- `dk.nix`: Partitionning configuration. Import a top-level `dk` scheme, adding disks ids and other configuration required.
|
||||||
|
- `os.nix`, `hm.nix`, `nod.nix`: Entrypoint for the device/system configuration. Imports the above files (last two only for NixOS) and contains configuration specific to this combination.
|
||||||
|
- `<profile-name>_<media>` (e.g. `pindakaas_sd`): Alternate configuration for a device. Used to test a configuration without altering the "main" one.
|
||||||
|
- `options.nix`: Same as above. Can be a symlink.
|
||||||
|
- `hardware.nix`: Same as above. Should be a symlink.
|
||||||
|
- `dk.nix`: Same as above. Should not be a symlink.
|
||||||
|
- `os.nix`, `hm.nix`, `nod.nix`: Same as above. Should not be a symlink.
|
||||||
|
|
||||||
|
## Scripts
|
||||||
|
|
||||||
|
They all have a `-h` flag.
|
||||||
|
Except `add_channels.sh`, which should be removed as soon as I migrate to Flakes.
|
||||||
|
|
||||||
|
## Extensions
|
||||||
|
|
||||||
|
There's some things I'm not putting in this public repo: work-related things, and other sensitive things that probably shouldn't be public.
|
||||||
|
Those are stored in extensions, i.e. repos with a similar structure to this one, and ultimately importing things from it.
|
||||||
|
This is why you might see options not being seemingly used.
|
|
@ -8,6 +8,7 @@ SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
||||||
# Parse arguments
|
# Parse arguments
|
||||||
function help {
|
function help {
|
||||||
echo "Usage: $0 [-h|-v|-b] profile"
|
echo "Usage: $0 [-h|-v|-b] profile"
|
||||||
|
echo "Build NixOS configuration on the local machine."
|
||||||
echo
|
echo
|
||||||
echo "Arguments:"
|
echo "Arguments:"
|
||||||
echo " profile: OS/disk profile to use"
|
echo " profile: OS/disk profile to use"
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
../os
|
../os
|
||||||
./options.nix
|
./options.nix
|
||||||
./hardware.nix
|
./hardware.nix
|
||||||
./disko.nix
|
./dk.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
networking.hostName = "curacao";
|
networking.hostName = "curacao";
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
../os
|
../os
|
||||||
../curacao/options.nix
|
../curacao/options.nix
|
||||||
../curacao/hardware.nix
|
../curacao/hardware.nix
|
||||||
./disko.nix
|
./dk.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
networking.hostName = "curacao_usb";
|
networking.hostName = "curacao_usb";
|
||||||
|
|
|
@ -8,13 +8,14 @@ SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
||||||
# Parse arguments
|
# Parse arguments
|
||||||
function help {
|
function help {
|
||||||
echo "Usage: $0 [-h|-e] profile"
|
echo "Usage: $0 [-h|-e] profile"
|
||||||
|
echo "Install NixOS on a device."
|
||||||
echo
|
echo
|
||||||
echo "Arguments:"
|
echo "Arguments:"
|
||||||
echo " profile: OS/disk profile to use"
|
echo " profile: OS/disk profile to use"
|
||||||
echo
|
echo
|
||||||
echo "Options:"
|
echo "Options:"
|
||||||
echo " -h: Display this help message."
|
echo " -h: Display this help message."
|
||||||
echo " -e: Erase the disk. This can be used in case the wanted partition scheme doesn't match."
|
echo " -e: Erase the disk. For cases where the partition scheme doesn't match the existing one."
|
||||||
}
|
}
|
||||||
|
|
||||||
disko_mode=mount
|
disko_mode=mount
|
||||||
|
@ -49,7 +50,7 @@ then
|
||||||
echo "Profile not found."
|
echo "Profile not found."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
disko_config="${profile_dir}/disko.nix"
|
disko_config="${profile_dir}/dk.nix"
|
||||||
if [ ! -f "$disko_config" ]
|
if [ ! -f "$disko_config" ]
|
||||||
then
|
then
|
||||||
echo "Disk configuration not found."
|
echo "Disk configuration not found."
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
imports = [
|
imports = [
|
||||||
../os
|
../os
|
||||||
./hardware.nix
|
./hardware.nix
|
||||||
./disko.nix
|
./dk.nix
|
||||||
./options.nix
|
./options.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
../os
|
../os
|
||||||
../pindakaas/options.nix
|
../pindakaas/options.nix
|
||||||
../pindakaas/hardware.nix
|
../pindakaas/hardware.nix
|
||||||
./disko.nix
|
./dk.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
networking.hostName = "pindakaas_sd";
|
networking.hostName = "pindakaas_sd";
|
||||||
|
|
Loading…
Reference in a new issue