core/pkgs/build-support/buildenv/default.nix

103 lines
2.8 KiB
Nix
Raw Normal View History

2024-05-02 00:46:19 +00:00
# buildEnv creates a tree of symlinks to the specified paths. This is
# a fork of the hardcoded buildEnv in the Nix distribution.
2024-06-30 08:16:52 +00:00
{
buildPackages,
runCommand,
lib,
substituteAll,
}:
2024-05-02 00:46:19 +00:00
let
builder = substituteAll {
src = ./builder.pl;
inherit (builtins) storeDir;
};
in
2024-06-30 08:16:52 +00:00
lib.makeOverridable (
{
name,
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# The manifest file (if any). A symlink $out/manifest will be
# created to it.
manifest ? "",
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# The paths to symlink.
paths,
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# Whether to ignore collisions or abort.
ignoreCollisions ? false,
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# If there is a collision, check whether the contents and permissions match
# and only if not, throw a collision error.
checkCollisionContents ? true,
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# The paths (relative to each element of `paths') that we want to
# symlink (e.g., ["/bin"]). Any file not inside any of the
# directories in the list is not symlinked.
pathsToLink ? [ "/" ],
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# The package outputs to include. By default, only the default
# output is included.
extraOutputsToInstall ? [ ],
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# Root the result in directory "$out${extraPrefix}", e.g. "/share".
extraPrefix ? "",
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# Shell commands to run after building the symlink tree.
postBuild ? "",
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
# Additional inputs
nativeBuildInputs ? [ ], # Handy e.g. if using makeWrapper in `postBuild`.
buildInputs ? [ ],
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
passthru ? { },
meta ? { },
}:
2024-05-02 00:46:19 +00:00
2024-06-30 08:16:52 +00:00
runCommand name
rec {
inherit
manifest
ignoreCollisions
checkCollisionContents
passthru
meta
pathsToLink
extraPrefix
postBuild
nativeBuildInputs
buildInputs
;
pkgs = builtins.toJSON (
map (drv: {
paths =
# First add the usual output(s): respect if user has chosen explicitly,
# and otherwise use `meta.outputsToInstall`. The attribute is guaranteed
# to exist in mkDerivation-created cases. The other cases (e.g. runCommand)
# aren't expected to have multiple outputs.
(
if
(!drv ? outputSpecified || !drv.outputSpecified) && drv.meta.outputsToInstall or null != null
then
map (outName: drv.${outName}) drv.meta.outputsToInstall
else
[ drv ]
)
# Add any extra outputs specified by the caller of `buildEnv`.
++ lib.filter (p: p != null) (builtins.map (outName: drv.${outName} or null) extraOutputsToInstall);
priority = drv.meta.priority or 5;
}) paths
);
preferLocalBuild = true;
allowSubstitutes = false;
# XXX: The size is somewhat arbitrary
passAsFile = if builtins.stringLength pkgs >= 128 * 1024 then [ "pkgs" ] else [ ];
}
''
${buildPackages.perl}/bin/perl -w ${builder}
eval "$postBuild"
''
)