Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/numtide/flake-utils
Pure Nix flake utility functions [maintainer=@zimbatm]
https://github.com/numtide/flake-utils
flake nix nix-flake
Last synced: 24 days ago
JSON representation
Pure Nix flake utility functions [maintainer=@zimbatm]
- Host: GitHub
- URL: https://github.com/numtide/flake-utils
- Owner: numtide
- License: mit
- Created: 2020-04-11T13:21:34.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-09-17T08:14:13.000Z (about 2 months ago)
- Last Synced: 2024-09-28T09:01:22.662Z (about 1 month ago)
- Topics: flake, nix, nix-flake
- Language: Nix
- Homepage:
- Size: 106 KB
- Stars: 1,162
- Watchers: 21
- Forks: 79
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-github-repos - numtide/flake-utils - Pure Nix flake utility functions [maintainer=@zimbatm] (Nix)
- awesome-nix - flake-utils - Pure Nix flake utility functions to help with writing flakes. (Development / Discovery)
README
# flake-utils
**STATUS: stable**
Pure Nix flake utility functions.
The goal of this project is to build a collection of pure Nix functions that don't
depend on nixpkgs, and that are useful in the context of writing other Nix
flakes.## Usage
### `system :: { system = system, ... }`
A map from system to system built from `allSystems`:
```nix
system = {
x86_64-linux = "x86_64-linux";
x86_64-darwin = "x86_64-darwin";
...
}
```
It's mainly useful to
detect typos and auto-complete if you use [rnix-lsp](https://github.com/nix-community/rnix-lsp).Eg: instead of typing `"x86_64-linux"`, use `system.x86_64-linux`.
### `allSystems :: []`
A list of all systems defined in nixpkgs. For a smaller list see `defaultSystems`.
### `defaultSystems :: []`
The list of systems to use in `eachDefaultSystem` and `simpleFlake`.
The default values are `["x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin"]`.
It's possible to override and control that list by changing the `systems` input of this flake.
Eg (in your `flake.nix`):
```nix
{
# 1. Defined a "systems" inputs that maps to only ["x86_64-linux"]
inputs.systems.url = "github:nix-systems/x86_64-linux";inputs.flake-utils.url = "github:numtide/flake-utils";
# 2. Override the flake-utils default to your version
inputs.flake-utils.inputs.systems.follows = "systems";outputs = { self, flake-utils, ... }:
# Now eachDefaultSystem is only using ["x86_64-linux"], but this list can also
# further be changed by users of your flake.
flake-utils.lib.eachDefaultSystem (system: {
# ...
});
}
```For more details in this pattern, see: .
### `eachSystem :: [] -> ( -> attrs)`
A common case is to build the same structure for each system. Instead of
building the hierarchy manually or per prefix, iterate over each systems and
then re-build the hierarchy.Eg:
```nix
eachSystem [ system.x86_64-linux ] (system: { hello = 42; })
# => { hello = { x86_64-linux = 42; }; }
eachSystem allSystems (system: { hello = 42; })
# => {
hello.aarch64-darwin = 42,
hello.aarch64-genode = 42,
hello.aarch64-linux = 42,
...
hello.x86_64-redox = 42,
hello.x86_64-solaris = 42,
hello.x86_64-windows = 42
}
```### `eachSystemPassThrough :: [] -> ( -> attrs)`
Unlike `eachSystem`, this function does not inject the `${system}` key by merely
providing the system argument to the function.### `eachDefaultSystem :: ( -> attrs)`
`eachSystem` pre-populated with `defaultSystems`.
#### Example
[$ examples/each-system/flake.nix](examples/each-system/flake.nix) as nix
```nix
{
description = "Flake utils demo";inputs.flake-utils.url = "github:numtide/flake-utils";
outputs = { self, nixpkgs, flake-utils }:
flake-utils.lib.eachDefaultSystem (system:
let pkgs = nixpkgs.legacyPackages.${system}; in
{
packages = rec {
hello = pkgs.hello;
default = hello;
};
apps = rec {
hello = flake-utils.lib.mkApp { drv = self.packages.${system}.hello; };
default = hello;
};
}
);
}
```### `eachDefaultSystemPassThrough :: ( -> attrs)`
`eachSystemPassThrough` pre-populated with `defaultSystems`.
#### Example
```nix
inputs.flake-utils.lib.eachDefaultSystem (system: {
checks./*.*/"" = /* ... */;
devShells./*.*/"" = /* ... */;
packages./*.*/"" = /* ... */;
})
// inputs.flake-utils.lib.eachDefaultSystemPassThrough (system: {
homeConfigurations."" = /* ... */;
nixosConfigurations."" = /* ... */;
})
```### `meld :: attrs -> [ path ] -> attrs`
Meld merges subflakes using common inputs. Useful when you want to
split up a large flake with many different components into more
manageable parts.### `mkApp { drv, name ? drv.pname or drv.name, exePath ? drv.passthru.exePath or "/bin/${name}"`
A small utility that builds the structure expected by the special `apps` and `defaultApp` prefixes.
### `flattenTree :: attrs -> attrs`
Nix flakes insists on having a flat attribute set of derivations in
various places like the `packages` and `checks` attributes.This function traverses a tree of attributes (by respecting
[recurseIntoAttrs](https://noogle.dev/f/lib/recurseIntoAttrs)) and only returns their derivations, with a flattened
key-space.Eg:
```nix
flattenTree { hello = pkgs.hello; gitAndTools = pkgs.gitAndTools }
```
Returns:```nix
{
hello = «derivation»;
"gitAndTools/git" = «derivation»;
"gitAndTools/hub" = «derivation»;
# ...
}
```### `simpleFlake :: attrs -> attrs`
This function should be useful for most common use-cases where you have a
simple flake that builds a package. It takes nixpkgs and a bunch of other
parameters and outputs a value that is compatible as a flake output.Input:
```nix
{
# pass an instance of self
self
, # pass an instance of the nixpkgs flake
nixpkgs
, # we assume that the name maps to the project name, and also that the
# overlay has an attribute with the `name` prefix that contains all of the
# project's packages.
name
, # nixpkgs config
config ? { }
, # pass either a function or a file
overlay ? null
, # use this to load other flakes overlays to supplement nixpkgs
preOverlays ? [ ]
, # maps to the devShell output. Pass in a shell.nix file or function.
shell ? null
, # pass the list of supported systems
systems ? [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]
}: null
```#### Example
Here is how it looks like in practice:
[$ examples/simple-flake/flake.nix](examples/simple-flake/flake.nix) as nix
```nix
{
description = "Flake utils demo";inputs.flake-utils.url = "github:numtide/flake-utils";
outputs = { self, nixpkgs, flake-utils }:
flake-utils.lib.simpleFlake {
inherit self nixpkgs;
name = "simple-flake";
overlay = ./overlay.nix;
shell = ./shell.nix;
};
}
```## Commercial support
Looking for help or customization?
Get in touch with Numtide to get a quote. We make it easy for companies to
work with Open Source projects: