blob: f1c84df648ca6750c35ae8dd007123257e925804 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
{
description = "";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
};
outputs =
{ self, nixpkgs }:
let
inherit (nixpkgs) lib;
systems = [
"x86_64-linux"
"aarch64-linux"
"x86_64-darwin"
"aarch64-darwin"
];
forAllSystems = fn: lib.genAttrs systems;
nixpkgsFor = forAllSystems (system: nixpkgs.legacyPackages.${system});
in
{
checks = forAllSystems (
system:
let
pkgs = nixpkgsFor.${system};
in
{
nixfmt = pkgs.runCommand "check-nixfmt" ''
cd ${self}
echo "Running nixfmt..."
${lib.getExe self.formatter.${system}}--check .
touch $out
'';
}
);
devShells = forAllSystems (
system:
let
pkgs = nixpkgsFor.${system};
in
{
default = pkgs.mkShell {
packages = [ pkgs.bash ];
inputsFrom = [ self.packages.${system}.hello ];
};
}
);
formatter = forAllSystems (system: nixpkgsFor.${system}.nixfmt-rfc-style);
packages = forAllSystems (
system:
let
pkgs = import ./. {
inherit system nixpkgs lib;
pkgs = nixpkgsFor.${system};
};
isAvailable = lib.meta.availableOn { inherit system; };
pkgs' = lib.filterAttrs (_: isAvailable) pkgs;
in
pkgs // { default = pkgs'.hello; }
);
};
}
|