crane/flake.nix
Sebastian Rutofski 17e5109bb1
Add build-std and quick-start-workspace as flake templates (#665)
---------

Co-authored-by: Ivan Petkov <ivanppetkov@gmail.com>
2024-07-15 15:49:38 +00:00

169 lines
4.7 KiB
Nix

{
description = "A Nix library for building cargo projects. Never build twice thanks to incremental artifact caching.";
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
nixConfig = {
extra-substituters = [ "https://crane.cachix.org" ];
extra-trusted-public-keys = [ "crane.cachix.org-1:8Scfpmn9w+hGdXH/Q9tTLiYAE/2dnJYRJP7kl80GuRk=" ];
};
outputs = { nixpkgs, ... }:
let
mkLib = pkgs: import ./default.nix {
inherit pkgs;
};
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"
];
in
{
inherit mkLib;
overlays.default = _final: _prev: { };
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";
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;
};
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;
};
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:
let
pkgs = nixpkgs.legacyPackages.${system};
# To override do: lib.overrideScope (self: super: { ... });
lib = pkgs.lib.warn
"`crane.lib.\${system}` is deprecated. please use `(crane.mkLib nixpkgs.legacyPackages.\${system})` instead"
(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";
});
};
in
{
inherit checks lib;
packages = import ./pkgs {
inherit pkgs;
myLib = lib;
};
formatter = pkgs.nixpkgs-fmt;
devShells.default = pkgs.mkShell {
nativeBuildInputs = with pkgs; [
jq
mdbook
nix-eval-jobs
nixpkgs-fmt
];
};
});
}