blob: 9040149af3848e6eddf0b6bf8064eed3403ea65b (
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
|
{ pkgs, lib, ... }:
let
inherit (lib) escapeShellArg;
# Encode the store path in base 64 so that the wrapper
# doesn't have a direct dependency on the package.
encoder = "${escapeShellArg "${pkgs.coreutils}/bin/base64"} -w0";
decoder = "${escapeShellArg "${pkgs.coreutils}/bin/base64"} -d";
# The command used to fetch the store path from the binary cache.
fetchSubstitute = "${escapeShellArg "${pkgs.nix}/bin/nix-store"} -r";
mkWrapper = {package, extraErrorMessage ? ""}: pkgs.runCommandLocal "${package.name}-lazy" {
inherit package;
inherit extraErrorMessage;
} ''
encoded="$(echo "$package" | ${encoder})"
if [ ! -e "$package/bin" ]; then
echo "Store path $package doesn't have a \`bin' directory" \
"so we can't create lazy wrappers for it." \
"$extraErrorMessage" >&2
exit 1
fi
for bin in "$package"/bin/*; do
[ -x "$bin" -a ! -d "$bin" ] || continue
binpath="''${bin#$package/}"
mkdir -p "$out/bin"
( echo ${escapeShellArg "#!${pkgs.stdenv.shell}"}
echo "encoded='$encoded'"
echo "binpath='$binpath'"
echo -n ${escapeShellArg ''
storepath="$(echo "$encoded" | ${decoder})"
program="$storepath/$binpath"
if [ ! -e "$storepath" ]; then
${fetchSubstitute} "$storepath" > /dev/null || exit $?
fi
exec "$program" "$@"
''}
) > "$out/bin/$(basename "$bin")"
chmod +x "$out/bin/$(basename "$bin")"
done
'';
in {
inherit
mkWrapper
;
}
|