lib.modules: Explain why options can only be merged into submodules

This commit is contained in:
Robert Hensing 2022-02-24 14:50:40 +01:00
parent 0c09eb343d
commit 81f342d1f3

View file

@ -501,6 +501,15 @@ rec {
}
else if optionDecls != [] then
if (lib.head optionDecls).options.type.name == "submodule"
# Raw options can only be merged into submodules. Merging into
# attrsets might be nice, but ambiguous. Suppose we have
# attrset as a `attrsOf submodule`. User declares option
# attrset.foo.bar, this could mean:
# a. option `bar` is only available in `attrset.foo`
# b. option `foo.bar` is available in all `attrset.*`
# c. reject and require "<name>" as a reminder that it behaves like (b).
# d. magically combine (a) and (c).
# All options are merely syntax sugar though.
then
let opt = fixupOptionType loc (mergeOptionDecls loc (map optionTreeToOption decls));
in {