2004-07-02 14:05:53 +04:00
|
|
|
{ stdenv, name, preHook ? null, postHook ? null, initialPath, gcc, shell
|
|
|
|
, param1 ? "", param2 ? "", param3 ? "", param4 ? "", param5 ? ""
|
2006-02-09 20:04:18 +03:00
|
|
|
, extraAttrs ? {}
|
2004-07-02 14:05:53 +04:00
|
|
|
}:
|
|
|
|
|
|
|
|
let {
|
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
stdenvGenerator = setupScript: rec {
|
2004-07-02 14:05:53 +04:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
# The stdenv that we are producing.
|
|
|
|
result =
|
2004-07-02 14:05:53 +04:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
stdenv.mkDerivation {
|
|
|
|
inherit name;
|
2004-07-02 14:05:53 +04:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
builder = ./builder.sh;
|
2005-02-22 17:32:56 +03:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
substitute = ../../build-support/substitute/substitute.sh;
|
2004-07-02 14:05:53 +04:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
setup = setupScript;
|
2004-07-02 14:05:53 +04:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
inherit preHook postHook initialPath gcc shell;
|
2004-07-02 14:05:53 +04:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
# TODO: make this more elegant.
|
|
|
|
inherit param1 param2 param3 param4 param5;
|
|
|
|
}
|
|
|
|
|
|
|
|
// {
|
2006-02-09 20:04:18 +03:00
|
|
|
|
2006-08-07 17:31:18 +04:00
|
|
|
# Add a utility function to produce derivations that use this
|
|
|
|
# stdenv and its shell.
|
|
|
|
mkDerivation = attrs:
|
|
|
|
(derivation (
|
2006-09-14 17:30:47 +04:00
|
|
|
(removeAttrs attrs ["meta" "passthru"])
|
2006-08-07 17:31:18 +04:00
|
|
|
//
|
|
|
|
{
|
|
|
|
builder = if attrs ? realBuilder then attrs.realBuilder else shell;
|
|
|
|
args = if attrs ? args then attrs.args else
|
|
|
|
["-e" (if attrs ? builder then attrs.builder else ./default-builder.sh)];
|
|
|
|
stdenv = result;
|
|
|
|
system = result.system;
|
|
|
|
})
|
|
|
|
)
|
|
|
|
# The meta attribute is passed in the resulting attribute set,
|
|
|
|
# but it's not part of the actual derivation, i.e., it's not
|
|
|
|
# passed to the builder and is not a dependency. But since we
|
|
|
|
# include it in the result, it *is* available to nix-env for
|
|
|
|
# queries.
|
2006-09-14 17:30:47 +04:00
|
|
|
//
|
|
|
|
{ meta = if attrs ? meta then attrs.meta else {}; }
|
|
|
|
# Pass through extra attributes that are not inputs, but
|
|
|
|
# should be made available to Nix expressions using the
|
|
|
|
# derivation (e.g., in assertions).
|
|
|
|
//
|
|
|
|
(if attrs ? passthru then attrs.passthru else {});
|
2006-08-07 17:31:18 +04:00
|
|
|
|
|
|
|
# Utility value: is this a Darwin system?
|
|
|
|
isDarwin = result.system == "i686-darwin" || result.system == "powerpc-darwin";
|
2006-10-23 21:43:03 +04:00
|
|
|
isLinux = result.system == "i686-linux"
|
|
|
|
|| result.system == "x86_64-linux"
|
|
|
|
|| result.system == "powerpc-linux";
|
2006-08-07 17:31:18 +04:00
|
|
|
|
|
|
|
# Utility function: allow stdenv to be easily regenerated with
|
|
|
|
# a different setup script. (See all-packages.nix for an
|
|
|
|
# example.)
|
|
|
|
regenerate = stdenvGenerator;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
# Propagate any extra attributes. For instance, we use this to
|
|
|
|
# "lift" packages like curl from the final stdenv for Linux to
|
|
|
|
# all-packages.nix for that platform (meaning that it has a line
|
|
|
|
# like curl = if stdenv ? curl then stdenv.curl else ...).
|
|
|
|
// extraAttrs;
|
|
|
|
|
|
|
|
}.result;
|
|
|
|
|
|
|
|
|
|
|
|
body = stdenvGenerator ./setup.sh;
|
2004-07-02 14:05:53 +04:00
|
|
|
|
|
|
|
}
|