Skip to content

Lib

Usage

snowfall-lib provides two utilities directly on the flake itself.

mkLib

The library generator function. This is the entrypoint for snowfall-lib and is how you access all of its features. See the following Nix Flake example for how to create a library instance with mkLib.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
# You can optionally place your Snowfall-related files in another
# directory.
snowfall.root = ./nix;
};
in
# We'll cover what to do here next.
{ };
}

For information on how to use lib, see the lib section. Or skip directly to lib.mkFlake to see how to configure your flake’s outputs.

mkFlake

A convenience wrapper for writing the following.

let
lib = inputs.snowfall-lib.mkLib {
inherit inputs;
src = ./.;
# You can optionally place your Snowfall-related files in another
# directory.
snowfall.root = ./nix;
};
in lib.mkFlake {
}

Instead, with mkFlake you can combine these calls into one like the following.

inputs.snowfall-lib.mkFlake {
inherit inputs;
src = ./.;
};

See lib.mkFlake for information on how to configure your flake’s outputs.

lib

Snowfall Lib provides utilities for creating flake outputs as well as some necessary helpers. In addition, lib is an extension of nixpkgs.lib and every flake input that contains a lib attribute. This means that you can use lib directly for all of your needs, whether they’re Snowfall-related, NixPkgs-related, or for one of the other flake inputs.

The way that mkLib merges libraries is by starting with the base nixpkgs.lib and then merge each flake input’s lib attribute, namespaced by the name of the input. For example, if you have the input flake-utils-plus then you will be able to use lib.flake-utils-plus instead of having to keep a reference to the input’s lib at inputs.flake-utils-plus.lib.

If you have your own library in a lib/ directory at your flake’s root, definitions in there will automatically be imported and merged as well.

When producing flake outputs with mkFlake or another Snowfall lib utility, lib will be passed in as an input. All of this together gives you easy access to a common library of utilities and easy access to the libraries of flake inputs or your own custom library.

lib.mkFlake

The lib.mkFlake function creates full flake outputs. For most cases you will only need to use this helper and the Snowfall lib will take care of everything else.

Flake Structure

Snowfall Lib has opinions about how a flake’s files are laid out. This lets lib do all of the busy work for you and allows you to focus on creating. Here is the structure that lib expects to find at the root of your flake.

