Is there an existing issue for this?
This is a CLI Docs Problem, not another kind of Docs Problem.
Description of Problem
For overrides, I was surprised to find that the parent key version range is not just a matcher / condition, but also an applied override to the parent. (if it matches the parent)
It fits the docs, once you understood. I needed some testing around, reading code and docs again to get there.
Example: Sub-dependency foo version 19 gets overridden to version 20 for the following overrides:
{ "overrides": {
"foo@<=20": {
"bar": "1.2.3"
}
}}
Potential Solution
How about stating more clearly that parent key version ranges apply overrides too, adding the following?
Parent keys with version ranges override that parent's version too, if matching. Add child override `".": "$foo"` to prevent that.
This seems to do what I actually want:
{ "overrides": {
".": "$foo",
"foo@<=20": {
"bar": "1.2.3"
}
}}
❗ I do not know though, if I should actually use reference $foo if it is a sub-dependency itself. Docs state [...] overrides may also be defined as a reference to a spec for a direct dependency [...].
Affected URL
This is regarding https://docs.npmjs.com/cli/v11/configuring-npm/package-json#overrides
The key of an override can also include a version, or range of versions. To override `@npm/foo` to `1.0.0`, but only when it's a child of `@npm/bar@2.0.0`:
Is there an existing issue for this?
This is a CLI Docs Problem, not another kind of Docs Problem.
Description of Problem
For
overrides, I was surprised to find that the parent key version range is not just a matcher / condition, but also an applied override to the parent. (if it matches the parent)It fits the docs, once you understood. I needed some testing around, reading code and docs again to get there.
Example: Sub-dependency
fooversion19gets overridden to version20for the following overrides:{ "overrides": { "foo@<=20": { "bar": "1.2.3" } }}Potential Solution
How about stating more clearly that parent key version ranges apply overrides too, adding the following?
This seems to do what I actually want:
{ "overrides": { ".": "$foo", "foo@<=20": { "bar": "1.2.3" } }}❗ I do not know though, if I should actually use reference
$fooif it is a sub-dependency itself. Docs state[...] overrides may also be defined as a reference to a spec for a direct dependency [...].Affected URL
This is regarding https://docs.npmjs.com/cli/v11/configuring-npm/package-json#overrides