mirror of
https://github.com/numtide/flake-utils.git
synced 2024-12-14 11:47:31 +00:00
add lib.simpleFlake (#5)
This commit is contained in:
parent
ec20f52e2f
commit
e34fcedfc7
7 changed files with 174 additions and 23 deletions
77
README.md
77
README.md
|
@ -50,10 +50,36 @@ eachSystem allSystems (system: { hello = 42; })
|
|||
|
||||
`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
|
||||
rec {
|
||||
packages = flake-utils.lib.flattenTree {
|
||||
hello = pkgs.hello;
|
||||
gitAndTools = pkgs.gitAndTools;
|
||||
};
|
||||
defaultPackage = packages.hello;
|
||||
apps.hello = flake-utils.lib.mkApp { drv = packages.hello; };
|
||||
defaultApp = apps.hello;
|
||||
}
|
||||
);
|
||||
}
|
||||
```
|
||||
|
||||
### `mkApp { drv, name ? drv.pname or drv.name, execPath ? drv.passthru.execPath 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
|
||||
|
@ -78,27 +104,54 @@ Returns:
|
|||
}
|
||||
```
|
||||
|
||||
## Example
|
||||
### `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" ]
|
||||
}: null
|
||||
```
|
||||
|
||||
#### Example
|
||||
|
||||
Here is how it looks like in practice:
|
||||
|
||||
[$ example/flake.nix](example/flake.nix) as nix
|
||||
[$ 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";
|
||||
inputs.flake-utils.url = "github:numtide/flake-utils/simple-flake";
|
||||
|
||||
outputs = { self, nixpkgs, flake-utils }:
|
||||
flake-utils.lib.eachDefaultSystem (system:
|
||||
let pkgs = nixpkgs.legacyPackages.${system}; in
|
||||
rec {
|
||||
packages.hello = pkgs.hello;
|
||||
defaultPackage = packages.hello;
|
||||
apps.hello = flake-utils.lib.mkApp { drv = packages.hello; };
|
||||
defaultApp = apps.hello;
|
||||
}
|
||||
);
|
||||
flake-utils.lib.simpleFlake {
|
||||
inherit self nixpkgs;
|
||||
name = "simple-flake";
|
||||
overlay = ./overlay.nix;
|
||||
shell = ./shell.nix;
|
||||
};
|
||||
}
|
||||
```
|
||||
|
||||
|
|
27
default.nix
27
default.nix
|
@ -117,15 +117,20 @@ let
|
|||
type = "app";
|
||||
program = "${drv}${exePath}";
|
||||
};
|
||||
in
|
||||
{
|
||||
inherit
|
||||
allSystems
|
||||
defaultSystems
|
||||
eachDefaultSystem
|
||||
eachSystem
|
||||
flattenTree
|
||||
mkApp
|
||||
;
|
||||
|
||||
}
|
||||
# This function tries to capture a common flake pattern.
|
||||
simpleFlake = import ./simpleFlake.nix { inherit lib; };
|
||||
|
||||
lib = {
|
||||
inherit
|
||||
allSystems
|
||||
defaultSystems
|
||||
eachDefaultSystem
|
||||
eachSystem
|
||||
flattenTree
|
||||
mkApp
|
||||
simpleFlake
|
||||
;
|
||||
};
|
||||
in
|
||||
lib
|
||||
|
|
13
examples/simple-flake/flake.nix
Normal file
13
examples/simple-flake/flake.nix
Normal file
|
@ -0,0 +1,13 @@
|
|||
{
|
||||
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;
|
||||
};
|
||||
}
|
11
examples/simple-flake/overlay.nix
Normal file
11
examples/simple-flake/overlay.nix
Normal file
|
@ -0,0 +1,11 @@
|
|||
final: prev:
|
||||
{
|
||||
# this key should be the same as the simpleFlake name attribute.
|
||||
simple-flake = {
|
||||
# assuming that hello is a project-specific package;
|
||||
hello = prev.hello;
|
||||
|
||||
# demonstrating recursive packages
|
||||
terraform-providers = prev.terraform-providers;
|
||||
};
|
||||
}
|
4
examples/simple-flake/shell.nix
Normal file
4
examples/simple-flake/shell.nix
Normal file
|
@ -0,0 +1,4 @@
|
|||
{ pkgs ? import <nixpkgs> }:
|
||||
pkgs.mkShell {
|
||||
buildInputs = [ pkgs.jq ];
|
||||
}
|
65
simpleFlake.nix
Normal file
65
simpleFlake.nix
Normal file
|
@ -0,0 +1,65 @@
|
|||
{ lib }:
|
||||
# This function returns a flake outputs-compatible schema.
|
||||
{
|
||||
# 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" ]
|
||||
}:
|
||||
let
|
||||
loadOverlay = obj:
|
||||
if obj == null then
|
||||
[ ]
|
||||
else
|
||||
[ (maybeImport obj) ]
|
||||
;
|
||||
|
||||
maybeImport = obj:
|
||||
if (builtins.typeOf obj == "path") || (builtins.typeOf obj == "string") then
|
||||
import obj
|
||||
else
|
||||
obj
|
||||
;
|
||||
|
||||
overlays = preOverlays ++ (loadOverlay overlay);
|
||||
|
||||
shell_ = maybeImport shell;
|
||||
|
||||
outputs = lib.eachSystem systems (system:
|
||||
let
|
||||
pkgs = import nixpkgs {
|
||||
inherit
|
||||
config
|
||||
overlays
|
||||
system
|
||||
;
|
||||
};
|
||||
|
||||
packages = pkgs.${name} or { };
|
||||
in
|
||||
{
|
||||
legacyPackages = packages;
|
||||
|
||||
# Flake expects a flat attrset containing only derivations as values
|
||||
packages = lib.flattenTree packages;
|
||||
} // (if shell == null then { } else {
|
||||
devShell = shell_ { inherit pkgs; };
|
||||
})
|
||||
);
|
||||
|
||||
in
|
||||
outputs
|
Loading…
Reference in a new issue