71184f8e15
There were two issues: * builtins.getEnv was called deep into the nixpkgs tree making it hard to discover. This is solved by moving the call into pkgs/top-level/impure.nix * when the config was explicitly set by the user to false, it would still try and load the environment variable. This meant that it was not possible to guarantee the same outcome on two different systems.
102 lines
4.1 KiB
Nix
102 lines
4.1 KiB
Nix
/* Impure default args for `pkgs/top-level/default.nix`. See that file
|
||
for the meaning of each argument. */
|
||
|
||
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;
|
||
|
||
defaultConfig = {
|
||
# These attributes are used in pkgs/stdenv/generic/check-meta.nix
|
||
allowBroken = builtins.getEnv "NIXPKGS_ALLOW_BROKEN" == "1";
|
||
allowInsecure = builtins.getEnv "NIXPKGS_ALLOW_INSECURE" == "1";
|
||
allowUnfree = builtins.getEnv "NIXPKGS_ALLOW_UNFREE" == "1";
|
||
allowUnsupportedSystem = builtins.getEnv "NIXPKGS_ALLOW_UNSUPPORTED_SYSTEM" == "1";
|
||
};
|
||
|
||
in
|
||
|
||
{ # 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
|
||
|
||
, # 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
|
||
, crossSystem ? null
|
||
|
||
, # Fallback: The contents of the configuration file found at $NIXPKGS_CONFIG or
|
||
# $HOME/.config/nixpkgs/config.nix.
|
||
config ? let
|
||
configFile = getEnv "NIXPKGS_CONFIG";
|
||
configFile2 = homeDir + "/.config/nixpkgs/config.nix";
|
||
configFile3 = homeDir + "/.nixpkgs/config.nix"; # obsolete
|
||
in
|
||
if configFile != "" && pathExists configFile then import configFile
|
||
else if homeDir != "" && pathExists configFile2 then import configFile2
|
||
else if homeDir != "" && pathExists configFile3 then import configFile3
|
||
else {}
|
||
|
||
, # 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
|
||
isDir = path: pathExists (path + "/.");
|
||
pathOverlays = try (toString <nixpkgs-overlays>) "";
|
||
homeOverlaysFile = homeDir + "/.config/nixpkgs/overlays.nix";
|
||
homeOverlaysDir = homeDir + "/.config/nixpkgs/overlays";
|
||
overlays = path:
|
||
# check if the path is a directory or a file
|
||
if isDir path then
|
||
# it's a directory, so the set of overlays from the directory, ordered lexicographically
|
||
let content = readDir path; in
|
||
map (n: import (path + ("/" + n)))
|
||
(builtins.filter (n: builtins.match ".*\\.nix" n != null || pathExists (path + ("/" + n + "/default.nix")))
|
||
(attrNames content))
|
||
else
|
||
# it's a file, so the result is the contents of the file itself
|
||
import path;
|
||
in
|
||
if pathOverlays != "" && pathExists pathOverlays then overlays pathOverlays
|
||
else if pathExists homeOverlaysFile && pathExists homeOverlaysDir then
|
||
throw ''
|
||
Nixpkgs overlays can be specified with ${homeOverlaysFile} or ${homeOverlaysDir}, but not both.
|
||
Please remove one of them and try again.
|
||
''
|
||
else if pathExists homeOverlaysFile then
|
||
if isDir homeOverlaysFile then
|
||
throw (homeOverlaysFile + " should be a file")
|
||
else overlays homeOverlaysFile
|
||
else if pathExists homeOverlaysDir then
|
||
if !(isDir homeOverlaysDir) then
|
||
throw (homeOverlaysDir + " should be a directory")
|
||
else overlays homeOverlaysDir
|
||
else []
|
||
|
||
, crossOverlays ? []
|
||
|
||
, ...
|
||
} @ args:
|
||
|
||
# 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 overlays crossSystem crossOverlays;
|
||
|
||
config = defaultConfig // config;
|
||
|
||
# Fallback: Assume we are building packages on the current (build, in GNU
|
||
# Autotools parlance) system.
|
||
localSystem = if builtins.isString localSystem then localSystem
|
||
else (if args ? localSystem then {}
|
||
else { system = builtins.currentSystem; }) // localSystem;
|
||
})
|