forked from mattwparas/steel
-
Notifications
You must be signed in to change notification settings - Fork 0
/
flake.nix
55 lines (52 loc) · 1.57 KB
/
flake.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
{
description = "Steel";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable"; # We want to use packages from the binary cache
flake-utils.url = "github:numtide/flake-utils";
gitignore = {
url = "github:hercules-ci/gitignore.nix";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = {
self,
nixpkgs,
flake-utils,
gitignore,
}:
flake-utils.lib.eachDefaultSystem (system: let
inherit (gitignore.lib) gitignoreSource;
pkgs = nixpkgs.legacyPackages.${system};
manifest = pkgs.lib.importTOML ./Cargo.toml;
steel = with pkgs;
rustPlatform.buildRustPackage rec {
pname = manifest.package.name;
version = manifest.workspace.package.version;
src = gitignoreSource ./.;
cargoLock.lockFile = ./Cargo.lock;
buildInputs = [openssl] ++ lib.optionals stdenv.isDarwin [darwin.apple_sdk.frameworks.Security];
nativeBuildInputs = [
pkg-config
];
# Test failing
doCheck = false;
postInstall = ''
mkdir $out/lib
export STEEL_HOME="$out/lib"
pushd cogs
$out/bin/steel install.scm
popd
'';
};
in rec {
packages.steel = steel;
legacyPackages = packages;
defaultPackage = packages.steel;
devShell = with pkgs; mkShell {
buildInputs = [cargo openssl] ++ lib.optionals stdenv.isDarwin [darwin.apple_sdk.frameworks.Security];
nativeBuildInputs = [
pkg-config
];
};
});
}