2016-04-26 18:53:31 +01:00
|
|
|
|
/* Impure default args for `pkgs/top-level/default.nix`. See that file
|
|
|
|
|
for the meaning of each argument. */
|
|
|
|
|
|
2017-02-01 14:56:02 +00:00
|
|
|
|
with builtins;
|
|
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
|
|
homeDir = builtins.getEnv "HOME";
|
|
|
|
|
|
|
|
|
|
# Return ‘x’ if it evaluates, or ‘def’ if it throws an exception.
|
|
|
|
|
try = x: def: let res = tryEval x; in if res.success then res.value else def;
|
|
|
|
|
|
|
|
|
|
in
|
|
|
|
|
|
2017-02-08 21:43:52 +00:00
|
|
|
|
{ # We combine legacy `system` and `platform` into `localSystem`, if
|
|
|
|
|
# `localSystem` was not passed. Strictly speaking, this is pure desugar, but
|
|
|
|
|
# it is most convient to do so before the impure `localSystem.system` default,
|
|
|
|
|
# so we do it now.
|
|
|
|
|
localSystem ? builtins.intersectAttrs { system = null; platform = null; } args
|
2016-04-26 18:53:31 +01:00
|
|
|
|
|
2017-02-09 16:21:07 +00:00
|
|
|
|
, # These are needed only because nix's `--arg` command-line logic doesn't work
|
|
|
|
|
# with unnamed parameters allowed by ...
|
|
|
|
|
system ? localSystem.system
|
|
|
|
|
, platform ? localSystem.platform
|
|
|
|
|
|
2016-04-26 18:53:31 +01:00
|
|
|
|
, # Fallback: The contents of the configuration file found at $NIXPKGS_CONFIG or
|
2017-02-01 15:03:42 +00:00
|
|
|
|
# $HOME/.config/nixpkgs/config.nix.
|
2016-04-26 18:53:31 +01:00
|
|
|
|
config ? let
|
|
|
|
|
configFile = getEnv "NIXPKGS_CONFIG";
|
2017-02-01 15:03:42 +00:00
|
|
|
|
configFile2 = homeDir + "/.config/nixpkgs/config.nix";
|
|
|
|
|
configFile3 = homeDir + "/.nixpkgs/config.nix"; # obsolete
|
2016-04-26 18:53:31 +01:00
|
|
|
|
in
|
|
|
|
|
if configFile != "" && pathExists configFile then import configFile
|
|
|
|
|
else if homeDir != "" && pathExists configFile2 then import configFile2
|
2017-02-01 15:03:42 +00:00
|
|
|
|
else if homeDir != "" && pathExists configFile3 then import configFile3
|
2016-04-26 18:53:31 +01:00
|
|
|
|
else {}
|
|
|
|
|
|
2016-12-17 18:05:21 +00:00
|
|
|
|
, # Overlays are used to extend Nixpkgs collection with additional
|
|
|
|
|
# collections of packages. These collection of packages are part of the
|
|
|
|
|
# fix-point made by Nixpkgs.
|
|
|
|
|
overlays ? let
|
2017-02-01 14:56:02 +00:00
|
|
|
|
dirPath = try (if pathExists <nixpkgs-overlays> then <nixpkgs-overlays> else "") "";
|
2017-02-01 15:03:42 +00:00
|
|
|
|
dirHome = homeDir + "/.config/nixpkgs/overlays";
|
2016-12-17 18:05:21 +00:00
|
|
|
|
dirCheck = dir: dir != "" && pathExists (dir + "/.");
|
|
|
|
|
overlays = dir:
|
|
|
|
|
let content = readDir dir; in
|
2017-02-01 14:56:02 +00:00
|
|
|
|
map (n: import (dir + ("/" + n)))
|
2017-02-23 09:09:47 +00:00
|
|
|
|
(builtins.filter (n: builtins.match ".*\.nix" n != null || pathExists (dir + ("/" + n + "/default.nix")))
|
2017-02-01 19:25:58 +00:00
|
|
|
|
(attrNames content));
|
2016-12-17 18:05:21 +00:00
|
|
|
|
in
|
2017-02-01 14:56:02 +00:00
|
|
|
|
if dirPath != "" then
|
|
|
|
|
overlays dirPath
|
2016-12-17 18:05:21 +00:00
|
|
|
|
else if dirCheck dirHome then overlays dirHome
|
|
|
|
|
else []
|
|
|
|
|
|
2016-04-26 18:53:31 +01:00
|
|
|
|
, ...
|
|
|
|
|
} @ args:
|
|
|
|
|
|
2017-02-08 21:43:52 +00:00
|
|
|
|
# If `localSystem` was explicitly passed, legacy `system` and `platform` should
|
|
|
|
|
# not be passed.
|
|
|
|
|
assert args ? localSystem -> !(args ? system || args ? platform);
|
|
|
|
|
|
|
|
|
|
import ./. (builtins.removeAttrs args [ "system" "platform" ] // {
|
|
|
|
|
inherit config overlays;
|
|
|
|
|
# Fallback: Assume we are building packages on the current (build, in GNU
|
|
|
|
|
# Autotools parlance) system.
|
|
|
|
|
localSystem = { system = builtins.currentSystem; } // localSystem;
|
|
|
|
|
})
|