snowfall-root/
│ The Snowfall root defaults to "src", but can be changed by setting "snowfall.root".
│ This is useful if you want to add a flake to a project, but don't want to clutter the
│ root of the repository with directories.
│ Your Nix flake.
├─ flake.nix
│ An optional custom library.
├─ lib/
│ │
│ │ A Nix function called with `inputs`, `snowfall-inputs`, and `lib`.
│ │ The function should return an attribute set to merge with `lib`.
│ ├─ default.nix
│ │
│ │ Any (nestable) directory name.
│ └─ **/
│ │
│ │ A Nix function called with `inputs`, `snowfall-inputs`, and `lib`.
│ │ The function should return an attribute set to merge with `lib`.
│ └─ default.nix
│ An optional set of packages to export.
├─ packages/
│ │
│ │ Any (nestable) directory name. The name of the directory will be the
│ │ name of the package.
│ └─ **/
│ │
│ │ A Nix package to be instantiated with `callPackage`. This file
│ │ should contain a function that takes an attribute set of packages
│ │ and *required* `lib` and returns a derivation.
│ └─ default.nix
├─ modules/ (optional modules)
│ │
│ │ A directory named after the `platform` type that will be used for modules within.
│ │
│ │ Supported platforms are:
│ │ - nixos
│ │ - darwin
│ │ - home
│ └─ <platform>/
│ │
│ │ Any (nestable) directory name. The name of the directory will be the
│ │ name of the module.
│ └─ **/
│ │
│ │ A NixOS module.
│ └─ default.nix
├─ overlays/ (optional overlays)
│ │
│ │ Any (nestable) directory name.
│ └─ **/
│ │
│ │ A custom overlay. This file should contain a function that takes three arguments:
│ │ - An attribute set of your flake's inputs and a `channels` attribute containing
│ │ all of your available channels (eg. nixpkgs, unstable).
│ │ - The final set of `pkgs`.
│ │ - The previous set of `pkgs`.
│ │
│ │ This function should return an attribute set to merge onto `pkgs`.
│ └─ default.nix
├─ systems/ (optional system configurations)
│ │
│ │ A directory named after the `system` type that will be used for all machines within.
│ │
│ │ The architecture is any supported architecture of NixPkgs, for example:
│ │ - x86_64
│ │ - aarch64
│ │ - i686
│ │
│ │ The format is any supported NixPkgs format *or* a format provided by either nix-darwin
│ │ or nixos-generators. However, in order to build systems with nix-darwin or nixos-generators,
│ │ you must add `darwin` and `nixos-generators` inputs to your flake respectively. Here
│ │ are some example formats:
│ │ - linux
│ │ - darwin
│ │ - iso
│ │ - install-iso
│ │ - do
│ │ - vmware
│ │
│ │ With the architecture and format together (joined by a hyphen), you get the name of the
│ │ directory for the system type.
│ └─ <architecture>-<format>/
│ │
│ │ A directory that contains a single system's configuration. The directory name
│ │ will be the name of the system.
│ └─ <system-name>/
│ │
│ │ A NixOS module for your system's configuration.
│ └─ default.nix
├─ homes/ (optional homes configurations)
│ │
│ │ A directory named after the `home` type that will be used for all homes within.
│ │
│ │ The architecture is any supported architecture of NixPkgs, for example:
│ │ - x86_64
│ │ - aarch64
│ │ - i686
│ │
│ │ The format is any supported NixPkgs format *or* a format provided by either nix-darwin
│ │ or nixos-generators. However, in order to build systems with nix-darwin or nixos-generators,
│ │ you must add `darwin` and `nixos-generators` inputs to your flake respectively. Here
│ │ are some example formats:
│ │ - linux
│ │ - darwin
│ │ - iso
│ │ - install-iso
│ │ - do
│ │ - vmware
│ │
│ │ With the architecture and format together (joined by a hyphen), you get the name of the
│ │ directory for the home type.
│ └─ <architecture>-<format>/
│ │
│ │ A directory that contains a single home's configuration. The directory name
│ │ will be the name of the home.
│ └─ <home-name>/
│ │
│ │ A NixOS module for your home's configuration.
│ └─ default.nix

Default Flake

Without any extra input, lib.mkFlake will generate outputs for all systems, modules, packages, overlays, and shells specified by the Flake Structure section.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
};
in
lib.mkFlake { };
}

Snowfall Configuration

Snowfall Lib supports configuring some functionality and interopability with other tools via the snowfall attribute passed to mkLib.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
snowfall = {
namespace = "my-namespace";
meta = {
# Your flake's preferred name in the flake registry.
name = "my-flake";
# A pretty name for your flake.
title = "My Flake";
};
};
};
in
lib.mkFlake { };
}

External Overlays And Modules

You can apply overlays and modules from your flake’s inputs with the following options.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
};
in
lib.mkFlake {
# Add overlays for the `nixpkgs` channel.
overlays = with inputs; [
# my-inputs.overlays.my-overlay
];
# Add modules to all NixOS systems.
systems.modules.nixos = with inputs; [
# my-input.nixosModules.my-module
];
# Add modules to all Darwin systems.
systems.modules.darwin = with inputs; [
# my-input.darwinModules.my-module
];
# Add modules to a specific system.
systems.hosts.my-host = with inputs; [
# my-input.nixosModules.my-module
];
# Add modules to all homes.
homes.modules = with inputs; [
# my-input.homeModules.my-module
];
# Add modules to a specific home.
homes.users."my-user@my-host".modules = with inputs; [
# my-input.homeModules.my-module
];
};
}

Internal Packages And Outputs

