diff options
author | Artturi <Artturin@artturin.com> | 2023-09-15 07:37:07 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-09-15 07:37:07 +0300 |
commit | fc21cde24b75e357115daf5c896511a5ac6611fa (patch) | |
tree | cd9aa05d5919005b70f4f23fdc0194fb19c30e37 | |
parent | 014b0d9fba82431165473addaeac391e3d6f351c (diff) | |
parent | fee76f189c53266391aa7485f017de3a51f86461 (diff) |
Merge pull request #91956 from c00w/makebtrfs
-rw-r--r-- | nixos/lib/make-btrfs-fs.nix | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/nixos/lib/make-btrfs-fs.nix b/nixos/lib/make-btrfs-fs.nix new file mode 100644 index 0000000000000..fceeea8d5755b --- /dev/null +++ b/nixos/lib/make-btrfs-fs.nix @@ -0,0 +1,45 @@ +# Builds an btrfs image containing a populated /nix/store with the closure +# of store paths passed in the storePaths parameter, in addition to the +# contents of a directory that can be populated with commands. The +# generated image is sized to only fit its contents, with the expectation +# that a script resizes the filesystem at boot time. +{ pkgs +, lib +# List of derivations to be included +, storePaths +# Shell commands to populate the ./files directory. +# All files in that directory are copied to the root of the FS. +, populateImageCommands ? "" +, volumeLabel +, uuid ? "44444444-4444-4444-8888-888888888888" +, btrfs-progs +}: + +let + sdClosureInfo = pkgs.buildPackages.closureInfo { rootPaths = storePaths; }; +in +pkgs.stdenv.mkDerivation { + name = "btrfs-fs.img"; + + nativeBuildInputs = [ btrfs-progs ]; + + buildCommand = + '' + set -x + ( + mkdir -p ./files + ${populateImageCommands} + ) + + mkdir -p ./files/nix/store + cp ${sdClosureInfo}/registration ./files/nix-path-registration + + # Add the closures of the top-level store objects. + for p in $(cat ${sdClosureInfo}/store-paths); do + echo cp -r $p "./files/nix/store" + done + + touch $out + mkfs.btrfs -L ${volumeLabel} -U ${uuid} -r ./files --shrink $out + ''; +} |