diff options
-rw-r--r-- | flake.lock | 26 | ||||
-rw-r--r-- | flake.nix | 36 |
2 files changed, 52 insertions, 10 deletions
@@ -71,7 +71,31 @@ | |||
71 | "advisory-db": "advisory-db", | 71 | "advisory-db": "advisory-db", |
72 | "crane": "crane", | 72 | "crane": "crane", |
73 | "flake-utils": "flake-utils", | 73 | "flake-utils": "flake-utils", |
74 | "nixpkgs": "nixpkgs" | 74 | "nixpkgs": "nixpkgs", |
75 | "rust-overlay": "rust-overlay" | ||
76 | } | ||
77 | }, | ||
78 | "rust-overlay": { | ||
79 | "inputs": { | ||
80 | "flake-utils": [ | ||
81 | "flake-utils" | ||
82 | ], | ||
83 | "nixpkgs": [ | ||
84 | "nixpkgs" | ||
85 | ] | ||
86 | }, | ||
87 | "locked": { | ||
88 | "lastModified": 1706149103, | ||
89 | "narHash": "sha256-Me28A0tAb1EzZIozfi31+hnsQIaYU0HXaMPWCe+zByc=", | ||
90 | "owner": "oxalica", | ||
91 | "repo": "rust-overlay", | ||
92 | "rev": "493cc67d5e9f1b298241b8d92aa06883296acc3f", | ||
93 | "type": "github" | ||
94 | }, | ||
95 | "original": { | ||
96 | "owner": "oxalica", | ||
97 | "repo": "rust-overlay", | ||
98 | "type": "github" | ||
75 | } | 99 | } |
76 | }, | 100 | }, |
77 | "systems": { | 101 | "systems": { |
@@ -2,24 +2,39 @@ | |||
2 | inputs = { | 2 | inputs = { |
3 | nixpkgs.url = "https://flakehub.com/f/NixOS/nixpkgs/0.2311.*.tar.gz"; | 3 | nixpkgs.url = "https://flakehub.com/f/NixOS/nixpkgs/0.2311.*.tar.gz"; |
4 | flake-utils.url = "https://flakehub.com/f/numtide/flake-utils/0.1.90.tar.gz"; | 4 | flake-utils.url = "https://flakehub.com/f/numtide/flake-utils/0.1.90.tar.gz"; |
5 | crane.url = "https://flakehub.com/f/ipetkov/crane/0.16.0.tar.gz"; | 5 | |
6 | crane.inputs.nixpkgs.follows = "nixpkgs"; | 6 | crane = { |
7 | url = "https://flakehub.com/f/ipetkov/crane/0.16.0.tar.gz"; | ||
8 | inputs.nixpkgs.follows = "nixpkgs"; | ||
9 | }; | ||
10 | |||
7 | advisory-db = { | 11 | advisory-db = { |
8 | url = "github:rustsec/advisory-db"; | 12 | url = "github:rustsec/advisory-db"; |
9 | flake = false; | 13 | flake = false; |
10 | }; | 14 | }; |
15 | |||
16 | rust-overlay = { | ||
17 | url = "github:oxalica/rust-overlay"; | ||
18 | inputs = { | ||
19 | nixpkgs.follows = "nixpkgs"; | ||
20 | flake-utils.follows = "flake-utils"; | ||
21 | }; | ||
22 | }; | ||
11 | }; | 23 | }; |
12 | 24 | ||
13 | outputs = { self, nixpkgs, flake-utils, crane, advisory-db, ... }@inputs: | 25 | outputs = { self, nixpkgs, flake-utils, crane, rust-overlay, advisory-db, ... }@inputs: |
14 | flake-utils.lib.eachDefaultSystem | 26 | flake-utils.lib.eachDefaultSystem |
15 | (system: | 27 | (system: |
16 | let | 28 | let |
17 | pkgs = import nixpkgs { | 29 | pkgs = import nixpkgs { |
18 | inherit system; | 30 | inherit system; |
19 | overlays = [ ]; | 31 | overlays = [ (import rust-overlay) ]; |
20 | }; | 32 | }; |
21 | 33 | ||
22 | craneLib = crane.lib.${system}; | 34 | rustToolchain = pkgs.rust-bin.stable.latest.default.override { |
35 | extensions = [ "rust-src" ]; | ||
36 | }; | ||
37 | craneLib = (crane.mkLib pkgs).overrideToolchain rustToolchain; | ||
23 | src = craneLib.cleanCargoSource (craneLib.path ./.); | 38 | src = craneLib.cleanCargoSource (craneLib.path ./.); |
24 | 39 | ||
25 | commonArgs = { | 40 | commonArgs = { |
@@ -44,19 +59,19 @@ | |||
44 | inherit cargoArtifacts; | 59 | inherit cargoArtifacts; |
45 | cargoClippyExtraArgs = "--all-targets -- --deny warnings"; | 60 | cargoClippyExtraArgs = "--all-targets -- --deny warnings"; |
46 | }); | 61 | }); |
47 | 62 | ||
48 | gitolfs3-doc = craneLib.cargoDoc (commonArgs // { | 63 | gitolfs3-doc = craneLib.cargoDoc (commonArgs // { |
49 | inherit cargoArtifacts; | 64 | inherit cargoArtifacts; |
50 | }); | 65 | }); |
51 | 66 | ||
52 | # Check formatting | 67 | # Check formatting |
53 | gitolfs3-fmt = craneLib.cargoFmt commonArgs; | 68 | gitolfs3-fmt = craneLib.cargoFmt commonArgs; |
54 | 69 | ||
55 | # Audit dependencies | 70 | # Audit dependencies |
56 | gitolfs3-audit = craneLib.cargoAudit (commonArgs // { | 71 | gitolfs3-audit = craneLib.cargoAudit (commonArgs // { |
57 | inherit advisory-db; | 72 | inherit advisory-db; |
58 | }); | 73 | }); |
59 | 74 | ||
60 | # Run tests with cargo-nextest | 75 | # Run tests with cargo-nextest |
61 | gitolfs3-nextest = craneLib.cargoNextest (commonArgs // { | 76 | gitolfs3-nextest = craneLib.cargoNextest (commonArgs // { |
62 | inherit cargoArtifacts; | 77 | inherit cargoArtifacts; |
@@ -70,6 +85,9 @@ | |||
70 | 85 | ||
71 | devShells.default = craneLib.devShell { | 86 | devShells.default = craneLib.devShell { |
72 | checks = self.checks.${system}; | 87 | checks = self.checks.${system}; |
88 | |||
89 | packages = [ rustToolchain pkgs.rust-analyzer ]; | ||
90 | RUST_SRC_PATH = "${rustToolchain}/lib/rustlib/src/rust/library"; | ||
73 | }; | 91 | }; |
74 | 92 | ||
75 | formatter = pkgs.nixpkgs-fmt; | 93 | formatter = pkgs.nixpkgs-fmt; |