mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-23 14:16:10 +00:00
wip
This commit is contained in:
parent
c08980e70f
commit
bc87aca8d7
157
pkg/yqlib/doc/Boolean Operators.md
Normal file
157
pkg/yqlib/doc/Boolean Operators.md
Normal file
@ -0,0 +1,157 @@
|
|||||||
|
The `or` and `and` operators take two parameters and return a boolean result. These are most commonly used with the `select` operator to filter particular nodes.
|
||||||
|
## Examples
|
||||||
|
### Update node to be the child value
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b:
|
||||||
|
g: foof
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a |= .b' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
g: foof
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update node to be the sibling value
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: child
|
||||||
|
b: sibling
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a = .b' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a: sibling
|
||||||
|
b: sibling
|
||||||
|
```
|
||||||
|
|
||||||
|
### Updated multiple paths
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
a: fieldA
|
||||||
|
b: fieldB
|
||||||
|
c: fieldC
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '(.a, .c) |= "potatoe"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a: potatoe
|
||||||
|
b: fieldB
|
||||||
|
c: potatoe
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update string value
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: apple
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a.b = "frog"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: frog
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update string value via |=
|
||||||
|
Note there is no difference between `=` and `|=` when the RHS is a scalar
|
||||||
|
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: apple
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a.b |= "frog"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: frog
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update selected results
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: apple
|
||||||
|
c: cactus
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a[] | select(. == "apple") |= "frog"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: frog
|
||||||
|
c: cactus
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update array values
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
- candy
|
||||||
|
- apple
|
||||||
|
- sandy
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.[] | select(. == "*andy") |= "bogs"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
- bogs
|
||||||
|
- apple
|
||||||
|
- bogs
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update empty object
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
'': null
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a.b |= "bogs"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
'': null
|
||||||
|
a:
|
||||||
|
b: bogs
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update empty object and array
|
||||||
|
Given a sample.yml file of:
|
||||||
|
```yaml
|
||||||
|
'': null
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq eval '.a.b[0] |= "bogs"' sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
'': null
|
||||||
|
a:
|
||||||
|
b:
|
||||||
|
- bogs
|
||||||
|
```
|
||||||
|
|
1
pkg/yqlib/doc/headers/Boolean Operators.md
Normal file
1
pkg/yqlib/doc/headers/Boolean Operators.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
The `or` and `and` operators take two parameters and return a boolean result. These are most commonly used with the `select` operator to filter particular nodes.
|
@ -6,18 +6,37 @@ import (
|
|||||||
|
|
||||||
var booleanOperatorScenarios = []expressionScenario{
|
var booleanOperatorScenarios = []expressionScenario{
|
||||||
{
|
{
|
||||||
document: `{}`,
|
description: "OR example",
|
||||||
expression: `true or false`,
|
expression: `true or false`,
|
||||||
expected: []string{
|
expected: []string{
|
||||||
"D0, P[], (!!bool)::true\n",
|
"D0, P[], (!!bool)::true\n",
|
||||||
},
|
},
|
||||||
}, {
|
},
|
||||||
document: `{}`,
|
{
|
||||||
|
description: "AND example",
|
||||||
|
expression: `true and false`,
|
||||||
|
expected: []string{
|
||||||
|
"D0, P[], (!!bool)::false\n",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
document: "[{a: bird, b: dog}, {a: frog, b: bird}, {a: cat, b: fly}]",
|
||||||
|
description: "Matching nodes with select, equals and or",
|
||||||
|
expression: `.[] | select(.a == "cat" or .b == "dog")`,
|
||||||
|
expected: []string{
|
||||||
|
"D0, P[], (!!map)::{a: bird, b: dog}\n",
|
||||||
|
"D0, P[], (!!map)::{a: cat, b: fly}\n",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
skipDoc: true,
|
||||||
expression: `false or false`,
|
expression: `false or false`,
|
||||||
expected: []string{
|
expected: []string{
|
||||||
"D0, P[], (!!bool)::false\n",
|
"D0, P[], (!!bool)::false\n",
|
||||||
},
|
},
|
||||||
}, {
|
},
|
||||||
|
{
|
||||||
|
skipDoc: true,
|
||||||
document: `{a: true, b: false}`,
|
document: `{a: true, b: false}`,
|
||||||
expression: `.[] or (false, true)`,
|
expression: `.[] or (false, true)`,
|
||||||
expected: []string{
|
expected: []string{
|
||||||
@ -33,4 +52,5 @@ func TestBooleanOperatorScenarios(t *testing.T) {
|
|||||||
for _, tt := range booleanOperatorScenarios {
|
for _, tt := range booleanOperatorScenarios {
|
||||||
testScenario(t, &tt)
|
testScenario(t, &tt)
|
||||||
}
|
}
|
||||||
|
documentScenarios(t, "Boolean Operators", assignOperatorScenarios)
|
||||||
}
|
}
|
||||||
|
@ -196,6 +196,7 @@ func initLexer() (*lex.Lexer, error) {
|
|||||||
lexer.Add([]byte(`select`), opToken(Select))
|
lexer.Add([]byte(`select`), opToken(Select))
|
||||||
lexer.Add([]byte(`explode`), opToken(Explode))
|
lexer.Add([]byte(`explode`), opToken(Explode))
|
||||||
lexer.Add([]byte(`or`), opToken(Or))
|
lexer.Add([]byte(`or`), opToken(Or))
|
||||||
|
lexer.Add([]byte(`and`), opToken(And))
|
||||||
lexer.Add([]byte(`not`), opToken(Not))
|
lexer.Add([]byte(`not`), opToken(Not))
|
||||||
|
|
||||||
lexer.Add([]byte(`documentIndex`), opToken(GetDocumentIndex))
|
lexer.Add([]byte(`documentIndex`), opToken(GetDocumentIndex))
|
||||||
|
Loading…
Reference in New Issue
Block a user