From 608d0e11f3007648276520e81d6d9672a434f10b Mon Sep 17 00:00:00 2001
From: Ruy Adorno
Date: Thu, 13 May 2021 16:18:53 -0400
Subject: [PATCH] deps: upgrade npm to 7.13.0
PR-URL: /~https://github.com/nodejs/node/pull/38682
Reviewed-By: Rich Trott
Reviewed-By: Danielle Adams
Reviewed-By: Trivikram Kamat
Reviewed-By: Luigi Pinca
Reviewed-By: Colin Ihrig
---
deps/npm/CHANGELOG.md | 18 +++
deps/npm/docs/content/commands/npm-fund.md | 56 ++++++++
deps/npm/docs/content/commands/npm-publish.md | 7 +
deps/npm/docs/output/commands/npm-fund.html | 45 ++++++
deps/npm/docs/output/commands/npm-ls.html | 2 +-
.../npm/docs/output/commands/npm-publish.html | 9 ++
deps/npm/docs/output/commands/npm.html | 2 +-
deps/npm/lib/fund.js | 16 ++-
deps/npm/lib/publish.js | 76 ++++++----
deps/npm/lib/workspaces/arborist-cmd.js | 24 ++++
deps/npm/man/man1/npm-fund.1 | 67 +++++++++
deps/npm/man/man1/npm-ls.1 | 2 +-
deps/npm/man/man1/npm-publish.1 | 7 +
deps/npm/man/man1/npm.1 | 2 +-
.../@npmcli/arborist/lib/arborist/index.js | 23 +++
.../arborist/lib/get-workspace-nodes.js | 33 +++++
.../@npmcli/arborist/package.json | 2 +-
deps/npm/node_modules/libnpmfund/CHANGELOG.md | 6 -
deps/npm/node_modules/libnpmfund/README.md | 5 +-
deps/npm/node_modules/libnpmfund/index.js | 63 +++++----
deps/npm/node_modules/libnpmfund/package.json | 19 ++-
deps/npm/package.json | 8 +-
.../tap-snapshots/test/lib/fund.js.test.cjs | 20 +++
.../test/lib/publish.js.test.cjs | 103 ++++++++++++++
.../test/lib/utils/npm-usage.js.test.cjs | 3 +
deps/npm/test/lib/fund.js | 86 ++++++++++++
deps/npm/test/lib/publish.js | 132 +++++++++++++++---
deps/npm/test/lib/workspaces/arborist-cmd.js | 109 +++++++++++++++
28 files changed, 846 insertions(+), 99 deletions(-)
create mode 100644 deps/npm/lib/workspaces/arborist-cmd.js
create mode 100644 deps/npm/node_modules/@npmcli/arborist/lib/get-workspace-nodes.js
delete mode 100644 deps/npm/node_modules/libnpmfund/CHANGELOG.md
create mode 100644 deps/npm/test/lib/workspaces/arborist-cmd.js
diff --git a/deps/npm/CHANGELOG.md b/deps/npm/CHANGELOG.md
index bed0f87c2b80c9..1c36c70875f722 100644
--- a/deps/npm/CHANGELOG.md
+++ b/deps/npm/CHANGELOG.md
@@ -1,3 +1,21 @@
+## v7.13.0 (2021-05-13)
+
+* [`076420c14`](/~https://github.com/npm/cli/commit/076420c149d097056f687e44e21744b743b86e4e)
+ [#3231](/~https://github.com/npm/cli/issues/3231)
+ feat(publish): add workspace support
+ ([@wraithgar](/~https://github.com/wraithgar))
+* [`370b36a36`](/~https://github.com/npm/cli/commit/370b36a36ca226840761e4214cbccaf2a1a90e3c)
+ [#3241](/~https://github.com/npm/cli/issues/3241)
+ feat(fund): add workspaces support
+ ([@ruyadorno](/~https://github.com/ruyadorno))
+
+### DEPENDENCIES
+
+* [`0c18e4f77`](/~https://github.com/npm/cli/commit/0c18e4f774562fa054fedf323bea25805ebf39b3)
+ `@npmcli/arborist@2.5.0`
+* [`b551c6811`](/~https://github.com/npm/cli/commit/b551c6811251dbc901f47fea3c137f93e205a9e4)
+ `libnpmfund@1.1.0`
+
## v7.12.1 (2021-05-10)
### BUG FIXES
diff --git a/deps/npm/docs/content/commands/npm-fund.md b/deps/npm/docs/content/commands/npm-fund.md
index aa1b26b9a8971b..45c5dfaac2afc2 100644
--- a/deps/npm/docs/content/commands/npm-fund.md
+++ b/deps/npm/docs/content/commands/npm-fund.md
@@ -8,6 +8,7 @@ description: Retrieve funding information
```bash
npm fund []
+npm fund [-w ]
```
### Description
@@ -24,6 +25,43 @@ The list will avoid duplicated entries and will stack all packages that
share the same url as a single entry. Thus, the list does not have the same
shape of the output from `npm ls`.
+#### Example
+
+### Workspaces support
+
+It's possible to filter the results to only include a single workspace and its
+dependencies using the `workspace` config option.
+
+#### Example:
+
+Here's an example running `npm fund` in a project with a configured
+workspace `a`:
+
+```bash
+$ npm fund
+test-workspaces-fund@1.0.0
++-- https://example.com/a
+| | `-- a@1.0.0
+| `-- https://example.com/maintainer
+| `-- foo@1.0.0
++-- https://example.com/npmcli-funding
+| `-- @npmcli/test-funding
+`-- https://example.com/org
+ `-- bar@2.0.0
+```
+
+And here is an example of the expected result when filtering only by
+a specific workspace `a` in the same project:
+
+```bash
+$ npm fund -w a
+test-workspaces-fund@1.0.0
+`-- https://example.com/a
+ | `-- a@1.0.0
+ `-- https://example.com/maintainer
+ `-- foo@2.0.0
+```
+
### Configuration
#### browser
@@ -48,6 +86,23 @@ Show information in JSON format.
Whether to represent the tree structure using unicode characters.
Set it to `false` in order to use all-ansi output.
+#### `workspace`
+
+* Default:
+* Type: String (can be set multiple times)
+
+Enable running a command in the context of the configured workspaces of the
+current project while filtering by running only the workspaces defined by
+this configuration option.
+
+Valid values for the `workspace` config are either:
+* Workspace names
+* Path to a workspace directory
+* Path to a parent workspace directory (will result to selecting all of the
+nested workspaces)
+
+This value is not exported to the environment for child processes.
+
#### which
* Type: Number
@@ -61,3 +116,4 @@ If there are multiple funding sources, which 1-indexed source URL to open.
* [npm docs](/commands/npm-docs)
* [npm ls](/commands/npm-ls)
* [npm config](/commands/npm-config)
+* [npm workspaces](/using-npm/workspaces)
diff --git a/deps/npm/docs/content/commands/npm-publish.md b/deps/npm/docs/content/commands/npm-publish.md
index fc13e672223589..10e65f895ec5bc 100644
--- a/deps/npm/docs/content/commands/npm-publish.md
+++ b/deps/npm/docs/content/commands/npm-publish.md
@@ -47,6 +47,13 @@ by specifying a different default registry or using a
actually publishing to the registry. Reports the details of what would
have been published.
+* `[--workspaces]`: Enables workspace context while publishing. All
+ workspace packages will be published.
+
+* `[--workspace]`: Enables workspaces context and limits results to only
+ those specified by this config item. Only the packages in the
+ workspaces given will be published.
+
The publish will fail if the package name and version combination already
exists in the specified registry.
diff --git a/deps/npm/docs/output/commands/npm-fund.html b/deps/npm/docs/output/commands/npm-fund.html
index bd9118fe326559..16539cfd998685 100644
--- a/deps/npm/docs/output/commands/npm-fund.html
+++ b/deps/npm/docs/output/commands/npm-fund.html
@@ -146,6 +146,7 @@
Table of contents
Synopsis
npm fund [<pkg>]
+npm fund [-w <workspace-name>]
Description
This command retrieves information on how to fund the dependencies of a
@@ -158,6 +159,33 @@
Description
The list will avoid duplicated entries and will stack all packages that
share the same url as a single entry. Thus, the list does not have the same
shape of the output from npm ls.
+
Example
+
Workspaces support
+
It’s possible to filter the results to only include a single workspace and its
+dependencies using the workspace config option.
+
Example:
+
Here’s an example running npm fund in a project with a configured
+workspace a:
And here is an example of the expected result when filtering only by
+a specific workspace a in the same project:
+
$ npm fund -w a
+test-workspaces-fund@1.0.0
+`-- https://example.com/a
+ | `-- a@1.0.0
+ `-- https://example.com/maintainer
+ `-- foo@2.0.0
+
Configuration
browser
@@ -178,6 +206,22 @@
unicode
Whether to represent the tree structure using unicode characters.
Set it to false in order to use all-ansi output.
+
workspace
+
+
Default:
+
Type: String (can be set multiple times)
+
+
Enable running a command in the context of the configured workspaces of the
+current project while filtering by running only the workspaces defined by
+this configuration option.
+
Valid values for the workspace config are either:
+
+
Workspace names
+
Path to a workspace directory
+
Path to a parent workspace directory (will result to selecting all of the
+nested workspaces)
+
+
This value is not exported to the environment for child processes.
the results to only the paths to the packages named. Note that nested
packages will also show the paths to the specified packages. For
example, running npm ls promzard in npm’s source tree will show:
actually publishing to the registry. Reports the details of what would
have been published.
+
+
[--workspaces]: Enables workspace context while publishing. All
+workspace packages will be published.
+
+
+
[--workspace]: Enables workspaces context and limits results to only
+those specified by this config item. Only the packages in the
+workspaces given will be published.
+
The publish will fail if the package name and version combination already
exists in the specified registry.
npm is the package manager for the Node JavaScript platform. It puts
modules in place so that node can find them, and manages dependency
diff --git a/deps/npm/lib/fund.js b/deps/npm/lib/fund.js
index 25d3462f638693..55d2f65dc4b55c 100644
--- a/deps/npm/lib/fund.js
+++ b/deps/npm/lib/fund.js
@@ -13,15 +13,14 @@ const {
const completion = require('./utils/completion/installed-deep.js')
const openUrl = require('./utils/open-url.js')
+const ArboristWorkspaceCmd = require('./workspaces/arborist-cmd.js')
const getPrintableName = ({ name, version }) => {
const printableVersion = version ? `@${version}` : ''
return `${name}${printableVersion}`
}
-const BaseCommand = require('./base-command.js')
-
-class Fund extends BaseCommand {
+class Fund extends ArboristWorkspaceCmd {
/* istanbul ignore next - see test/lib/load-all-commands.js */
static get description () {
return 'Retrieve funding information'
@@ -38,6 +37,7 @@ class Fund extends BaseCommand {
'json',
'browser',
'unicode',
+ 'workspace',
'which',
]
}
@@ -92,10 +92,16 @@ class Fund extends BaseCommand {
return
}
+ const fundingInfo = getFundingInfo(tree, {
+ ...this.flatOptions,
+ log: this.npm.log,
+ workspaces: this.workspaces,
+ })
+
if (this.npm.config.get('json'))
- this.npm.output(this.printJSON(getFundingInfo(tree)))
+ this.npm.output(this.printJSON(fundingInfo))
else
- this.npm.output(this.printHuman(getFundingInfo(tree)))
+ this.npm.output(this.printHuman(fundingInfo))
}
printJSON (fundingInfo) {
diff --git a/deps/npm/lib/publish.js b/deps/npm/lib/publish.js
index b121cb3d36773a..b33839903a266d 100644
--- a/deps/npm/lib/publish.js
+++ b/deps/npm/lib/publish.js
@@ -8,13 +8,19 @@ const pacote = require('pacote')
const npa = require('npm-package-arg')
const npmFetch = require('npm-registry-fetch')
-const flatten = require('./utils/config/flatten.js')
const otplease = require('./utils/otplease.js')
const { getContents, logTar } = require('./utils/tar.js')
+const getWorkspaces = require('./workspaces/get-workspaces.js')
+
+// for historical reasons, publishConfig in package.json can contain ANY config
+// keys that npm supports in .npmrc files and elsewhere. We *may* want to
+// revisit this at some point, and have a minimal set that's a SemVer-major
+// change that ought to get a RFC written on it.
+const flatten = require('./utils/config/flatten.js')
-// this is the only case in the CLI where we use the old full slow
-// 'read-package-json' module, because we want to pull in all the
-// defaults and metadata, like git sha's and default scripts and all that.
+// this is the only case in the CLI where we want to use the old full slow
+// 'read-package-json' module, because we want to pull in all the defaults and
+// metadata, like git sha's and default scripts and all that.
const readJson = util.promisify(require('read-package-json'))
const BaseCommand = require('./base-command.js')
@@ -30,7 +36,7 @@ class Publish extends BaseCommand {
/* istanbul ignore next - see test/lib/load-all-commands.js */
static get params () {
- return ['tag', 'access', 'dry-run']
+ return ['tag', 'access', 'dry-run', 'workspace', 'workspaces']
}
/* istanbul ignore next - see test/lib/load-all-commands.js */
@@ -44,6 +50,10 @@ class Publish extends BaseCommand {
this.publish(args).then(() => cb()).catch(cb)
}
+ execWorkspaces (args, filters, cb) {
+ this.publishWorkspaces(args, filters).then(() => cb()).catch(cb)
+ }
+
async publish (args) {
if (args.length === 0)
args = ['.']
@@ -56,6 +66,7 @@ class Publish extends BaseCommand {
const dryRun = this.npm.config.get('dry-run')
const json = this.npm.config.get('json')
const defaultTag = this.npm.config.get('tag')
+ const silent = log.level === 'silent'
if (semver.validRange(defaultTag))
throw new Error('Tag name must not be a valid SemVer range: ' + defaultTag.trim())
@@ -68,7 +79,7 @@ class Publish extends BaseCommand {
let manifest = await this.getManifest(spec, opts)
if (manifest.publishConfig)
- Object.assign(opts, this.publishConfigToOpts(manifest.publishConfig))
+ flatten(manifest.publishConfig, opts)
// only run scripts for directory type publishes
if (spec.type === 'directory') {
@@ -77,7 +88,7 @@ class Publish extends BaseCommand {
path: spec.fetchSpec,
stdio: 'inherit',
pkg: manifest,
- banner: log.level !== 'silent',
+ banner: !silent,
})
}
@@ -89,7 +100,7 @@ class Publish extends BaseCommand {
// note that publishConfig might have changed as well!
manifest = await this.getManifest(spec, opts)
if (manifest.publishConfig)
- Object.assign(opts, this.publishConfigToOpts(manifest.publishConfig))
+ flatten(manifest.publishConfig, opts)
// note that logTar calls npmlog.notice(), so if we ARE in silent mode,
// this will do nothing, but we still want it in the debuglog if it fails.
@@ -114,7 +125,7 @@ class Publish extends BaseCommand {
path: spec.fetchSpec,
stdio: 'inherit',
pkg: manifest,
- banner: log.level !== 'silent',
+ banner: !silent,
})
await runScript({
@@ -122,19 +133,43 @@ class Publish extends BaseCommand {
path: spec.fetchSpec,
stdio: 'inherit',
pkg: manifest,
- banner: log.level !== 'silent',
+ banner: !silent,
})
}
- const silent = log.level === 'silent'
- if (!silent && json)
- this.npm.output(JSON.stringify(pkgContents, null, 2))
- else if (!silent)
- this.npm.output(`+ ${pkgContents.id}`)
+ if (!this.workspaces) {
+ if (!silent && json)
+ this.npm.output(JSON.stringify(pkgContents, null, 2))
+ else if (!silent)
+ this.npm.output(`+ ${pkgContents.id}`)
+ }
return pkgContents
}
+ async publishWorkspaces (args, filters) {
+ // Suppresses JSON output in publish() so we can handle it here
+ this.workspaces = true
+
+ const results = {}
+ const json = this.npm.config.get('json')
+ const silent = log.level === 'silent'
+ const workspaces =
+ await getWorkspaces(filters, { path: this.npm.localPrefix })
+ for (const [name, workspace] of workspaces.entries()) {
+ const pkgContents = await this.publish([workspace])
+ // This needs to be in-line w/ the rest of the output that non-JSON
+ // publish generates
+ if (!silent && !json)
+ this.npm.output(`+ ${pkgContents.id}`)
+ else
+ results[name] = pkgContents
+ }
+
+ if (!silent && json)
+ this.npm.output(JSON.stringify(results, null, 2))
+ }
+
// if it's a directory, read it from the file system
// otherwise, get the full metadata from whatever it is
getManifest (spec, opts) {
@@ -142,16 +177,5 @@ class Publish extends BaseCommand {
return readJson(`${spec.fetchSpec}/package.json`)
return pacote.manifest(spec, { ...opts, fullMetadata: true })
}
-
- // for historical reasons, publishConfig in package.json can contain
- // ANY config keys that npm supports in .npmrc files and elsewhere.
- // We *may* want to revisit this at some point, and have a minimal set
- // that's a SemVer-major change that ought to get a RFC written on it.
- publishConfigToOpts (publishConfig) {
- // create a new object that inherits from the config stack
- // then squash the css-case into camelCase opts, like we do
- // this is Object.assign()'ed onto the base npm.flatOptions
- return flatten(publishConfig, {})
- }
}
module.exports = Publish
diff --git a/deps/npm/lib/workspaces/arborist-cmd.js b/deps/npm/lib/workspaces/arborist-cmd.js
new file mode 100644
index 00000000000000..f08843bd9ea5a8
--- /dev/null
+++ b/deps/npm/lib/workspaces/arborist-cmd.js
@@ -0,0 +1,24 @@
+// This is the base for all commands whose execWorkspaces just gets
+// a list of workspace names and passes it on to new Arborist() to
+// be able to run a filtered Arborist.reify() at some point.
+
+const BaseCommand = require('../base-command.js')
+const getWorkspaces = require('../workspaces/get-workspaces.js')
+class ArboristCmd extends BaseCommand {
+ /* istanbul ignore next - see test/lib/load-all-commands.js */
+ static get params () {
+ return [
+ 'workspace',
+ ]
+ }
+
+ execWorkspaces (args, filters, cb) {
+ getWorkspaces(filters, { path: this.npm.localPrefix })
+ .then(workspaces => {
+ this.workspaces = [...workspaces.keys()]
+ this.exec(args, cb)
+ })
+ }
+}
+
+module.exports = ArboristCmd
diff --git a/deps/npm/man/man1/npm-fund.1 b/deps/npm/man/man1/npm-fund.1
index 81a277bb0087c2..aa21dad231882a 100644
--- a/deps/npm/man/man1/npm-fund.1
+++ b/deps/npm/man/man1/npm-fund.1
@@ -6,6 +6,7 @@
.RS 2
.nf
npm fund []
+npm fund [\-w ]
.fi
.RE
.SS Description
@@ -21,6 +22,44 @@ to pass the \fB\-\-which\fP option to disambiguate\.
The list will avoid duplicated entries and will stack all packages that
share the same url as a single entry\. Thus, the list does not have the same
shape of the output from \fBnpm ls\fP\|\.
+.SS Example
+.SS Workspaces support
+.P
+It's possible to filter the results to only include a single workspace and its
+dependencies using the \fBworkspace\fP config option\.
+.SS Example:
+.P
+Here's an example running \fBnpm fund\fP in a project with a configured
+workspace \fBa\fP:
+.P
+.RS 2
+.nf
+$ npm fund
+test\-workspaces\-fund@1\.0\.0
++\-\- https://example\.com/a
+| | `\-\- a@1\.0\.0
+| `\-\- https://example\.com/maintainer
+| `\-\- foo@1\.0\.0
++\-\- https://example\.com/npmcli\-funding
+| `\-\- @npmcli/test\-funding
+`\-\- https://example\.com/org
+ `\-\- bar@2\.0\.0
+.fi
+.RE
+.P
+And here is an example of the expected result when filtering only by
+a specific workspace \fBa\fP in the same project:
+.P
+.RS 2
+.nf
+$ npm fund \-w a
+test\-workspaces\-fund@1\.0\.0
+`\-\- https://example\.com/a
+ | `\-\- a@1\.0\.0
+ `\-\- https://example\.com/maintainer
+ `\-\- foo@2\.0\.0
+.fi
+.RE
.SS Configuration
.SS browser
.RS 0
@@ -53,6 +92,32 @@ Default: true
.P
Whether to represent the tree structure using unicode characters\.
Set it to \fBfalse\fP in order to use all\-ansi output\.
+.SS \fBworkspace\fP
+.RS 0
+.IP \(bu 2
+Default:
+.IP \(bu 2
+Type: String (can be set multiple times)
+
+.RE
+.P
+Enable running a command in the context of the configured workspaces of the
+current project while filtering by running only the workspaces defined by
+this configuration option\.
+.P
+Valid values for the \fBworkspace\fP config are either:
+.RS 0
+.IP \(bu 2
+Workspace names
+.IP \(bu 2
+Path to a workspace directory
+.IP \(bu 2
+Path to a parent workspace directory (will result to selecting all of the
+nested workspaces)
+
+.RE
+.P
+This value is not exported to the environment for child processes\.
.SS which
.RS 0
.IP \(bu 2
@@ -73,5 +138,7 @@ npm help docs
npm help ls
.IP \(bu 2
npm help config
+.IP \(bu 2
+npm help workspaces
.RE
diff --git a/deps/npm/man/man1/npm-ls.1 b/deps/npm/man/man1/npm-ls.1
index c47da91875482f..d7013b296440c0 100644
--- a/deps/npm/man/man1/npm-ls.1
+++ b/deps/npm/man/man1/npm-ls.1
@@ -26,7 +26,7 @@ example, running \fBnpm ls promzard\fP in npm's source tree will show:
.P
.RS 2
.nf
-npm@7\.12\.1 /path/to/npm
+npm@7\.13\.0 /path/to/npm
└─┬ init\-package\-json@0\.0\.4
└── promzard@0\.1\.5
.fi
diff --git a/deps/npm/man/man1/npm-publish.1 b/deps/npm/man/man1/npm-publish.1
index c405f64f27e361..906c5a36e194fe 100644
--- a/deps/npm/man/man1/npm-publish.1
+++ b/deps/npm/man/man1/npm-publish.1
@@ -45,6 +45,13 @@ from a TTY then you'll be prompted\.
\fB[\-\-dry\-run]\fP: As of \fBnpm@6\fP, does everything publish would do except
actually publishing to the registry\. Reports the details of what would
have been published\.
+.IP \(bu 2
+\fB[\-\-workspaces]\fP: Enables workspace context while publishing\. All
+workspace packages will be published\.
+.IP \(bu 2
+\fB[\-\-workspace]\fP: Enables workspaces context and limits results to only
+those specified by this config item\. Only the packages in the
+workspaces given will be published\.
.RE
.P
diff --git a/deps/npm/man/man1/npm.1 b/deps/npm/man/man1/npm.1
index 4562527e1b5ade..4921bcc656a555 100644
--- a/deps/npm/man/man1/npm.1
+++ b/deps/npm/man/man1/npm.1
@@ -10,7 +10,7 @@ npm [args]
.RE
.SS Version
.P
-7\.12\.1
+7\.13\.0
.SS Description
.P
npm is the package manager for the Node JavaScript platform\. It puts
diff --git a/deps/npm/node_modules/@npmcli/arborist/lib/arborist/index.js b/deps/npm/node_modules/@npmcli/arborist/lib/arborist/index.js
index 3578d50389ea64..cd39df01af6c6f 100644
--- a/deps/npm/node_modules/@npmcli/arborist/lib/arborist/index.js
+++ b/deps/npm/node_modules/@npmcli/arborist/lib/arborist/index.js
@@ -45,6 +45,7 @@ const mixins = [
]
const Base = mixins.reduce((a, b) => b(a), require('events'))
+const getWorkspaceNodes = require('../get-workspace-nodes.js')
class Arborist extends Base {
constructor (options = {}) {
@@ -64,6 +65,28 @@ class Arborist extends Base {
this.path = resolve(this.options.path)
process.emit('timeEnd', 'arborist:ctor')
}
+
+ // returns an array of the actual nodes for all the workspaces
+ workspaceNodes (tree, workspaces) {
+ return getWorkspaceNodes(tree, workspaces, this.log)
+ }
+
+ // returns a set of workspace nodes and all their deps
+ workspaceDependencySet (tree, workspaces) {
+ const wsNodes = this.workspaceNodes(tree, workspaces)
+ const set = new Set(wsNodes)
+ for (const node of set) {
+ for (const edge of node.edgesOut.values()) {
+ const dep = edge.to
+ if (dep) {
+ set.add(dep)
+ if (dep.target)
+ set.add(dep.target)
+ }
+ }
+ }
+ return set
+ }
}
module.exports = Arborist
diff --git a/deps/npm/node_modules/@npmcli/arborist/lib/get-workspace-nodes.js b/deps/npm/node_modules/@npmcli/arborist/lib/get-workspace-nodes.js
new file mode 100644
index 00000000000000..6db489f69c5185
--- /dev/null
+++ b/deps/npm/node_modules/@npmcli/arborist/lib/get-workspace-nodes.js
@@ -0,0 +1,33 @@
+// Get the actual nodes corresponding to a root node's child workspaces,
+// given a list of workspace names.
+const relpath = require('./relpath.js')
+const getWorkspaceNodes = (tree, workspaces, log) => {
+ const wsMap = tree.workspaces
+ if (!wsMap) {
+ log.warn('workspaces', 'filter set, but no workspaces present')
+ return []
+ }
+
+ const nodes = []
+ for (const name of workspaces) {
+ const path = wsMap.get(name)
+ if (!path) {
+ log.warn('workspaces', `${name} in filter set, but not in workspaces`)
+ continue
+ }
+
+ const loc = relpath(tree.realpath, path)
+ const node = tree.inventory.get(loc)
+
+ if (!node) {
+ log.warn('workspaces', `${name} in filter set, but no workspace folder present`)
+ continue
+ }
+
+ nodes.push(node)
+ }
+
+ return nodes
+}
+
+module.exports = getWorkspaceNodes
diff --git a/deps/npm/node_modules/@npmcli/arborist/package.json b/deps/npm/node_modules/@npmcli/arborist/package.json
index bbe87d8bf97ad2..fd579cbf27fdc8 100644
--- a/deps/npm/node_modules/@npmcli/arborist/package.json
+++ b/deps/npm/node_modules/@npmcli/arborist/package.json
@@ -1,6 +1,6 @@
{
"name": "@npmcli/arborist",
- "version": "2.4.4",
+ "version": "2.5.0",
"description": "Manage node_modules trees",
"dependencies": {
"@npmcli/installed-package-contents": "^1.0.7",
diff --git a/deps/npm/node_modules/libnpmfund/CHANGELOG.md b/deps/npm/node_modules/libnpmfund/CHANGELOG.md
deleted file mode 100644
index b890b58e1405ae..00000000000000
--- a/deps/npm/node_modules/libnpmfund/CHANGELOG.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# Changelog
-
-## 0.0.0-pre.0
-
-- Initial pre-release.
-
diff --git a/deps/npm/node_modules/libnpmfund/README.md b/deps/npm/node_modules/libnpmfund/README.md
index c373a9ceb7dd57..8ab663f634d6fb 100644
--- a/deps/npm/node_modules/libnpmfund/README.md
+++ b/deps/npm/node_modules/libnpmfund/README.md
@@ -73,7 +73,10 @@ Options:
- `countOnly`: Uses the tree-traversal logic from **npm fund** but skips over
any obj definition and just returns an obj containing `{ length }` - useful for
things such as printing a `6 packages are looking for funding` msg.
-- `path`: Location to current working directory
+- `workspaces`: `Array` List of workspaces names to filter for,
+the result will only include a subset of the resulting tree that includes
+only the nodes that are children of the listed workspaces names.
+- `path`, `registry` and more [Arborist](/~https://github.com/npm/arborist/) options.
##### `> fund.readTree(tree, [opts]) -> Promise