Major Changes
-
The root package is excluded by default, when running
pnpm -r exec|run|add
#2769. -
Filtering by path is done by globs.
In pnpm v6, in order to pick packages under a certain directory, the following filter was used:
--filter=./apps
In pnpm v7, a glob should be used:
--filter=./apps/**
-
The
NODE_PATH
env variable is not set in the command shims (the files innode_modules/.bin
). This env variable was really long and frequently caused errors on Windows.Also, the
extend-node-path
setting is removed.Related PR: #4253
-
The
embed-readme
setting isfalse
by default. -
When using
pnpm run <script>
, all command line arguments after the script name are now passed to the script's argv, even--
. For example,pnpm run echo --hello -- world
will now pass--hello -- world
to theecho
script's argv. Previously flagged arguments (e.g.--silent
) were intepreted as pnpm arguments unless--
came before it. -
Side effects cache is turned on by default. To turn it off, use
side-effects-cache=false
. -
The
npm_config_argv
env variable is not set for scripts #4153. -
pnpx
is now just an alias ofpnpm dlx
.If you want to just execute the command of a dependency, run
pnpm <cmd>
. For instance,pnpm eslint
.If you want to install and execute, use
pnpm dlx <pkg name>
. -
pnpm install -g pkg
will add the global command only to a predefined location. pnpm will not try to add a bin to the global Node.js or npm folder. To set the global bin directory, either set thePNPM_HOME
env variable or theglobal-bin-dir
setting. -
pnpm pack
should only pack a file as an executable if it's a bin or listed in thepublishConfig.executableFiles
array.