-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathpackages.nix
62 lines (57 loc) · 1.35 KB
/
packages.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
56
57
58
59
60
61
62
{
pkgs ? import <nixpkgs> { },
lib ? pkgs.lib,
}:
let
# This project's `.gitignore` implemented for cleanSource.
filterGitignore =
orig_path: type:
let
baseName = baseNameOf (toString orig_path);
in
!(baseName == "target" && type == "directory")
|| lib.hasSuffix ".rs.bk" baseName
|| baseName == ".nixos-test-history"
|| (baseName == ".direnv" && type == "directory");
cleanSourceWithGitignore =
src:
lib.cleanSourceWith {
src = lib.cleanSource src;
filter = filterGitignore;
};
cargoManifest = (pkgs.lib.importTOML ./Cargo.toml).package;
in
{
system-manager = pkgs.callPackage (
{
rustPlatform,
dbus,
pkg-config,
makeWrapper,
nix,
clippy,
}:
rustPlatform.buildRustPackage {
pname = "system-manager";
version = cargoManifest.version;
src = cleanSourceWithGitignore ./.;
cargoLock.lockFile = ./Cargo.lock;
buildInputs = [ dbus ];
nativeBuildInputs = [
pkg-config
makeWrapper
];
nativeCheckInputs = [
clippy
];
preCheck = ''
${lib.getExe pkgs.cargo} clippy
'';
# TODO: Is prefixing nix here the correct approach?
postFixup = ''
wrapProgram $out/bin/system-manager \
--prefix PATH : ${lib.makeBinPath [ nix ]}
'';
}
) { };
}