diff options
author | Ruy Adorno <ruyadorno@hotmail.com> | 2021-03-04 18:19:28 -0500 |
---|---|---|
committer | Ruy Adorno <ruyadorno@hotmail.com> | 2021-03-15 18:13:01 -0400 |
commit | 6527e041f7d42ae127adade9862e86093979e64a (patch) | |
tree | 0749e788e19da7515dd200c70e142d6215e35f6e /tools/update-babel-eslint.sh | |
parent | ac73d58de240dff36cba6209e6c702014f4db16a (diff) | |
download | node-new-6527e041f7d42ae127adade9862e86093979e64a.tar.gz |
tools: use bundled npm in update scripts
The scripts `./tools/update-babel-eslint.sh` and
`./tools/update-eslint.sh` are relying on the version of `npm` found in
the local-defined `$PATH` env.
This changeset proposes to modify these scripts to run the version of
npm bundled in the current branch (found at `./deps/npm`) - in order to:
a) Standardize the version of npm that should be use to install these
deps, avoids the pitfall of having an inadverted user run these
scripts with an unsupported/incompatible npm version.
b) Given that npm7 has a different install algorithm than npm6 that
takes into account and install peer dependencies, it might be a safer
choice to ensure what version of npm should be use during this
transitional period in which users might still have npm6 by default in
their local system.
c) Avoids the possible extra churn of having different resulting files
being shuffled around between installs due to usage of a disparate
version of the npm cli.
PR-URL: https://github.com/nodejs/node/pull/37613
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: Richard Lau <rlau@redhat.com>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com>
Diffstat (limited to 'tools/update-babel-eslint.sh')
-rwxr-xr-x | tools/update-babel-eslint.sh | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/tools/update-babel-eslint.sh b/tools/update-babel-eslint.sh index b64b8f25d3..36bfd91891 100755 --- a/tools/update-babel-eslint.sh +++ b/tools/update-babel-eslint.sh @@ -2,8 +2,6 @@ # Shell script to update babel-eslint in the source tree to the latest release. -# Depends on npm, npx, and node being in $PATH. - # This script must be be in the tools directory when it runs because it uses # $0 to determine directories to work in. @@ -11,15 +9,20 @@ cd "$( dirname "${0}" )" || exit rm -rf node_modules/@babel mkdir babel-eslint-tmp cd babel-eslint-tmp || exit -npm init --yes -npm install --global-style --no-bin-links --production --no-package-lock @babel/core @babel/eslint-parser@latest @babel/plugin-syntax-class-properties@latest @babel/plugin-syntax-top-level-await@latest +ROOT="$PWD/../.." +[ -z "$NODE" ] && NODE="$ROOT/out/Release/node" +[ -x "$NODE" ] || NODE=`command -v node` +NPM="$ROOT/deps/npm" + +"$NODE" "$NPM" init --yes +"$NODE" "$NPM" install --global-style --no-bin-links --production --no-package-lock @babel/core @babel/eslint-parser@latest @babel/plugin-syntax-class-properties@latest @babel/plugin-syntax-top-level-await@latest # Use dmn to remove some unneeded files. -npx dmn@2.2.2 -f clean +"$NODE" "$NPM" exec -- dmn@2.2.2 -f clean # Use removeNPMAbsolutePaths to remove unused data in package.json. # This avoids churn as absolute paths can change from one dev to another. -npx removeNPMAbsolutePaths@1.0.4 . +"$NODE" "$NPM" exec -- removeNPMAbsolutePaths@1.0.4 . cd .. mv babel-eslint-tmp/node_modules/@babel node_modules/@babel |