oizys/lib/default.nix

97 lines
2.3 KiB
Nix

inputs@{
nixpkgs,
treefmt-nix,
self,
...
}:
let
lib = nixpkgs.lib.extend (import ./extended.nix inputs);
inherit (builtins) mapAttrs readDir listToAttrs;
inherit (lib)
genAttrs
loadOverlays
listify
enableAttrs
;
inherit (import ./find-modules.nix { inherit lib; }) findModulesList;
inherit (import ./generators.nix { inherit lib self inputs; }) mkIso mkSystem;
#supportedSystems = ["x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin"];
supportedSystems = [ "x86_64-linux" ];
forAllSystems =
fn:
genAttrs supportedSystems (
system:
fn (
import nixpkgs {
inherit system;
overlays = (import ../overlays { inherit inputs loadOverlays; });
}
)
);
evalTreeFmt =
pkgs:
(treefmt-nix.lib.evalModule pkgs (
{ ... }:
{
projectRootFile = "flake.nix";
# don't warn me about missing formatters
settings.excludes = [
# likely to be nnl lockfiles
"pkgs/**/lock.json"
"hosts/**/secrets.yaml"
];
settings.on-unmatched = "debug";
programs = "prettier|nixfmt" |> listify |> enableAttrs;
}
));
oizysFlake = {
templates = {
dev = {
path = ../templates/dev;
description = "a basic dev shell";
};
default = self.templates.dev;
};
nixosModules = listToAttrs (findModulesList ../modules);
nixosConfigurations = mapAttrs (name: _: mkSystem name) (readDir ../hosts);
packages = forAllSystems (
pkgs:
rec {
default = oizys;
oizys = pkgs.callPackage ../pkgs/oizys { };
iso = mkIso.config.system.build.isoImage;
# nimlangserver = pkgs.callPackage ../pkgs/nim/nimlangserver { };
}
// (import ../pkgs { inherit pkgs lib; })
);
devShells = forAllSystems (pkgs: {
oizys = pkgs.mkShell {
packages = with pkgs; [
openssl
nim
self.packages.${pkgs.system}.nimble
];
};
});
checks = forAllSystems (
pkgs:
import ./checks.nix {
inherit inputs lib self;
system = pkgs.system;
}
// {
formatter = (evalTreeFmt pkgs).config.build.check self;
}
);
formatter = forAllSystems (pkgs: (evalTreeFmt pkgs).config.build.wrapper);
};
in
{
inherit oizysFlake;
}