1
0
Fork 0
mirror of https://github.com/mitchellh/zig-overlay.git synced 2025-05-08 18:46:02 +03:00

flake: inputs: remove flake-utils

You don't need it.

This commit supercedes
<https://github.com/mitchellh/zig-overlay/pull/60>,
which copies a function from `flake-utils`.

Instead of using this (arguably bad) abstraction,
introduce `eachSystem` and `pkgsFor`.
This commit is contained in:
Jacob Birkett 2025-04-23 23:06:03 -07:00
parent ee9cba5c35
commit fb77f77e83
2 changed files with 55 additions and 84 deletions

36
flake.lock generated
View file

@ -16,24 +16,6 @@
"type": "github" "type": "github"
} }
}, },
"flake-utils": {
"inputs": {
"systems": "systems"
},
"locked": {
"lastModified": 1705309234,
"narHash": "sha256-uNRRNRKmJyCRC/8y1RqBkqWBLM034y4qN7EprSdmgyA=",
"owner": "numtide",
"repo": "flake-utils",
"rev": "1ef2e671c3b0c19053962c07dbda38332dcebf26",
"type": "github"
},
"original": {
"owner": "numtide",
"repo": "flake-utils",
"type": "github"
}
},
"nixpkgs": { "nixpkgs": {
"locked": { "locked": {
"lastModified": 1708161998, "lastModified": 1708161998,
@ -53,27 +35,11 @@
"root": { "root": {
"inputs": { "inputs": {
"flake-compat": "flake-compat", "flake-compat": "flake-compat",
"flake-utils": "flake-utils",
"nixpkgs": "nixpkgs", "nixpkgs": "nixpkgs",
"systems": "systems_2" "systems": "systems"
} }
}, },
"systems": { "systems": {
"locked": {
"lastModified": 1681028828,
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
"owner": "nix-systems",
"repo": "default",
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
"type": "github"
},
"original": {
"owner": "nix-systems",
"repo": "default",
"type": "github"
}
},
"systems_2": {
"flake": false, "flake": false,
"locked": { "locked": {
"lastModified": 1681028828, "lastModified": 1681028828,

103
flake.nix
View file

@ -7,7 +7,6 @@
url = "github:nix-systems/default"; url = "github:nix-systems/default";
flake = false; flake = false;
}; };
flake-utils.url = "github:numtide/flake-utils";
# Used for shell.nix # Used for shell.nix
flake-compat = { flake-compat = {
@ -20,58 +19,64 @@
self, self,
nixpkgs, nixpkgs,
systems, systems,
flake-utils,
... ...
}: let }: let
outputs = flake-utils.lib.eachSystem (import systems) (system: let inherit (nixpkgs) lib;
pkgs = nixpkgs.legacyPackages.${system};
in rec {
# The packages exported by the Flake:
# - default - latest /released/ version
# - <version> - tagged version
# - master - latest nightly (updated daily)
# - master-<date> - nightly by date
packages = import ./default.nix {inherit system pkgs;};
# "Apps" so that `nix run` works. If you run `nix run .` then eachSystem = lib.genAttrs (import systems);
# this will use the latest default.
apps = rec {
default = apps.zig;
zig = flake-utils.lib.mkApp {drv = packages.default;};
};
# nix fmt pkgsFor = eachSystem (system: nixpkgs.legacyPackages.${system});
formatter = pkgs.alejandra; in {
# The packages exported by the Flake:
# - default - latest /released/ version
# - <version> - tagged version
# - master - latest nightly (updated daily)
# - master-<date> - nightly by date
packages = lib.mapAttrs (system: pkgs: import ./default.nix {inherit system pkgs;}) pkgsFor;
devShells.default = pkgs.mkShell { # Overlay that can be imported so you can access the packages
nativeBuildInputs = with pkgs; [ # using zigpkgs.master or whatever you'd like.
curl overlays.default = final: prev: {
jq zigpkgs = self.packages.${prev.system};
minisign
];
};
# For compatibility with older versions of the `nix` binary
devShell = self.devShells.${system}.default;
});
in
outputs
// {
# Overlay that can be imported so you can access the packages
# using zigpkgs.master or whatever you'd like.
overlays.default = final: prev: {
zigpkgs = outputs.packages.${prev.system};
};
# Templates for use with nix flake init
templates.compiler-dev = {
path = ./templates/compiler-dev;
description = "A development environment for Zig compiler development.";
};
templates.init = {
path = ./templates/init;
description = "A basic, empty development environment.";
};
}; };
# "Apps" so that `nix run` works. If you run `nix run .` then
# this will use the latest default.
apps = eachSystem (system: {
default = self.apps.${system}.zig;
zig = {
type = "app";
program = self.packages.${system}.default.outPath;
};
});
# nix fmt
formatter = lib.mapAttrs (_: pkgs: pkgs.alejandra) pkgsFor;
devShells =
lib.mapAttrs (system: pkgs: {
default = pkgs.mkShell {
nativeBuildInputs = with pkgs; [
curl
jq
minisign
];
};
})
pkgsFor;
# For compatibility with older versions of the `nix` binary
devShell = eachSystem (system: self.devShells.${system}.default);
# Templates for use with nix flake init
templates.compiler-dev = {
path = ./templates/compiler-dev;
description = "A development environment for Zig compiler development.";
};
templates.init = {
path = ./templates/init;
description = "A basic, empty development environment.";
};
};
} }