Packages created from your packages/ directory are automatically made available via an overlay for your nixpkgs channel. System configurations can access these packages directly on pkgs and consumers of your flake can use the generated <your-flake>.overlays attributes.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
comma = {
url = "github:nix-community/comma";
inputs.nixpkgs.follows = "unstable";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
};
in
lib.mkFlake {
# Optionally place all packages under a namespace when used in an overlay.
# Instead of accessing packages with `pkgs.<name>`, your internal packages
# will be available at `pkgs.<namespace>.<name>`.
snowfall.namespace = "my-namespace";
# You can also pass through external packages or dynamically create new ones
# in addition to the ones that `lib` will create from your `packages/` directory.
outputs-builder = channels: {
packages = {
comma = inputs.comma.packages.${channels.nixpkgs.system}.comma;
};
};
};
}

Default Packages And Shells

Snowfall Lib will create packages and shells based on your packages/ and shells directories. However, it is common to additionally map one of those packages or shells to be their respective default. This can be achieved by setting an alias and mapping the default package or shell to the name of the one you want.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
};
in
lib.mkFlake {
alias = {
packages = {
default = "my-package";
};
shells = {
default = "my-shell";
};
checks = {
default = "my-check";
};
modules = {
nixos.default = "my-nixos-module";
darwin.default = "my-darwin-module";
home.default = "my-home-module";
};
templates = {
default = "my-template";
};
};
};
}

Darwin And NixOS Generators

Snowfall Lib has support for configuring macOS systems and building any output supported by NixOS Generators. In order to use these features, your flake must include darwin and/or nixos-generators as inputs.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
# In order to configure macOS systems.
darwin = {
url = "github:lnl7/nix-darwin";
inputs.nixpkgs.follows = "nixpkgs";
};
# In order to build system images and artifacts supported by nixos-generators.
nixos-generators = {
url = "github:nix-community/nixos-generators";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
};
in
# No additional configuration is required to use this feature, you only
# have to add darwin or nixos-generators to your flake inputs.
lib.mkFlake { };
}

Any macOS systems will be available on your flake at darwinConfigurations for use with darwin-rebuild. Any system type supported by NixOS Generators will be available on your flake at <format>Configurations where <format> is the name of the generator type. See the following table for a list of supported formats from NixOS Generators.

formatdescription
amazonAmazon EC2 image
azureMicrosoft azure image (Generation 1 / VHD)
cloudstackqcow2 image for cloudstack
doDigital Ocean image
gceGoogle Compute image
hypervHyper-V Image (Generation 2 / VHDX)
install-isoInstaller ISO
install-iso-hypervInstaller ISO with enabled hyper-v support
isoISO
kexeckexec tarball (extract to / and run /kexec_nixos)
kexec-bundleSame as before, but it’s just an executable
kubevirtKubeVirt image
lxcCreate a tarball which is importable as an lxc container, use together with lxc-metadata
lxc-metadataThe necessary metadata for the lxc image to start
openstackqcow2 image for openstack
proxmoxVMA file for proxmox
qcowqcow2 image
rawRaw image with bios/mbr
raw-efiRaw image with efi support
sd-aarch64Like sd-aarch64-installer, but does not use default installer image config.
sd-aarch64-installercreate an installer sd card for aarch64
vagrant-virtualboxVirtualBox image for Vagrant
virtualboxvirtualbox VM
vmOnly used as a qemu-kvm runner
vm-bootloaderSame as vm, but uses a real bootloader instead of netbooting
vm-noguiSame as vm, but without a GUI
vmwareVMWare image (VMDK)

Home Manager

Snowfall Lib supports configuring Home Manager for both standalone use and for use as a module with NixOS or nix-darwin. To use this feature, your flake must include home-manager as an input.

{
description = "My Flake";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
snowfall-lib = {
url = "github:snowfallorg/lib";
inputs.nixpkgs.follows = "nixpkgs";
};
# In order to use Home Manager.
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = inputs:
# This is an example and in your actual flake you can use `snowfall-lib.mkFlake`
# directly unless you explicitly need a feature of `lib`.
let
lib = inputs.snowfall-lib.mkLib {
# You must pass in both your flake's inputs and the root directory of
# your flake.
inherit inputs;
src = ./.;
};
in
# No additional configuration is required to use this feature, you only
# have to add home-manager to your flake inputs.
lib.mkFlake { };
}

lib.snowfall.flake

Helpers related to Nix flakes.

