index | npm-run-all | run-s | run-p | Node API |
---|
A CLI command to run given npm-scripts sequentially.
This command is the shorthand of npm-run-all -s
.
Usage:
$ run-s [--help | -h | --version | -v]
$ run-s [OPTIONS] <tasks>
Run given npm-scripts sequentially.
<tasks> : A list of npm-scripts' names and Glob-like patterns.
Options:
-c, --continue-on-error - Set the flag to continue executing subsequent
tasks even if a task threw an error. 'run-s'
itself will exit with non-zero code if one or
more tasks threw error(s).
--npm-path <string> - - - Set the path to npm. Default is the value of
environment variable npm_execpath.
If the variable is not defined, then it's "npm."
In this case, the "npm" command must be found in
environment variable PATH.
-l, --print-label - - - - Set the flag to print the task name as a prefix
on each line of output. Tools in tasks may stop
coloring their output if this option was given.
-n, --print-name - - - - Set the flag to print the task name before
running each task.
-s, --silent - - - - - - Set 'silent' to the log level of npm.
Shorthand aliases can be combined.
For example, '-clns' equals to '-c -l -n -s'.
Examples:
$ run-s build:**
$ run-s lint clean build:**
$ run-s --silent --print-name lint clean build:**
$ run-s -sn lint clean build:**
It's "scripts"
field of package.json
.
For example:
{
"scripts": {
"clean": "rm -rf dist",
"lint": "eslint src",
"build": "babel src -o lib"
}
}
We can run a script with npm run
command.
On the other hand, this run-s
command runs multiple scripts sequentially.
The following 2 commands are the same.
The run-s
command is shorter.
$ run-s clean lint build
$ npm run clean && npm run lint && npm run build
Note: If a script exited with a non-zero code, the following scripts are not run.
We can use glob-like patterns to specify npm-scripts.
The difference is one -- the separator is :
instead of /
.
$ run-s build:*
In this case, runs sub scripts of build
. For example: build:html
, build:js
.
But, doesn't run sub-sub scripts. For example: build:js:index
.
$ run-s build:**
If we use a globstar **
, runs both sub scripts and sub-sub scripts.
run-s
reads the actual npm-script list from package.json
in the current directory, then filters the scripts by glob-like patterns, then runs those.
We can enclose a script name or a pattern in quotes to use arguments. The following 2 commands are the same.
$ run-s start:server "delay 3000" start:client
$ npm run start:server && npm run delay 3000 && npm run start:client
When we use a pattern, arguments are forwarded to every matched script.
We can use placeholders to give the arguments preceded by --
to scripts.
$ run-s build "start-server -- --port {1}" -- 8080
This is useful to pass through arguments from npm run
command.
{
"scripts": {
"start": "run-s build \"start-server -- --port {1}\" --"
}
}
$ npm run start 8080
> [email protected] start /path/to/package.json
> run-s build "start-server -- --port {1}" -- "8080"
There are the following placeholders:
{1}
,{2}
, ... -- An argument.{1}
is the 1st argument.{2}
is the 2nd.{@}
-- All arguments.{*}
-- All arguments as combined.{%}
-- Repeats the command for every argument. (There's no equivalent shell parameter and does not support suffixes)
Support for following suffixes:
{1-=foo}
-- defaults to'foo'
here when the 1st argument is missing{1:=foo}
-- defaults to'foo'
here and in all following{1}
when the 1st argument is missing
Those are similar to Shell Parameters. But please note arguments are enclosed by double quotes automatically (similar to npm).
- If
--print-label
option is given, some tools in scripts might stop coloring their output. Because some coloring library (e.g. chalk) will stop coloring ifprocess.stdout
is not a TTY.run-s
changes theprocess.stdout
of child processes to a pipe in order to add labels to the head of each line if--print-label
option is given.
For example, eslint stops coloring underrun-s --print-label
. But eslint has--color
option to force coloring, we can use it.