Merge pull request #97114 from Infinisil/type-deprecation
Better type deprecation messages
This commit is contained in:
commit
ed5a07c0ef
|
@ -457,7 +457,11 @@ rec {
|
||||||
# yield a value computed from the definitions
|
# yield a value computed from the definitions
|
||||||
value = if opt ? apply then opt.apply res.mergedValue else res.mergedValue;
|
value = if opt ? apply then opt.apply res.mergedValue else res.mergedValue;
|
||||||
|
|
||||||
in opt //
|
warnDeprecation =
|
||||||
|
if opt.type.deprecationMessage == null then id
|
||||||
|
else warn "The type `types.${opt.type.name}' of option `${showOption loc}' defined in ${showFiles opt.declarations} is deprecated. ${opt.type.deprecationMessage}";
|
||||||
|
|
||||||
|
in warnDeprecation opt //
|
||||||
{ value = builtins.addErrorContext "while evaluating the option `${showOption loc}':" value;
|
{ value = builtins.addErrorContext "while evaluating the option `${showOption loc}':" value;
|
||||||
inherit (res.defsFinal') highestPrio;
|
inherit (res.defsFinal') highestPrio;
|
||||||
definitions = map (def: def.value) res.defsFinal;
|
definitions = map (def: def.value) res.defsFinal;
|
||||||
|
|
|
@ -91,9 +91,12 @@ rec {
|
||||||
# combinable with the binOp binary operation.
|
# combinable with the binOp binary operation.
|
||||||
# binOp: binary operation that merge two payloads of the same type.
|
# binOp: binary operation that merge two payloads of the same type.
|
||||||
functor ? defaultFunctor name
|
functor ? defaultFunctor name
|
||||||
|
, # The deprecation message to display when this type is used by an option
|
||||||
|
# If null, the type isn't deprecated
|
||||||
|
deprecationMessage ? null
|
||||||
}:
|
}:
|
||||||
{ _type = "option-type";
|
{ _type = "option-type";
|
||||||
inherit name check merge emptyValue getSubOptions getSubModules substSubModules typeMerge functor;
|
inherit name check merge emptyValue getSubOptions getSubModules substSubModules typeMerge functor deprecationMessage;
|
||||||
description = if description == null then name else description;
|
description = if description == null then name else description;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -222,8 +225,10 @@ rec {
|
||||||
|
|
||||||
# Deprecated; should not be used because it quietly concatenates
|
# Deprecated; should not be used because it quietly concatenates
|
||||||
# strings, which is usually not what you want.
|
# strings, which is usually not what you want.
|
||||||
string = warn "types.string is deprecated because it quietly concatenates strings"
|
string = separatedString "" // {
|
||||||
(separatedString "");
|
name = "string";
|
||||||
|
deprecationMessage = "See https://github.com/NixOS/nixpkgs/pull/66346 for better alternative types.";
|
||||||
|
};
|
||||||
|
|
||||||
attrs = mkOptionType {
|
attrs = mkOptionType {
|
||||||
name = "attrs";
|
name = "attrs";
|
||||||
|
@ -252,9 +257,6 @@ rec {
|
||||||
merge = mergeEqualOption;
|
merge = mergeEqualOption;
|
||||||
};
|
};
|
||||||
|
|
||||||
# TODO: drop this in the future:
|
|
||||||
list = builtins.trace "`types.list` has been removed; please use `types.listOf` instead" types.listOf;
|
|
||||||
|
|
||||||
listOf = elemType: mkOptionType rec {
|
listOf = elemType: mkOptionType rec {
|
||||||
name = "listOf";
|
name = "listOf";
|
||||||
description = "list of ${elemType.description}s";
|
description = "list of ${elemType.description}s";
|
||||||
|
@ -327,14 +329,12 @@ rec {
|
||||||
};
|
};
|
||||||
|
|
||||||
# TODO: drop this in the future:
|
# TODO: drop this in the future:
|
||||||
loaOf =
|
loaOf = elemType: types.attrsOf elemType // {
|
||||||
let msg =
|
name = "loaOf";
|
||||||
''
|
deprecationMessage = "Mixing lists with attribute values is no longer"
|
||||||
`types.loaOf` has been removed and mixing lists with attribute values
|
+ " possible; please use `types.attrsOf` instead. See"
|
||||||
is no longer possible; please use `types.attrsOf` instead.
|
+ " https://github.com/NixOS/nixpkgs/issues/1800 for the motivation.";
|
||||||
See https://github.com/NixOS/nixpkgs/issues/1800 for the motivation.
|
};
|
||||||
'';
|
|
||||||
in builtins.trace msg types.attrsOf;
|
|
||||||
|
|
||||||
# Value of given type but with no merging (i.e. `uniq list`s are not concatenated).
|
# Value of given type but with no merging (i.e. `uniq list`s are not concatenated).
|
||||||
uniq = elemType: mkOptionType rec {
|
uniq = elemType: mkOptionType rec {
|
||||||
|
@ -534,8 +534,9 @@ rec {
|
||||||
# declarations from the ‘options’ attribute of containing option
|
# declarations from the ‘options’ attribute of containing option
|
||||||
# declaration.
|
# declaration.
|
||||||
optionSet = mkOptionType {
|
optionSet = mkOptionType {
|
||||||
name = builtins.trace "types.optionSet is deprecated; use types.submodule instead" "optionSet";
|
name = "optionSet";
|
||||||
description = "option set";
|
description = "option set";
|
||||||
|
deprecationMessage = "Use `types.submodule' instead";
|
||||||
};
|
};
|
||||||
# Augment the given type with an additional type check function.
|
# Augment the given type with an additional type check function.
|
||||||
addCheck = elemType: check: elemType // { check = x: elemType.check x && check x; };
|
addCheck = elemType: check: elemType // { check = x: elemType.check x && check x; };
|
||||||
|
|
Loading…
Reference in New Issue