diff --git a/content/docs/command-reference/dag.md b/content/docs/command-reference/dag.md
index 08122c356b..a905c9b9aa 100644
--- a/content/docs/command-reference/dag.md
+++ b/content/docs/command-reference/dag.md
@@ -32,8 +32,8 @@ final model, as well as accuracy [metrics](/doc/command-reference/metrics).
In DVC, pipeline stages and commands, their data I/O, interdependencies, and
results (intermediate or final) are specified in `dvc.yaml`, which can be
-written manually or built using the helper command `dvc run`. This allows DVC to
-restore one or more pipelines later (see `dvc repro`).
+written manually or built using the helper command `dvc stage add`. This allows
+DVC to restore one or more pipelines later (see `dvc repro`).
> DVC builds a dependency graph
> ([DAG](https://en.wikipedia.org/wiki/Directed_acyclic_graph)) to do this.
diff --git a/content/docs/command-reference/import-url.md b/content/docs/command-reference/import-url.md
index 47a97d0cc7..1493e85b55 100644
--- a/content/docs/command-reference/import-url.md
+++ b/content/docs/command-reference/import-url.md
@@ -110,17 +110,19 @@ Instead of:
$ dvc import-url https://data.dvc.org/get-started/data.xml data.xml
```
-It is possible to use `dvc run`, for example (HTTP URL):
+It is possible to use `dvc stage add`, for example (HTTP URL):
```dvc
-$ dvc run -n download_data \
- -d https://data.dvc.org/get-started/data.xml \
- -o data.xml \
- wget https://data.dvc.org/get-started/data.xml -O data.xml
+$ dvc stage add -n download_data \
+ -d https://data.dvc.org/get-started/data.xml \
+ -o data.xml \
+ wget https://data.dvc.org/get-started/data.xml -O data.xml
+
+$ dvc repro
```
-`dvc import-url` generates an _import `.dvc` file_ and `dvc run` a regular stage
-(in `dvc.yaml`).
+`dvc import-url` generates an _import `.dvc` file_ and `dvc stage add` a regular
+stage (in `dvc.yaml`).
## Options
@@ -297,10 +299,12 @@ $ pip install -r src/requirements.txt
```dvc
-$ dvc run -n prepare \
- -d src/prepare.py -d data/data.xml \
- -o data/prepared \
- python src/prepare.py data/data.xml
+$ dvc stage add -n prepare \
+ -d src/prepare.py -d data/data.xml \
+ -o data/prepared \
+ python src/prepare.py data/data.xml
+
+$ dvc repro
Running command:
python src/prepare.py data/data.xml
...
diff --git a/content/docs/command-reference/index.md b/content/docs/command-reference/index.md
index 6f097d869f..9a3274647f 100644
--- a/content/docs/command-reference/index.md
+++ b/content/docs/command-reference/index.md
@@ -15,8 +15,8 @@ does not change directories in your terminal).
- Copy data files or dataset directories for modeling into the repository, and
track them with DVC using the `dvc add` command.
- Process the data with your own source code, using `dvc.yaml` and/or the
- `dvc run` command, specifying further outputs that should also be
- tracked by DVC after the code is executed.
+ `dvc stage add` command to specify further outputs that should
+ also be tracked by DVC, and executing the code using `dvc repro`.
- Sharing a DVC repository with the codified data
[pipeline](/doc/command-reference/dag) will not include the project's
cache. Use [remote storage](/doc/command-reference/remote) and
diff --git a/content/docs/command-reference/init.md b/content/docs/command-reference/init.md
index e67d4adc26..0f6277d988 100644
--- a/content/docs/command-reference/init.md
+++ b/content/docs/command-reference/init.md
@@ -126,9 +126,9 @@ include:
automation like running a data pipeline using `cron`.
In this mode, DVC features related to versioning are not available. For example
-automatic creation and updating of `.gitignore` files on `dvc add` or `dvc run`,
-as well as `dvc diff` and `dvc metrics diff`, which require Git revisions to
-compare.
+automatic creation and updating of `.gitignore` files on `dvc add` or
+`dvc stage add`, as well as `dvc diff` and `dvc metrics diff`, which require Git
+revisions to compare.
DVC sets the `core.no_scm` config option value to `true` in the DVC
[config](/doc/command-reference/config) when initialized this way. This means
diff --git a/content/docs/command-reference/metrics/diff.md b/content/docs/command-reference/metrics/diff.md
index 33a3f95599..f4ca1af58f 100644
--- a/content/docs/command-reference/metrics/diff.md
+++ b/content/docs/command-reference/metrics/diff.md
@@ -88,12 +88,14 @@ all the current metrics (without comparisons).
## Examples
-Start by creating a metrics file and commit it (see the `-M` option of `dvc run`
-for more details):
+Start by creating a metrics file and commit it (see the `-M` option of
+`dvc stage add` for more details):
```dvc
-$ dvc run -n eval -M metrics.json \
- 'echo {"AUC": 0.9643, "TP": 527} > metrics.json'
+$ dvc stage add -n eval -M metrics.json \
+ 'echo {"AUC": 0.9643, "TP": 527} > metrics.json'
+
+$ dvc repro
$ cat metrics.json
{"AUC": 0.9643, "TP": 527}
diff --git a/content/docs/command-reference/metrics/index.md b/content/docs/command-reference/metrics/index.md
index 2e29872e41..72c7d19b2a 100644
--- a/content/docs/command-reference/metrics/index.md
+++ b/content/docs/command-reference/metrics/index.md
@@ -34,7 +34,7 @@ positives, etc.
This type of metrics files are typically generated by user data processing code,
and are tracked using the `-m` (`--metrics`) and `-M` (`--metrics-no-cache`)
-options of `dvc run`.
+options of `dvc stage add`.
In contrast to `dvc plots`, these metrics should be stored in hierarchical
files. Unlike its `dvc plots` counterpart, `dvc metrics diff` can report the
@@ -64,9 +64,9 @@ stages:
```
> `cache: false` above specifies that `summary.json` is not tracked or
-> cached by DVC (`-M` option of `dvc run`). These metrics files are
-> normally committed with Git instead. See `dvc.yaml` for more information on
-> the file format above.
+> cached by DVC (`-M` option of `dvc stage add`). These metrics
+> files are normally committed with Git instead. See `dvc.yaml` for more
+> information on the file format above.
### Supported file formats
@@ -106,13 +106,15 @@ First, let's imagine we have a simple [stage](/doc/command-reference/run) that
produces an `eval.json` metrics file:
```dvc
-$ dvc run -n evaluate -d code/evaluate.py -M eval.json \
- python code/evaluate.py
+$ dvc stage add -n evaluate -d code/evaluate.py -M eval.json \
+ python code/evaluate.py
+
+$ dvc repro
```
> `-M` (`--metrics-no-cache`) tells DVC to mark `eval.json` as a metrics file,
-> without tracking it directly (You can track it with Git). See `dvc run` for
-> more info.
+> without tracking it directly (You can track it with Git). See `dvc stage add`
+> for more info.
Now let's print metrics values that we are tracking in this
project, using `dvc metrics show`:
diff --git a/content/docs/command-reference/params/diff.md b/content/docs/command-reference/params/diff.md
index f40d0b7e3d..c6352608f7 100644
--- a/content/docs/command-reference/params/diff.md
+++ b/content/docs/command-reference/params/diff.md
@@ -26,7 +26,7 @@ repository history. The differences shown by this command include the old and
new param values, along with the param name.
> Parameter dependencies are defined in the `params` field of `dvc.yaml` (e.g.
-> with the the `-p` (`--params`) option of `dvc run`).
+> with the the `-p` (`--params`) option of `dvc stage add`).
Without arguments, `dvc params diff` compares parameters currently present in
the workspace (uncommitted changes) with the latest committed
@@ -95,10 +95,10 @@ Define a pipeline [stage](/doc/command-reference/run) with parameter
dependencies:
```dvc
-$ dvc run -n train \
- -d train.py -d users.csv -o model.pkl \
- -p lr,train \
- python train.py
+$ dvc stage add -n train \
+ -d train.py -d users.csv -o model.pkl \
+ -p lr,train \
+ python train.py
```
Let's now print parameter values that we are tracking in this
diff --git a/content/docs/command-reference/params/index.md b/content/docs/command-reference/params/index.md
index 7878cb3c48..285685c1d5 100644
--- a/content/docs/command-reference/params/index.md
+++ b/content/docs/command-reference/params/index.md
@@ -22,7 +22,7 @@ dependencies: _parameters_. They usually have simple names like `epochs`,
`learning-rate`, `batch_size`, etc.
To start tracking parameters, list them under the `params` field of `dvc.yaml`
-stages (manually or with the the `-p`/`--params` option of `dvc run`). For
+stages (manually or with the the `-p`/`--params` option of `dvc stage add`). For
example:
```yaml
@@ -97,14 +97,14 @@ process:
bow: 15000
```
-Using `dvc run`, define a [stage](/doc/command-reference/run) that depends on
-params `lr`, `layers`, and `epochs` from the params file above. Full paths
+Using `dvc stage add`, define a [stage](/doc/command-reference/run) that depends
+on params `lr`, `layers`, and `epochs` from the params file above. Full paths
should be used to specify `layers` and `epochs` from the `train` group:
```dvc
-$ dvc run -n train -d train.py -d users.csv -o model.pkl \
- -p lr,train.epochs,train.layers \
- python train.py
+$ dvc stage add -n train -d train.py -d users.csv -o model.pkl \
+ -p lr,train.epochs,train.layers \
+ python train.py
```
> Note that we could use the same parameter addressing with JSON, TOML, or
@@ -147,9 +147,9 @@ Alternatively, the entire group of parameters `train` can be referenced, instead
of specifying each of the params separately:
```dvc
-$ dvc run -n train -d train.py -d users.csv -o model.pkl \
- -p lr,train \
- python train.py
+$ dvc stage add -n train -d train.py -d users.csv -o model.pkl \
+ -p lr,train \
+ python train.py
```
```yaml
@@ -161,12 +161,12 @@ params:
In the examples above, the default parameters file name `params.yaml` was used.
Note that this file name can be redefined using a prefix in the `-p` argument of
-`dvc run`. In our case:
+`dvc stage add`. In our case:
```dvc
-$ dvc run -n train -d train.py -d logs/ -o users.csv -f \
- -p parse_params.yaml:threshold,classes_num \
- python train.py
+$ dvc stage add -n train -d train.py -d logs/ -o users.csv -f \
+ -p parse_params.yaml:threshold,classes_num \
+ python train.py
```
## Examples: Print all parameters
@@ -234,9 +234,9 @@ The following [stage](/doc/command-reference/run) depends on params `BOOL`,
`INT`, as well as `TrainConfig`'s `EPOCHS` and `layers`:
```dvc
-$ dvc run -n train -d train.py -d users.csv -o model.pkl \
- -p params.py:BOOL,INT,TrainConfig.EPOCHS,TrainConfig.layers \
- python train.py
+$ dvc stage add -n train -d train.py -d users.csv -o model.pkl \
+ -p params.py:BOOL,INT,TrainConfig.EPOCHS,TrainConfig.layers \
+ python train.py
```
Resulting `dvc.yaml` and `dvc.lock` files (notice the `params` lists):
@@ -283,7 +283,7 @@ can be referenced
supported), instead of the parameters in it:
```dvc
-$ dvc run -n train -d train.py -d users.csv -o model.pkl \
- -p params.py:BOOL,INT,TestConfig \
- python train.py
+$ dvc stage add -n train -d train.py -d users.csv -o model.pkl \
+ -p params.py:BOOL,INT,TestConfig \
+ python train.py
```
diff --git a/content/docs/command-reference/plots/modify.md b/content/docs/command-reference/plots/modify.md
index 2792ba0e92..e3579910ec 100644
--- a/content/docs/command-reference/plots/modify.md
+++ b/content/docs/command-reference/plots/modify.md
@@ -27,8 +27,8 @@ plots are generated with `dvc plot show` or `dvc plot diff`. This command sets
(or unsets) default display properties for a specific metrics file.
The path to the metrics file `target` is required. It must be listed in a
-`dvc.yaml` file (see the `--plots` option of `dvc run`). `dvc plots modify` adds
-the display properties to `dvc.yaml`.
+`dvc.yaml` file (see the `--plots` option of `dvc stage add`).
+`dvc plots modify` adds the display properties to `dvc.yaml`.
Property names are passed as [options](#options) to this command (prefixed with
`--`). These are based on the [Vega-Lite](https://vega.github.io/vega-lite/)
@@ -134,8 +134,8 @@ plots:
## Example: Template change
-_dvc run --plots file.csv ..._ command assign the default template that needs to
-be changed in many cases. A simple command changes the template:
+_dvc stage add --plots file.csv ..._ command assign the default template that
+needs to be changed in many cases. A simple command changes the template:
```dvc
$ dvc plots modify classes.csv --template confusion
diff --git a/content/docs/command-reference/repro.md b/content/docs/command-reference/repro.md
index 1a98a9774b..28bfa4c906 100644
--- a/content/docs/command-reference/repro.md
+++ b/content/docs/command-reference/repro.md
@@ -30,7 +30,8 @@ are run one after the other in the order they are defined. The failure of any
command will halt the remaining stage execution, and raises an error.
> Pipeline stages are defined in `dvc.yaml` (either manually or by using
-> `dvc run`) while initial data dependencies can be registered with `dvc add`.
+> `dvc stage add`) while initial data dependencies can be registered with
+> `dvc add`.
`dvc repro` is similar to [Make](https://www.gnu.org/software/make/) in software
build automation, but DVC captures build requirements
@@ -137,8 +138,8 @@ up-to-date and only execute the final stage.
`dvc commit` to finish the operation.
- `-m`, `--metrics` - show metrics after reproduction. The target pipelines must
- have at least one metrics file defined either with `dvc metrics` or by the
- `-M` or `-m` options of `dvc run`
+ have at least one [metrics](/doc/command-reference/metrics) file defined in
+ `dvc.yaml`.
- `--dry` - only print the commands that would be executed without actually
executing the commands.
@@ -170,10 +171,10 @@ up-to-date and only execute the final stage.
stages (`A` and below) depend on `requirements.txt`, we can specify it in `A`,
and omit it in `B` and `C`.
- Like with the `--force` option on `dvc run`, this is a way to force-execute
- stages without changes. This can also be useful for pipelines containing
- stages that produce non-deterministic (semi-random) outputs, where outputs can
- vary on each execution, meaning the cache cannot be trusted for such stages.
+ This is a way to force-execute stages without changes. This can also be useful
+ for pipelines containing stages that produce non-deterministic (semi-random)
+ outputs, where outputs can vary on each execution, meaning the cache cannot be
+ trusted for such stages.
- `--downstream` - only execute the stages after the given `targets` in their
corresponding pipelines, including the target stages themselves. This option
@@ -213,10 +214,10 @@ best
And runs a few simple transformations to filter and count numbers:
```dvc
-$ dvc run -n filter -d text.txt -o numbers.txt \
+$ dvc stage add -n filter -d text.txt -o numbers.txt \
"cat text.txt | egrep '[0-9]+' > numbers.txt"
-$ dvc run -n count -d numbers.txt -d process.py -M count.txt \
+$ dvc stage add -n count -d numbers.txt -d process.py -M count.txt \
"python process.py numbers.txt > count.txt"
```
@@ -232,9 +233,24 @@ with open(sys.argv[1], 'r') as f:
print(num_lines)
```
-The result of executing these `dvc run` commands should look like this:
+The result of executing `dvc repro` should look like this (`cat` shows the
+contents of a file and `tree` shows the contents of the working directory):
```dvc
+$ dvc repro
+Running stage 'filter':
+> cat text.txt | egrep '[0-9]+' > numbers.txt
+Generating lock file 'dvc.lock'
+Updating lock file 'dvc.lock'
+
+Running stage 'count':
+> python process.py numbers.txt > count.txt
+Updating lock file 'dvc.lock'
+Use `dvc push` to send your updates to remote storage.
+
+$ cat count.txt
+2
+
$ tree
.
├── count.txt <---- result: "2"
@@ -248,18 +264,8 @@ $ tree
You may want to check the contents of `dvc.lock` and `count.txt` for later
reference.
-Ok, now let's run `dvc repro`:
-
-```dvc
-$ dvc repro
-Stage 'filter' didn't change, skipping
-Stage 'count' didn't change, skipping
-Data and pipelines are up to date.
-```
-
-It makes sense, since we haven't changed any of the dependencies of this
-pipeline (`text.txt` and `process.py`). Now, let's imagine we want to print a
-description and we add this line to the `process.py`:
+Now, let's imagine we want to print a description and we add this line to the
+`process.py`:
```python
...
diff --git a/content/docs/command-reference/status.md b/content/docs/command-reference/status.md
index c5f1710e44..658be9fbd1 100644
--- a/content/docs/command-reference/status.md
+++ b/content/docs/command-reference/status.md
@@ -57,7 +57,7 @@ description_, as detailed below:
- _always changed_ means that this is a `.dvc` file with no dependencies (see
`dvc add`) or that the stage in `dvc.yaml` has the `always_changed: true`
- value set (see `--always-changed` option in `dvc run`).
+ value set (see `--always-changed` option in `dvc stage add`).
- _changed deps_ or _changed outs_ means that there are changes in dependencies
or outputs tracked by the stage or `.dvc` file. Depending on the use case,