yq/pkg/yqlib/doc/operators/alternative-default-value.md

108 lines
1.3 KiB
Markdown
Raw Normal View History

2021-11-03 02:54:09 +00:00
# Alternative (Default value)
2020-12-21 00:32:34 +00:00
This operator is used to provide alternative (or default) values when a particular expression is either null or false.
## LHS is defined
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: bridge}
2020-12-21 00:32:34 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a // "hello"' sample.yml
2020-12-21 00:32:34 +00:00
```
will output
```yaml
bridge
```
## LHS is not defined
Given a sample.yml file of:
```yaml
{}
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a // "hello"' sample.yml
2020-12-21 00:32:34 +00:00
```
will output
```yaml
hello
```
## LHS is null
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: ~}
2020-12-21 00:32:34 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a // "hello"' sample.yml
2020-12-21 00:32:34 +00:00
```
will output
```yaml
hello
```
## LHS is false
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: false}
2020-12-21 00:32:34 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a // "hello"' sample.yml
2020-12-21 00:32:34 +00:00
```
will output
```yaml
hello
```
## RHS is an expression
Given a sample.yml file of:
```yaml
2023-05-02 04:07:59 +00:00
{a: false, b: cat}
2020-12-21 00:32:34 +00:00
```
then
```bash
2022-01-27 06:21:10 +00:00
yq '.a // .b' sample.yml
2020-12-21 00:32:34 +00:00
```
will output
```yaml
cat
```
## Update or create - entity exists
This initialises `a` if it's not present
Given a sample.yml file of:
```yaml
a: 1
```
then
```bash
yq '(.a // (.a = 0)) += 1' sample.yml
```
will output
```yaml
a: 2
```
## Update or create - entity does not exist
This initialises `a` if it's not present
Given a sample.yml file of:
```yaml
b: camel
```
then
```bash
yq '(.a // (.a = 0)) += 1' sample.yml
```
will output
```yaml
b: camel
a: 1
```