blob: ad517f283242a4d6faf1c666339ebcb125b8d994 (
plain) (
blame)
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
|
let nixpkgs_unstable = import (builtins.fetchTarball {
# FIXME: upgrade to nixpkgs 19 when stable and stick to stable
# versions
name = "nixos-unstable-2018-12-08";
url = https://github.com/nixos/nixpkgs/archive/61c3169a0e17d789c566d5b241bfe309ce4a6275.tar.gz;
sha256 = "0qbycg7wkb71v20rchlkafrjfpbk2fnlvvbh3ai9pyfisci5wxvq";
}) {};
in
with nixpkgs_unstable;
{
inherit nixpkgs_unstable;
fetchedGithub = path:
let
json = lib.importJSON path;
in rec {
version = json.tag;
name = "${json.meta.name}-${version}";
src = fetchFromGitHub json.github;
};
fetchedGit = path:
let
json = lib.importJSON path;
in rec {
version = json.tag;
name = "${json.meta.name}-${version}";
src = fetchgit json.git;
};
fetchedGitPrivate = path:
let
json = lib.importJSON path;
in rec {
version = json.tag;
name = "${json.meta.name}-${version}";
src = fetchgitPrivate json.git;
};
checkEnv = var: builtins.stringLength (builtins.getEnv var) > 0;
wrap = { paths ? [], vars ? {}, file ? null, script ? null, name ? "wrap" }:
assert file != null || script != null ||
abort "wrap needs 'file' or 'script' argument";
with rec {
set = n: v: "--set ${pkgs.lib.escapeShellArg n} " +
"${pkgs.lib.escapeShellArg v}";
args = (map (p: "--prefix PATH : ${p}/bin") paths) ++
(builtins.attrValues (pkgs.lib.mapAttrs set vars));
};
runCommand name
{
f = if file == null then writeScript name script else file;
buildInputs = [ makeWrapper ];
}
''
makeWrapper "$f" "$out" ${toString args}
'';
}
|