A manager for npm deprecation warnings.
Turn:
$ npm clean-install
npm warn deprecated [email protected]: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.
npm warn deprecated @humanwhocodes/[email protected]: Use @eslint/config-array instead
npm warn deprecated [email protected]: Rimraf versions prior to v4 are no longer supported
npm warn deprecated @humanwhocodes/[email protected]: Use @eslint/config-array instead
npm warn deprecated [email protected]: Glob versions prior to v9 are no longer supported
npm warn deprecated [email protected]: Glob versions prior to v9 are no longer supported
npm warn deprecated [email protected]: Glob versions prior to v9 are no longer supported
npm warn deprecated @humanwhocodes/[email protected]: Use @eslint/object-schema instead
npm warn deprecated @humanwhocodes/[email protected]: Use @eslint/object-schema instead
npm warn deprecated [email protected]: This version is no longer supported. Please see https://eslint.org/version-support for other options.Into:
$ depreman
[email protected] ("Glob versions prior to v9 are no longer supported"):
[email protected] > [email protected]
[email protected] > [email protected] > [email protected]-
Install:
npm install depreman
-
Create an
.ndmrcfile in the root of your project. -
Run:
npx depreman
-
Configure.
The CLI has a couple of options:
--help/-h: show help text.--errors-only: output only deprecation warnings that are not ignored.--report-unused: report and fail if there is an ignore directive that is unused. This is recommended if you have a lockfile but discouraged if you do not.--package-manager=<npm|yarn>: select which package manager to use, 'npm' (default) or 'yarn'.--omit=<dev|optional|peer>: ignore deprecation warnings in development, optional, or peer dependencies. Can be repeated.
An .ndmrc file is just a JSON file with rules for deprecated dependencies to
ignore. The object hierarchy should reflect the dependency hierarchy with keys
representing <package>@<version> pairs (semver version ranges supported).
The * wildcard can be used to match 0-or-more dependencies in a hierarchy and
the + wildcard can be used to match 1-or-more dependencies in a hierarchy.
Use the "#ignore" directive when a deprecation for a given dependency should
be ignored and assign it a reason as a string (or a boolean if you prefer).
Optionally, use the "#expire" directive to set a date (YYYY-MM-DD) on which
the rule expires. Use the #scope directive to select in which scopes (e.g.
dev) the deprecation should be ignored.
For example:
{
"ignore@v0": {
"#ignore": "ignore deprecation warnings for ignore@v0 but not its children"
},
"not-ignored@v1": {
"package-a@v2": {
"#ignore": "ignore deprecation warnings for not-ignored@v1 > package-a@v2"
},
"package-b@v3": {
"#ignore": "and for package-b@v3 only until December 31, 2024",
"#expire": "2024-12-31"
}
},
"ignore-it@v4": {
"*": {
"#ignore": "ignore direct and transitive deprecation warnings with '*'"
}
},
"also-not-ignored@v5": {
"+": {
"#ignore": "ignore transitive deprecation warnings only with '+'"
}
},
"*": {
"ignored@v6": {
"#ignore": "ignore deprecation warnings anywhere in the tree"
},
"dev-only@v7": {
"#ignore": "only if it is used as a development dependency",
"#scope": ["dev"]
}
},
"no-reason@v8": {
"#ignore": true
}
}This software is available under the AGPL-3.0-only license, see LICENSE for
the full license text. Documentation is available under the GFDL-1.3-or-later
license, see GNU Free Documentation License v1.3 for the full license text.