2024-07-28 22:51:18 +01:00
|
|
|
|
{ lib }:
|
2024-06-24 12:16:54 +01:00
|
|
|
|
rec {
|
|
|
|
|
# Get a (sub)option by walking the path,
|
|
|
|
|
# checking for submodules along the way
|
|
|
|
|
getOptionRecursive =
|
|
|
|
|
opt: prefix: optionPath:
|
|
|
|
|
if optionPath == [ ] then
|
|
|
|
|
opt
|
2024-08-30 14:49:20 -05:00
|
|
|
|
else if lib.isOption opt then
|
2024-06-24 12:16:54 +01:00
|
|
|
|
getOptionRecursive (opt.type.getSubOptions prefix) prefix optionPath
|
|
|
|
|
else
|
|
|
|
|
let
|
2024-08-30 14:49:20 -05:00
|
|
|
|
name = lib.head optionPath;
|
|
|
|
|
opt' = lib.getAttr name opt;
|
2024-06-24 12:16:54 +01:00
|
|
|
|
prefix' = prefix ++ [ name ];
|
2024-08-30 14:49:20 -05:00
|
|
|
|
optionPath' = lib.drop 1 optionPath;
|
2024-06-24 12:16:54 +01:00
|
|
|
|
in
|
|
|
|
|
getOptionRecursive opt' prefix' optionPath';
|
|
|
|
|
|
|
|
|
|
# Like mkRemovedOptionModule, but has support for nested sub-options
|
|
|
|
|
# and uses warnings instead of assertions.
|
|
|
|
|
mkDeprecatedSubOptionModule =
|
|
|
|
|
optionPath: replacementInstructions:
|
|
|
|
|
{ options, ... }:
|
|
|
|
|
{
|
2024-08-30 14:49:20 -05:00
|
|
|
|
options = lib.setAttrByPath optionPath (
|
|
|
|
|
lib.mkOption {
|
|
|
|
|
# When (e.g.) `mkAttrs` is used on a submodule, this option will be evaluated.
|
|
|
|
|
# Therefore we have to apply _something_ (null) when there's no definition.
|
|
|
|
|
apply =
|
|
|
|
|
v:
|
|
|
|
|
let
|
|
|
|
|
# Avoid "option used but not defined" errors
|
|
|
|
|
res = builtins.tryEval v;
|
|
|
|
|
in
|
|
|
|
|
if res.success then res.value else null;
|
|
|
|
|
visible = false;
|
|
|
|
|
}
|
|
|
|
|
);
|
2024-06-24 12:16:54 +01:00
|
|
|
|
config.warnings =
|
|
|
|
|
let
|
|
|
|
|
opt = getOptionRecursive options [ ] optionPath;
|
|
|
|
|
in
|
2024-08-30 14:49:20 -05:00
|
|
|
|
lib.optional opt.isDefined ''
|
|
|
|
|
The option definition `${lib.showOption optionPath}' in ${lib.showFiles opt.files} is deprecated.
|
2024-06-24 12:16:54 +01:00
|
|
|
|
${replacementInstructions}
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-08-13 09:23:17 -05:00
|
|
|
|
mkSettingsRenamedOptionModules =
|
|
|
|
|
oldPrefix: newPrefix:
|
|
|
|
|
map (
|
|
|
|
|
option':
|
|
|
|
|
let
|
2024-08-30 14:49:20 -05:00
|
|
|
|
option = lib.toList option';
|
2024-08-13 09:23:17 -05:00
|
|
|
|
oldPath = oldPrefix ++ option;
|
2024-08-30 14:49:20 -05:00
|
|
|
|
newPath = newPrefix ++ map lib.nixvim.toSnakeCase option;
|
2024-08-13 09:23:17 -05:00
|
|
|
|
in
|
2024-08-30 14:49:20 -05:00
|
|
|
|
lib.mkRenamedOptionModule oldPath newPath
|
2024-08-13 09:23:17 -05:00
|
|
|
|
);
|
|
|
|
|
|
2024-07-07 16:01:10 +01:00
|
|
|
|
# A clone of types.coercedTo, but it prints a warning when oldType is used.
|
|
|
|
|
transitionType =
|
|
|
|
|
oldType: coerceFn: newType:
|
|
|
|
|
assert lib.assertMsg (
|
|
|
|
|
oldType.getSubModules == null
|
|
|
|
|
) "transitionType: oldType must not have submodules (it’s a ${oldType.description})";
|
|
|
|
|
lib.mkOptionType rec {
|
|
|
|
|
name = "transitionType";
|
|
|
|
|
inherit (newType) description;
|
|
|
|
|
check = x: (oldType.check x && newType.check (coerceFn x)) || newType.check x;
|
|
|
|
|
merge =
|
|
|
|
|
opt: defs:
|
|
|
|
|
let
|
|
|
|
|
coerceVal =
|
|
|
|
|
val:
|
|
|
|
|
if oldType.check val then
|
|
|
|
|
lib.warn ''
|
|
|
|
|
Passing a ${oldType.description} for `${lib.showOption opt}' is deprecated, use ${newType.description} instead. Definitions: ${lib.options.showDefs defs}
|
|
|
|
|
'' (coerceFn val)
|
|
|
|
|
else
|
|
|
|
|
val;
|
|
|
|
|
in
|
|
|
|
|
newType.merge opt (map (def: def // { value = coerceVal def.value; }) defs);
|
|
|
|
|
inherit (newType) emptyValue;
|
|
|
|
|
inherit (newType) getSubOptions;
|
|
|
|
|
inherit (newType) getSubModules;
|
|
|
|
|
substSubModules = m: transitionType oldType coerceFn (newType.substSubModules m);
|
|
|
|
|
typeMerge = t1: t2: null;
|
|
|
|
|
functor = (lib.types.defaultFunctor name) // {
|
|
|
|
|
wrapped = newType;
|
|
|
|
|
};
|
|
|
|
|
nestedTypes.coercedType = oldType;
|
|
|
|
|
nestedTypes.finalType = newType;
|
|
|
|
|
};
|
2024-06-24 12:16:54 +01:00
|
|
|
|
}
|