lib.snowfall.flake.without-self

Remove the self attribute from an attribute set.

Type: Attrs -> Attrs

Usage:

without-self { self = {}; x = true; }

Result:

{ x = true; }

lib.snowfall.flake.without-src

Remove the src attribute from an attribute set.

Type: Attrs -> Attrs

Usage:

without-src { src = {}; x = true; }

Result:

{ x = true; }

lib.snowfall.flake.without-snowfall-inputs

Remove the src and self attributes from an attribute set.

Type: Attrs -> Attrs

Usage:

without-snowfall-inputs { self = {}; src = {}; x = true; }

Result:

{ x = true; }

lib.snowfall.flake.get-libs

Transform an attribute set of inputs into an attribute set where the values are the inputs’ lib attribute. Entries without a lib attribute are removed.

Type: Attrs -> Attrs

Usage:

get-lib { x = nixpkgs; y = {}; }

Result:

{ x = nixpkgs.lib; }

lib.snowfall.path

lib.snowfall.path.split-file-extension

Split a file name and its extension.

Type: String -> [String]

Usage:

split-file-extension "my-file.md"

Result:

[ "my-file" "md" ]

lib.snowfall.path.has-any-file-extension

Check if a file name has a file extension.

Type: String -> Bool

Usage:

has-any-file-extension "my-file.txt"

Result:

true

lib.snowfall.path.get-file-extension

Get the file extension of a file name.

Type: String -> String Usage:

get-file-extension "my-file.final.txt"

Result:

"txt"

lib.snowfall.path.has-file-extension

Check if a file name has a specific file extension.

Type: String -> String -> Bool

Usage:

has-file-extension "txt" "my-file.txt"

Result:

true

lib.snowfall.path.get-parent-directory

Get the parent directory for a given path.

Type: Path -> Path

Usage:

get-parent-directory "/a/b/c"

Result:

"/a/b"

lib.snowfall.path.get-file-name-without-extension

Get the file name of a path without its extension.

Type: Path -> String

Usage:

get-file-name-without-extension ./some-directory/my-file.pdf

Result:

"my-file"

lib.snowfall.fs

File system utilities.

lib.snowfall.fs.is-file-kind

lib.snowfall.fs.is-directory-kind

lib.snowfall.fs.is-unknown-kind

Matchers for file kinds. These are often used with readDir.

Type: String -> Bool

Usage:

is-file-kind "directory"

Result:

false

lib.snowfall.fs.get-file

Get a file path relative to the user’s flake.

Type: Path -> Path

Usage:

get-file "systems"

Result:

"/user-source/systems"

lib.snowfall.fs.get-snowfall-file

Get a file path relative to the user’s snowfall directory.

Type: Path -> Path

Usage:

get-snowfall-file "systems"

Result:

"/user-source/snowfall-dir/systems"

lib.snowfall.fs.internal-get-file

Get a file relative to the Snowfall Lib flake. You probably shouldn’t use this!

Type: Path -> Path

Usage:

get-file "systems"

Result:

"/snowfall-lib-source/systems"

lib.snowfall.fs.safe-read-directory

Safely read from a directory if it exists.

Type: Path -> Attrs

Usage:

safe-read-directory ./some/path

Result:

{ "my-file.txt" = "regular"; }

lib.snowfall.fs.get-directories

Get directories at a given path.

Type: Path -> [Path]

Usage:

get-directories ./something

Result:

[ "./something/a-directory" ]

lib.snowfall.fs.get-files

Get files at a given path.

Type: Path -> [Path]

Usage:

get-files ./something

Result:

[ "./something/a-file" ]

lib.snowfall.fs.get-files-recursive

Get files at a given path, traversing any directories within.

Type: Path -> [Path]

Usage:

get-files-recursive ./something

Result:

[ "./something/some-directory/a-file" ]

lib.snowfall.fs.get-nix-files

Get nix files at a given path.

Type: Path -> [Path]

Usage:

get-nix-files "./something"

Result:

[ "./something/a.nix" ]

lib.snowfall.fs.get-nix-files-recursive

Get nix files at a given path, traversing any directories within.

