|
1 | 1 | pkgs:
|
2 | 2 |
|
3 |
| -{ crane, src, system, crateName, localDeps, dataDeps }: |
| 3 | +{ crane, src, system, crateName, extraSources ? [ ], extraSourcesDir ? ".extras", data ? [ ], dataDir ? "data" }: |
4 | 4 | let
|
5 | 5 | rustWithTools = pkgs.rust-bin.stable.latest.default.override {
|
6 | 6 | extensions = [ "rustfmt" "rust-analyzer" "clippy" ];
|
7 | 7 | };
|
8 | 8 | craneLib = crane.lib.${system}.overrideToolchain rustWithTools;
|
9 | 9 |
|
10 |
| - buildEnv = pkgs.stdenv.mkDerivation { |
11 |
| - inherit src; |
12 |
| - name = "lbf-rust-workspace"; |
13 |
| - unpackPhase = builtins.concatStringsSep "\n" |
14 |
| - ([ |
15 |
| - "mkdir -p $out" |
16 |
| - "cp -r $src $out/${crateName}" |
17 |
| - ] |
18 |
| - ++ (map ({ name, path }: "cp -r ${path} $out/${name}") localDeps) |
19 |
| - ++ (map ({ name, path }: "cp -r ${path} $out/${name}") dataDeps) |
20 |
| - ); |
| 10 | + # Library source code with extra dependencies attached |
| 11 | + fullSrc = pkgs.stdenv.mkDerivation { |
| 12 | + src = craneLib.cleanCargoSource (craneLib.path src); |
| 13 | + name = "lbf-rust-build-env"; |
| 14 | + unpackPhase = '' |
| 15 | + mkdir $out |
| 16 | + cp -r $src/* $out |
| 17 | + cd $out |
| 18 | + ${copyExtraSources} |
| 19 | + ${copyData} |
| 20 | + ''; |
21 | 21 | };
|
22 | 22 | commonArgs = {
|
23 |
| - src = buildEnv; |
| 23 | + src = fullSrc; |
24 | 24 | pname = crateName;
|
25 | 25 | strictDeps = true;
|
26 |
| - cargoLock = "${src}/Cargo.lock"; |
27 |
| - cargoToml = "${src}/Cargo.toml"; |
28 |
| - postUnpack = '' |
29 |
| - cd $sourceRoot/${crateName} |
30 |
| - sourceRoot="." |
31 |
| - ''; |
32 | 26 | };
|
33 | 27 | cargoArtifacts = craneLib.buildDepsOnly commonArgs;
|
34 | 28 |
|
| 29 | + # Extra sources |
| 30 | + extra-sources = pkgs.linkFarm "extra-sources" extraSources; |
| 31 | + hasExtraSources = builtins.length extraSources > 0; |
| 32 | + linkExtraSources = pkgs.lib.optionalString hasExtraSources '' |
| 33 | + echo "Linking extra sources" |
| 34 | + if [ -e ./${extraSourcesDir} ]; then rm ./${extraSourcesDir}; fi |
| 35 | + ln -s ${extra-sources} ./${extraSourcesDir} |
| 36 | + ''; |
| 37 | + copyExtraSources = pkgs.lib.optionalString hasExtraSources '' |
| 38 | + echo "Copying extra sources" |
| 39 | + cp -Lr ${extra-sources} ./${extraSourcesDir} |
| 40 | + ''; |
| 41 | + |
| 42 | + # Data |
| 43 | + data-drv = pkgs.linkFarm "data" data; |
| 44 | + hasData = builtins.length data > 0; |
| 45 | + linkData = pkgs.lib.optionalString hasData '' |
| 46 | + echo "Linking data" |
| 47 | + if [ -e ./${dataDir} ]; then rm ./${dataDir}; fi |
| 48 | + ln -s ${data-drv} ./${dataDir} |
| 49 | + ''; |
| 50 | + copyData = pkgs.lib.optionalString hasData '' |
| 51 | + echo "Copying data" |
| 52 | + cp -Lr ${data-drv} ./${dataDir} |
| 53 | + ''; |
35 | 54 | in
|
36 | 55 | {
|
37 | 56 | devShells."dev-${crateName}-rust" = craneLib.devShell {
|
38 |
| - # checks = self'.checks; |
| 57 | + shellHook = '' |
| 58 | + ${linkExtraSources} |
| 59 | + ${linkData} |
| 60 | + ''; |
39 | 61 | };
|
40 | 62 |
|
41 |
| - packages."${crateName}-rust" = craneLib.buildPackage commonArgs // { |
| 63 | + packages."${crateName}-rust" = craneLib.buildPackage (commonArgs // { |
42 | 64 | inherit cargoArtifacts;
|
43 | 65 | doCheck = false;
|
44 |
| - }; |
| 66 | + doInstallCargoArtifacts = true; |
| 67 | + }); |
45 | 68 |
|
46 | 69 | checks."${crateName}-rust-test" = craneLib.cargoNextest (commonArgs // {
|
47 | 70 | inherit cargoArtifacts;
|
|
0 commit comments