2019-02-23 00:00:01 +00:00
|
|
|
# This file defines the structure of the `config` nixpkgs option.
|
|
|
|
|
2024-04-24 11:49:33 +01:00
|
|
|
# This file is tested in `pkgs/test/config.nix`.
|
|
|
|
# Run tests with:
|
|
|
|
#
|
|
|
|
# nix-build -A tests.config
|
|
|
|
#
|
|
|
|
|
2022-04-30 11:57:50 +01:00
|
|
|
{ config, lib, ... }:
|
2019-02-23 00:00:01 +00:00
|
|
|
|
|
|
|
let
|
2024-03-06 01:42:18 +00:00
|
|
|
inherit (lib)
|
|
|
|
literalExpression
|
|
|
|
mapAttrsToList
|
|
|
|
mkOption
|
|
|
|
optionals
|
|
|
|
types
|
|
|
|
;
|
2019-02-23 00:00:01 +00:00
|
|
|
|
2024-08-05 17:44:45 +01:00
|
|
|
mkMassRebuild = args: mkOption (builtins.removeAttrs args [ "feature" ] // {
|
|
|
|
type = args.type or (types.uniq types.bool);
|
|
|
|
default = args.default or false;
|
|
|
|
description = ((args.description or ''
|
|
|
|
Whether to ${args.feature} while building nixpkgs packages.
|
|
|
|
'') + ''
|
|
|
|
Changing the default may cause a mass rebuild.
|
|
|
|
'');
|
|
|
|
});
|
2019-02-23 00:00:01 +00:00
|
|
|
|
|
|
|
options = {
|
|
|
|
|
2024-08-05 17:44:45 +01:00
|
|
|
/* Internal stuff */
|
2019-02-23 00:00:01 +00:00
|
|
|
|
2022-05-01 20:43:10 +01:00
|
|
|
# Hide built-in module system options from docs.
|
2024-08-05 17:44:45 +01:00
|
|
|
_module.args = mkOption {
|
|
|
|
internal = true;
|
|
|
|
};
|
2022-05-01 20:43:10 +01:00
|
|
|
|
2019-02-23 00:00:01 +00:00
|
|
|
warnings = mkOption {
|
|
|
|
type = types.listOf types.str;
|
2024-08-05 17:44:45 +01:00
|
|
|
default = [];
|
2019-02-23 00:00:01 +00:00
|
|
|
internal = true;
|
|
|
|
};
|
|
|
|
|
2024-08-05 17:44:45 +01:00
|
|
|
/* Config options */
|
2019-02-23 00:00:01 +00:00
|
|
|
|
2022-04-30 11:57:50 +01:00
|
|
|
warnUndeclaredOptions = mkOption {
|
2024-04-13 14:00:20 +01:00
|
|
|
description = "Whether to warn when `config` contains an unrecognized attribute.";
|
2022-09-11 08:34:37 +01:00
|
|
|
type = types.bool;
|
2022-04-30 11:57:50 +01:00
|
|
|
default = false;
|
|
|
|
};
|
|
|
|
|
2024-08-05 17:44:45 +01:00
|
|
|
doCheckByDefault = mkMassRebuild {
|
|
|
|
feature = "run `checkPhase` by default";
|
|
|
|
};
|
2019-02-23 00:00:01 +00:00
|
|
|
|
2024-08-05 17:44:45 +01:00
|
|
|
strictDepsByDefault = mkMassRebuild {
|
|
|
|
feature = "set `strictDeps` to true by default";
|
|
|
|
};
|
2022-04-27 15:53:08 +01:00
|
|
|
|
2022-11-17 16:30:58 +00:00
|
|
|
structuredAttrsByDefault = mkMassRebuild {
|
|
|
|
feature = "set `__structuredAttrs` to true by default";
|
|
|
|
};
|
|
|
|
|
2022-05-11 14:41:30 +01:00
|
|
|
enableParallelBuildingByDefault = mkMassRebuild {
|
2022-09-11 15:19:44 +01:00
|
|
|
feature = "set `enableParallelBuilding` to true by default";
|
2022-05-11 14:41:30 +01:00
|
|
|
};
|
|
|
|
|
2022-06-21 08:14:34 +01:00
|
|
|
configurePlatformsByDefault = mkMassRebuild {
|
2022-09-11 15:19:44 +01:00
|
|
|
feature = "set `configurePlatforms` to `[\"build\" \"host\"]` by default";
|
2022-06-21 08:14:34 +01:00
|
|
|
};
|
|
|
|
|
2022-04-27 21:21:32 +01:00
|
|
|
contentAddressedByDefault = mkMassRebuild {
|
2022-09-11 15:19:44 +01:00
|
|
|
feature = "set `__contentAddressed` to true by default";
|
2022-04-27 21:21:32 +01:00
|
|
|
};
|
|
|
|
|
2022-04-01 10:33:10 +01:00
|
|
|
allowAliases = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = true;
|
2024-04-13 14:00:20 +01:00
|
|
|
description = ''
|
2022-04-01 10:33:10 +01:00
|
|
|
Whether to expose old attribute names for compatibility.
|
|
|
|
|
|
|
|
The recommended setting is to enable this, as it
|
2024-04-02 22:47:24 +01:00
|
|
|
improves backward compatibility, easing updates.
|
2022-04-01 10:33:10 +01:00
|
|
|
|
|
|
|
The only reason to disable aliases is for continuous
|
|
|
|
integration purposes. For instance, Nixpkgs should
|
|
|
|
not depend on aliases in its internal code. Projects
|
|
|
|
that aren't Nixpkgs should be cautious of instantly
|
|
|
|
removing all usages of aliases, as migrating too soon
|
|
|
|
can break compatibility with the stable Nixpkgs releases.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2022-05-02 13:49:04 +01:00
|
|
|
allowUnfree = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
# getEnv part is in check-meta.nix
|
|
|
|
defaultText = literalExpression ''false || builtins.getEnv "NIXPKGS_ALLOW_UNFREE" == "1"'';
|
2024-04-13 14:00:20 +01:00
|
|
|
description = ''
|
2022-05-02 13:49:04 +01:00
|
|
|
Whether to allow unfree packages.
|
|
|
|
|
2022-09-11 15:19:44 +01:00
|
|
|
See [Installing unfree packages](https://nixos.org/manual/nixpkgs/stable/#sec-allow-unfree) in the NixOS manual.
|
2022-05-02 13:49:04 +01:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2022-05-02 15:20:44 +01:00
|
|
|
allowBroken = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
# getEnv part is in check-meta.nix
|
|
|
|
defaultText = literalExpression ''false || builtins.getEnv "NIXPKGS_ALLOW_BROKEN" == "1"'';
|
2024-04-13 14:00:20 +01:00
|
|
|
description = ''
|
2022-05-02 15:20:44 +01:00
|
|
|
Whether to allow broken packages.
|
|
|
|
|
2022-09-11 15:19:44 +01:00
|
|
|
See [Installing broken packages](https://nixos.org/manual/nixpkgs/stable/#sec-allow-broken) in the NixOS manual.
|
2022-05-02 15:20:44 +01:00
|
|
|
'';
|
|
|
|
};
|
2022-05-02 18:39:43 +01:00
|
|
|
|
|
|
|
allowUnsupportedSystem = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
# getEnv part is in check-meta.nix
|
|
|
|
defaultText = literalExpression ''false || builtins.getEnv "NIXPKGS_ALLOW_UNSUPPORTED_SYSTEM" == "1"'';
|
2024-04-13 14:00:20 +01:00
|
|
|
description = ''
|
2022-05-02 18:39:43 +01:00
|
|
|
Whether to allow unsupported packages.
|
|
|
|
|
2022-09-11 15:19:44 +01:00
|
|
|
See [Installing packages on unsupported systems](https://nixos.org/manual/nixpkgs/stable/#sec-allow-unsupported-system) in the NixOS manual.
|
2022-05-02 18:39:43 +01:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2023-07-20 15:57:06 +01:00
|
|
|
cudaSupport = mkMassRebuild {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
feature = "build packages with CUDA support by default";
|
|
|
|
};
|
|
|
|
|
2024-06-05 05:19:38 +01:00
|
|
|
replaceBootstrapFiles = mkMassRebuild {
|
|
|
|
type = types.functionTo (types.attrsOf types.package);
|
|
|
|
default = lib.id;
|
|
|
|
defaultText = literalExpression "lib.id";
|
|
|
|
description = ''
|
|
|
|
Use the bootstrap files returned instead of the default bootstrap
|
|
|
|
files.
|
|
|
|
The default bootstrap files are passed as an argument.
|
|
|
|
'';
|
|
|
|
example = literalExpression ''
|
|
|
|
prevFiles:
|
|
|
|
let
|
|
|
|
replacements = {
|
|
|
|
"sha256-YQlr088HPoVWBU2jpPhpIMyOyoEDZYDw1y60SGGbUM0=" = import <nix/fetchurl.nix> {
|
|
|
|
url = "(custom glibc linux x86_64 bootstrap-tools.tar.xz)";
|
|
|
|
hash = "(...)";
|
|
|
|
};
|
|
|
|
"sha256-QrTEnQTBM1Y/qV9odq8irZkQSD9uOMbs2Q5NgCvKCNQ=" = import <nix/fetchurl.nix> {
|
|
|
|
url = "(custom glibc linux x86_64 busybox)";
|
|
|
|
hash = "(...)";
|
|
|
|
executable = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
in
|
|
|
|
builtins.mapAttrs (name: prev: replacements.''${prev.outputHash} or prev) prevFiles
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2023-11-14 00:50:59 +00:00
|
|
|
rocmSupport = mkMassRebuild {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
feature = "build packages with ROCm support by default";
|
|
|
|
};
|
|
|
|
|
2022-05-03 20:16:04 +01:00
|
|
|
showDerivationWarnings = mkOption {
|
|
|
|
type = types.listOf (types.enum [ "maintainerless" ]);
|
2024-08-05 17:44:45 +01:00
|
|
|
default = [];
|
2024-04-13 14:00:20 +01:00
|
|
|
description = ''
|
2022-05-03 20:16:04 +01:00
|
|
|
Which warnings to display for potentially dangerous
|
|
|
|
or deprecated values passed into `stdenv.mkDerivation`.
|
|
|
|
|
|
|
|
A list of warnings can be found in
|
2022-09-11 15:19:44 +01:00
|
|
|
[/pkgs/stdenv/generic/check-meta.nix](https://github.com/NixOS/nixpkgs/blob/master/pkgs/stdenv/generic/check-meta.nix).
|
2022-05-03 20:16:04 +01:00
|
|
|
|
|
|
|
This is not a stable interface; warnings may be added, changed
|
|
|
|
or removed without prior notice.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2022-09-14 11:17:39 +01:00
|
|
|
checkMeta = mkOption {
|
|
|
|
type = types.bool;
|
2022-10-02 13:28:40 +01:00
|
|
|
default = false;
|
2024-04-13 14:00:20 +01:00
|
|
|
description = ''
|
2022-09-14 11:17:39 +01:00
|
|
|
Whether to check that the `meta` attribute of derivations are correct during evaluation time.
|
|
|
|
'';
|
|
|
|
};
|
2019-02-23 00:00:01 +00:00
|
|
|
};
|
|
|
|
|
2024-08-05 17:44:45 +01:00
|
|
|
in {
|
2019-02-23 00:00:01 +00:00
|
|
|
|
2022-04-30 11:57:50 +01:00
|
|
|
freeformType =
|
2024-08-05 17:44:45 +01:00
|
|
|
let t = types.lazyAttrsOf types.raw;
|
|
|
|
in t // {
|
|
|
|
merge = loc: defs:
|
|
|
|
let r = t.merge loc defs;
|
|
|
|
in r // { _undeclared = r; };
|
2022-04-30 11:57:50 +01:00
|
|
|
};
|
|
|
|
|
2019-02-23 00:00:01 +00:00
|
|
|
inherit options;
|
|
|
|
|
2022-05-10 05:53:43 +01:00
|
|
|
config = {
|
2024-03-06 01:42:18 +00:00
|
|
|
warnings = optionals config.warnUndeclaredOptions (
|
2024-08-05 17:44:45 +01:00
|
|
|
mapAttrsToList (k: v: "undeclared Nixpkgs option set: config.${k}") config._undeclared or {}
|
2022-05-10 05:53:43 +01:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2019-02-23 00:00:01 +00:00
|
|
|
}
|