Type: Path -> [Path]

Usage:

get-nix-files "./something"

Result:

[ "./something/a.nix" ]

lib.snowfall.fs.get-default-nix-files

Get nix files at a given path named “default.nix”.

Type: Path -> [Path]

Usage:

get-default-nix-files "./something"

Result:

[ "./something/default.nix" ]

lib.snowfall.fs.get-default-nix-files-recursive

Get nix files at a given path named “default.nix”, traversing any directories within.

Type: Path -> [Path]

Usage:

get-default-nix-files-recursive "./something"

Result:

[ "./something/some-directory/default.nix" ]

lib.snowfall.fs.get-non-default-nix-files

Get nix files at a given path not named “default.nix”.

Type: Path -> [Path]

Usage:

get-non-default-nix-files "./something"

Result:

[ "./something/a.nix" ]

lib.snowfall.fs.get-non-default-nix-files-recursive

Get nix files at a given path not named “default.nix”, traversing any directories within.

Type: Path -> [Path]

Usage:

get-non-default-nix-files-recursive "./something"

Result:

[ "./something/some-directory/a.nix" ]

lib.snowfall.module

Utilities for working with NixOS modules.

lib.snowfall.module.create-modules

Create flake output modules.

Type: Attrs -> Attrs

Usage:

create-modules { src = ./my-modules; overrides = { inherit another-module; }; alias = { default = "another-module" }; }

Result:

{ another-module = ...; my-module = ...; default = ...; }

lib.snowfall.attrs

Utilities for working with attribute sets.

lib.snowfall.attrs.map-concat-attrs-to-list

Map and flatten an attribute set into a list.

Type: (a -> b -> [c]) -> Attrs -> [c]

Usage:

map-concat-attrs-to-list (name: value: [name value]) { x = 1; y = 2; }

Result:

[ "x" 1 "y" 2 ]

lib.snowfall.attrs.merge-deep

Recursively merge a list of attribute sets.

Type: [Attrs] -> Attrs

Usage:

merge-deep [{ x = 1; } { x = 2; }]

Result:

{ x = 2; }

lib.snowfall.attrs.merge-shallow

Merge the root of a list of attribute sets.

Type: [Attrs] -> Attrs

Usage:

merge-shallow [{ x = 1; } { x = 2; }]

Result:

{ x = 2; }

lib.snowfall.attrs.merge-shallow-packages

Merge shallow for packages, but allow one deeper layer of attributes sets.

Type: [Attrs] -> Attrs

Usage:

merge-shallow-packages [
{
inherit (pkgs) vim;
namespace.first = 1;
}
{
inherit (unstable) vim;
namespace.second = 2;
}
]

Result:

{
vim = {/* the vim package from the last entry */};
namespace = {
first = 1;
second = 2;
};
}

lib.snowfall.system

lib.snowfall.system.is-darwin

Check whether a named system is macOS.

Type: String -> Bool

Usage:

is-darwin "x86_64-linux"

Result:

false

lib.snowfall.system.is-linux

Check whether a named system is Linux.

Type: String -> Bool

Usage:

is-linux "x86_64-linux"

Result:

false

lib.snowfall.system.is-virtual

Check whether a named system is virtual.

Type: String -> Bool

Usage:

is-linux "x86_64-iso"

Result:

true

lib.snowfall.system.get-virtual-system-type

Get the virtual system type of a system target.

Type: String -> String

Usage:

get-virtual-system-type "x86_64-iso"

Result:

"iso"

lib.snowfall.system.get-inferred-system-name

Get the name of a system based on its file path.

Type: Path -> String

Usage:

get-inferred-system-name "/systems/my-system/default.nix"

Result:

"my-system"

lib.snowfall.system.get-target-systems-metadata

Get structured data about all systems for a given target.

Type: String -> [Attrs]

Usage:

get-target-systems-metadata "x86_64-linux"

Result:

[ { target = "x86_64-linux"; name = "my-machine"; path = "/systems/x86_64-linux/my-machine"; } ]

lib.snowfall.system.get-system-builder

Get the system builder for a given target.

Type: String -> Function

Usage:

get-system-builder "x86_64-iso"

