2016-11-27 12:35:58 -08:00
|
|
|
/* This function composes the Nix Packages collection. It:
|
|
|
|
|
|
|
|
1. Applies the final stage to the given `config` if it is a function
|
|
|
|
|
|
|
|
2. Infers an appropriate `platform` based on the `system` if none is
|
|
|
|
provided
|
|
|
|
|
|
|
|
3. Defaults to no non-standard config and no cross-compilation target
|
|
|
|
|
|
|
|
4. Uses the above to infer the default standard environment (stdenv) if
|
|
|
|
none is provided
|
|
|
|
|
|
|
|
5. Builds the final stage --- a fully booted package set with the chosen
|
|
|
|
stdenv
|
|
|
|
|
|
|
|
Use `impure.nix` to also infer the `system` based on the one on which
|
|
|
|
evaluation is taking place, and the configuration from environment variables
|
|
|
|
or dot-files. */
|
2016-03-20 09:28:18 -07:00
|
|
|
|
|
|
|
{ # The system (e.g., `i686-linux') for which to build the packages.
|
2016-04-26 10:53:31 -07:00
|
|
|
system
|
2016-03-20 09:28:18 -07:00
|
|
|
|
2016-04-26 10:53:31 -07:00
|
|
|
, # Allow a configuration attribute set to be passed in as an argument.
|
|
|
|
config ? {}
|
2016-03-20 09:28:18 -07:00
|
|
|
|
|
|
|
, crossSystem ? null
|
2016-11-26 15:13:43 -08:00
|
|
|
, platform ? assert false; null
|
2016-11-02 13:39:18 -07:00
|
|
|
} @ args:
|
2016-03-20 09:28:18 -07:00
|
|
|
|
2016-11-27 12:32:56 -08:00
|
|
|
let # Rename the function arguments
|
|
|
|
configExpr = config;
|
2016-03-20 09:28:18 -07:00
|
|
|
|
2016-11-27 12:32:56 -08:00
|
|
|
in let
|
2016-03-20 09:28:18 -07:00
|
|
|
lib = import ../../lib;
|
|
|
|
|
2016-06-22 01:33:53 -07:00
|
|
|
# Allow both:
|
|
|
|
# { /* the config */ } and
|
|
|
|
# { pkgs, ... } : { /* the config */ }
|
2016-03-20 09:28:18 -07:00
|
|
|
config =
|
2016-06-22 01:33:53 -07:00
|
|
|
if builtins.isFunction configExpr
|
|
|
|
then configExpr { inherit pkgs; }
|
|
|
|
else configExpr;
|
2016-03-20 09:28:18 -07:00
|
|
|
|
2016-11-26 15:13:43 -08:00
|
|
|
# Allow setting the platform in the config file. Otherwise, let's use a
|
|
|
|
# reasonable default.
|
|
|
|
platform =
|
|
|
|
args.platform
|
|
|
|
or (config.platform
|
|
|
|
or (import ./platforms.nix).selectPlatformBySystem system);
|
2016-03-20 09:28:18 -07:00
|
|
|
|
2016-11-02 13:39:18 -07:00
|
|
|
# A few packages make a new package set to draw their dependencies from.
|
|
|
|
# (Currently to get a cross tool chain, or forced-i686 package.) Rather than
|
|
|
|
# give `all-packages.nix` all the arguments to this function, even ones that
|
|
|
|
# don't concern it, we give it this function to "re-call" nixpkgs, inheriting
|
|
|
|
# whatever arguments it doesn't explicitly provide. This way,
|
|
|
|
# `all-packages.nix` doesn't know more than it needs too.
|
|
|
|
#
|
|
|
|
# It's OK that `args` doesn't include the defaults: they'll be
|
|
|
|
# deterministically inferred the same way.
|
|
|
|
nixpkgsFun = newArgs: import ./. (args // newArgs);
|
|
|
|
|
2016-11-27 12:37:45 -08:00
|
|
|
# Partially apply some arguments for building bootstraping stage pkgs
|
|
|
|
# sets. Only apply arguments which no stdenv would want to override.
|
2016-11-27 12:35:58 -08:00
|
|
|
allPackages = newArgs: import ./stage.nix ({
|
2016-11-27 12:37:45 -08:00
|
|
|
inherit lib nixpkgsFun;
|
2016-11-27 12:35:58 -08:00
|
|
|
} // newArgs);
|
|
|
|
|
|
|
|
stdenv = import ../stdenv {
|
|
|
|
inherit lib allPackages system platform crossSystem config;
|
|
|
|
};
|
|
|
|
|
|
|
|
pkgs = allPackages { inherit system stdenv config crossSystem platform; };
|
2016-10-12 12:14:49 -07:00
|
|
|
|
|
|
|
in pkgs
|