crane/flake.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

169 lines
4.4 KiB
Nix
Raw Normal View History

2021-12-26 22:47:16 +03:00
{
description = "A Nix library for building cargo projects. Never build twice thanks to incremental artifact caching.";
inputs = { };
2021-12-26 22:47:16 +03:00
nixConfig = {
extra-substituters = [ "https://crane.cachix.org" ];
extra-trusted-public-keys = [ "crane.cachix.org-1:8Scfpmn9w+hGdXH/Q9tTLiYAE/2dnJYRJP7kl80GuRk=" ];
};
outputs = { ... }:
2021-12-26 22:47:16 +03:00
let
mkLib = pkgs: import ./default.nix {
inherit pkgs;
2022-01-16 07:21:02 +03:00
};
nodes = (builtins.fromJSON (builtins.readFile ./test/flake.lock)).nodes;
inputFromLock = name:
let
locked = nodes.${name}.locked;
in
fetchTarball {
url = "https://github.com/${locked.owner}/${locked.repo}/archive/${locked.rev}.tar.gz";
sha256 = locked.narHash;
};
eachSystem = systems: f:
let
# Merge together the outputs for all systems.
op = attrs: system:
let
ret = f system;
op = attrs: key: attrs //
{
${key} = (attrs.${key} or { })
// { ${system} = ret.${key}; };
}
;
in
builtins.foldl' op attrs (builtins.attrNames ret);
in
builtins.foldl' op { } systems;
eachDefaultSystem = eachSystem [
"aarch64-linux"
"aarch64-darwin"
"x86_64-darwin"
"x86_64-linux"
];
2021-12-26 22:47:16 +03:00
in
{
2022-01-16 07:21:02 +03:00
inherit mkLib;
2022-10-24 02:20:22 +03:00
overlays.default = _final: _prev: { };
2022-01-17 01:25:41 +03:00
templates = rec {
alt-registry = {
description = "Build a cargo project with alternative crate registries";
path = ./examples/alt-registry;
};
build-std = {
description = "Build a cargo project while also compiling the standard library";
path = ./examples/build-std;
};
cross-musl = {
description = "Building static binaries with musl";
2022-05-12 00:37:47 +03:00
path = ./examples/cross-musl;
};
cross-rust-overlay = {
description = "Cross compiling a rust program using rust-overlay";
path = ./examples/cross-rust-overlay;
};
cross-windows = {
description = "Cross compiling a rust program for windows";
path = ./examples/cross-windows;
};
custom-toolchain = {
description = "Build a cargo project with a custom toolchain";
path = ./examples/custom-toolchain;
};
2023-10-13 04:59:36 +03:00
end-to-end-testing = {
description = "Run End-to-End tests for a webapp";
path = ./examples/end-to-end-testing;
};
default = quick-start;
quick-start = {
description = "Build a cargo project";
path = ./examples/quick-start;
};
quick-start-simple = {
description = "Build a cargo project without extra checks";
path = ./examples/quick-start-simple;
};
quick-start-workspace = {
description = "Build a cargo workspace with hakari";
path = ./examples/quick-start-workspace;
};
2023-11-29 04:08:21 +03:00
sqlx = {
description = "Build a cargo project which uses SQLx";
path = ./examples/sqlx;
};
trunk = {
description = "Build a trunk project";
path = ./examples/trunk;
};
trunk-workspace = {
description = "Build a workspace with a trunk member";
path = ./examples/trunk-workspace;
};
};
} // eachDefaultSystem (system:
2021-12-27 02:32:57 +03:00
let
nixpkgs = inputFromLock "nixpkgs";
pkgs = import nixpkgs {
inherit system;
};
2022-12-27 01:27:13 +03:00
myLib = mkLib pkgs;
checks =
let
pkgsChecks = import nixpkgs {
inherit system;
overlays = [
(import (inputFromLock "rust-overlay"))
];
};
in
pkgsChecks.callPackages ./checks {
pkgs = pkgsChecks;
myLib = mkLib pkgsChecks;
myLibCross = mkLib (import nixpkgs {
localSystem = system;
crossSystem = "wasm32-wasi";
});
};
2021-12-27 02:32:57 +03:00
in
{
inherit checks;
packages = import ./pkgs {
inherit pkgs myLib;
};
2021-12-27 02:32:57 +03:00
formatter = pkgs.nixpkgs-fmt;
2022-11-21 03:28:49 +03:00
devShells.default = pkgs.mkShell {
nativeBuildInputs = with pkgs; [
2022-05-29 23:26:42 +03:00
jq
2022-12-27 01:27:13 +03:00
mdbook
nix-eval-jobs
nixpkgs-fmt
taplo
];
2021-12-27 02:32:57 +03:00
};
});
2021-12-26 22:47:16 +03:00
}