summaryrefslogtreecommitdiff
path: root/tools/update-babel-eslint.sh
diff options
context:
space:
mode:
authorRuy Adorno <ruyadorno@hotmail.com>2021-03-04 18:19:28 -0500
committerRuy Adorno <ruyadorno@hotmail.com>2021-03-15 18:13:01 -0400
commit6527e041f7d42ae127adade9862e86093979e64a (patch)
tree0749e788e19da7515dd200c70e142d6215e35f6e /tools/update-babel-eslint.sh
parentac73d58de240dff36cba6209e6c702014f4db16a (diff)
downloadnode-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-xtools/update-babel-eslint.sh15
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