Result:

(args: <system>)

lib.snowfall.system.get-system-output

Get the flake output attribute for a system target.

Type: String -> String

Usage:

get-system-output "aarch64-darwin"

Result:

"darwinConfigurations"

lib.snowfall.system.get-resolved-system-target

Get the resolved (non-virtual) system target.

Type: String -> String

Usage:

get-resolved-system-target "x86_64-iso"

Result:

"x86_64-linux"

lib.snowfall.system.create-system

Create a system.

Type: Attrs -> Attrs

Usage:

create-system { path = ./systems/my-system; }

Result:

<flake-utils-plus-system-configuration>

lib.snowfall.system.create-systems

Create all available systems.

Type: Attrs -> Attrs

Usage:

create-systems { hosts.my-host.specialArgs.x = true; modules.nixos = [ my-shared-module ]; }

Result:

{ my-host = <flake-utils-plus-system-configuration>; }

lib.snowfall.home

lib.snowfall.home.split-user-and-host

Get the user and host from a combined string.

Type: String -> Attrs

Usage:

split-user-and-host "myuser@myhost"

Result:

{ user = "myuser"; host = "myhost"; }

lib.snowfall.home.create-home

Create a home.

Type: Attrs -> Attrs

Usage:

create-home { path = ./homes/my-home; }

Result:

<flake-utils-plus-home-configuration>

lib.snowfall.home.create-homes

Create all available homes.

Type: Attrs -> Attrs

Usage:

create-homes { users."my-user@my-system".specialArgs.x = true; modules = [ my-shared-module ]; }

Result:

{ "my-user@my-system" = <flake-utils-plus-home-configuration>; }

lib.snowfall.home.get-target-homes-metadata

Get structured data about all homes for a given target.

Type: String -> [Attrs]

Usage:

get-target-homes-metadata ./homes

Result:

[ { system = "x86_64-linux"; name = "my-home"; path = "/homes/x86_64-linux/my-home";} ]

lib.snowfall.home.create-home-system-modules

Create system modules for home-manager integration.

Type: Attrs -> [Module]

Usage:

create-home-system-modules { users."my-user@my-system".specialArgs.x = true; modules = [ my-shared-module ]; }

Result:

[Module]

lib.snowfall.package

Utilities for working with flake packages.

lib.snowfall.package.create-packages

Create flake output packages.

Type: Attrs -> Attrs

Usage:

create-packages { inherit channels; src = ./my-packages; overrides = { inherit another-package; }; alias = { default = "another-package"; }; }

Result:

{ another-package = ...; my-package = ...; default = ...; }

lib.snowfall.shell

Utilities for working with flake dev shells.

lib.snowfall.shell.create-shell

Create flake output packages.

Type: Attrs -> Attrs

Usage:

create-shells { inherit channels; src = ./my-shells; overrides = { inherit another-shell; }; alias = { default = "another-shell"; }; }

Result:

{ another-shell = ...; my-shell = ...; default = ...; }

lib.snowfall.overlay

Utilities for working with channel overlays.

lib.snowfall.overlay.create-overlays-builder

Create a flake-utils-plus overlays builder.

Type: Attrs -> Attrs -> [(a -> b -> c)]

Usage:

create-overlays-builder { src = ./my-overlays; namespace = "my-namespace"; extra-overlays = []; }

Result:

(channels: [ ... ])

lib.snowfall.overlay.create-overlays

Create overlays to be used for flake outputs.

Type: Attrs -> Attrs

Usage:

create-overlays {
src = ./my-overlays;
packages-src = ./my-packages;
namespace = "my-namespace";
extra-overlays = {
my-example = final: prev: {};
};
}

Result:

{
default = final: prev: {};
my-example = final: prev: {};
some-overlay = final: prev: {};
}

lib.snowfall.template

Utilities for working with flake templates.

lib.snowfall.template.create-templates

Create flake templates.

Type: Attrs -> Attrs

Usage:

create-templates { src = ./my-templates; overrides = { inherit another-template; }; alias = { default = "another-template"; }; }

Result:

{ another-template = ...; my-template = ...; default = ...; }