mirror of
https://github.com/mikefarah/yq.git
synced 2024-11-13 22:38:04 +00:00
Comments in yq expressions! #1919
This commit is contained in:
parent
24bd563680
commit
2dda0a203d
33
pkg/yqlib/doc/usage/formatting-expressions.md
Normal file
33
pkg/yqlib/doc/usage/formatting-expressions.md
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
# Formatting Expressions
|
||||||
|
|
||||||
|
`From version v4.41+`
|
||||||
|
|
||||||
|
You can put expressions into `.yq` files, use whitespace and comments to break up complex expressions and explain what's going on.
|
||||||
|
|
||||||
|
## Using expression files and comments
|
||||||
|
Given a sample.yaml file of:
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: old
|
||||||
|
```
|
||||||
|
And an 'update.yq' expression file of:
|
||||||
|
```bash
|
||||||
|
# This is a yq expression that updates the map
|
||||||
|
# for several great reasons outlined here.
|
||||||
|
|
||||||
|
.a.b = "new" # line comment here
|
||||||
|
| .a.c = "frog"
|
||||||
|
|
||||||
|
# Now good things will happen.
|
||||||
|
```
|
||||||
|
then
|
||||||
|
```bash
|
||||||
|
yq --from-file update.yq sample.yml
|
||||||
|
```
|
||||||
|
will output
|
||||||
|
```yaml
|
||||||
|
a:
|
||||||
|
b: new
|
||||||
|
c: frog
|
||||||
|
```
|
||||||
|
|
5
pkg/yqlib/doc/usage/headers/formatting-expressions.md
Normal file
5
pkg/yqlib/doc/usage/headers/formatting-expressions.md
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Formatting Expressions
|
||||||
|
|
||||||
|
`From version v4.41+`
|
||||||
|
|
||||||
|
You can put expressions into `.yq` files, use whitespace and comments to break up complex expressions and explain what's going on.
|
@ -370,7 +370,7 @@ cat: purrs
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq -o=xml '.' sample.yml
|
yq -o=xml sample.yml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```xml
|
```xml
|
||||||
@ -387,7 +387,7 @@ pets:
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq -o=xml '.' sample.yml
|
yq -o=xml sample.yml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```xml
|
```xml
|
||||||
@ -409,7 +409,7 @@ cat:
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq -o=xml '.' sample.yml
|
yq -o=xml sample.yml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```xml
|
```xml
|
||||||
@ -430,7 +430,7 @@ cat:
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq -o=xml '.' sample.yml
|
yq -o=xml sample.yml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```xml
|
```xml
|
||||||
@ -457,7 +457,7 @@ cat: # inline_cat
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq -o=xml '.' sample.yml
|
yq -o=xml sample.yml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```xml
|
```xml
|
||||||
@ -487,7 +487,7 @@ apple:
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq -o=xml '.' sample.yml
|
yq -o=xml sample.yml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```xml
|
```xml
|
||||||
|
57
pkg/yqlib/formatting_expressions_test.go
Normal file
57
pkg/yqlib/formatting_expressions_test.go
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
package yqlib
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/mikefarah/yq/v4/test"
|
||||||
|
)
|
||||||
|
|
||||||
|
var formattingExpressionScenarios = []formatScenario{
|
||||||
|
{
|
||||||
|
description: "Using expression files and comments",
|
||||||
|
input: "a:\n b: old",
|
||||||
|
expression: "\n# This is a yq expression that updates the map\n# for several great reasons outlined here.\n\n.a.b = \"new\" # line comment here\n| .a.c = \"frog\"\n\n# Now good things will happen.\n",
|
||||||
|
expected: "a:\n b: new\n c: frog\n",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func documentExpressionScenario(_ *testing.T, w *bufio.Writer, i interface{}) {
|
||||||
|
s := i.(formatScenario)
|
||||||
|
|
||||||
|
if s.skipDoc {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
writeOrPanic(w, fmt.Sprintf("## %v\n", s.description))
|
||||||
|
|
||||||
|
if s.subdescription != "" {
|
||||||
|
writeOrPanic(w, s.subdescription)
|
||||||
|
writeOrPanic(w, "\n\n")
|
||||||
|
}
|
||||||
|
|
||||||
|
writeOrPanic(w, "Given a sample.yaml file of:\n")
|
||||||
|
writeOrPanic(w, fmt.Sprintf("```yaml\n%v\n```\n", s.input))
|
||||||
|
|
||||||
|
writeOrPanic(w, "And an 'update.yq' expression file of:\n")
|
||||||
|
writeOrPanic(w, fmt.Sprintf("```bash%v```\n", s.expression))
|
||||||
|
|
||||||
|
writeOrPanic(w, "then\n")
|
||||||
|
writeOrPanic(w, "```bash\nyq --from-file update.yq sample.yml\n```\n")
|
||||||
|
writeOrPanic(w, "will output\n")
|
||||||
|
|
||||||
|
writeOrPanic(w, fmt.Sprintf("```yaml\n%v```\n\n", mustProcessFormatScenario(s, NewYamlDecoder(ConfiguredYamlPreferences), NewYamlEncoder(2, false, ConfiguredYamlPreferences))))
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestExpressionCommentScenarios(t *testing.T) {
|
||||||
|
for _, tt := range formattingExpressionScenarios {
|
||||||
|
test.AssertResultComplexWithContext(t, tt.expected,
|
||||||
|
mustProcessFormatScenario(tt, NewYamlDecoder(ConfiguredYamlPreferences), NewYamlEncoder(2, false, ConfiguredYamlPreferences)),
|
||||||
|
tt.description)
|
||||||
|
}
|
||||||
|
genericScenarios := make([]interface{}, len(formattingExpressionScenarios))
|
||||||
|
for i, s := range formattingExpressionScenarios {
|
||||||
|
genericScenarios[i] = s
|
||||||
|
}
|
||||||
|
documentScenarios(t, "usage", "formatting-expressions", genericScenarios, documentExpressionScenario)
|
||||||
|
}
|
@ -221,6 +221,7 @@ var participleYqRules = []*participleYqRule{
|
|||||||
|
|
||||||
{"SubtractAssign", `\-=`, opToken(subtractAssignOpType), 0},
|
{"SubtractAssign", `\-=`, opToken(subtractAssignOpType), 0},
|
||||||
{"Subtract", `\-`, opToken(subtractOpType), 0},
|
{"Subtract", `\-`, opToken(subtractOpType), 0},
|
||||||
|
{"Comment", `#.*`, nil, 0},
|
||||||
}
|
}
|
||||||
|
|
||||||
type yqAction func(lexer.Token) (*token, error)
|
type yqAction func(lexer.Token) (*token, error)
|
||||||
|
@ -768,7 +768,7 @@ func documentXMLEncodeScenario(w *bufio.Writer, s formatScenario) {
|
|||||||
writeOrPanic(w, fmt.Sprintf("```yaml\n%v\n```\n", s.input))
|
writeOrPanic(w, fmt.Sprintf("```yaml\n%v\n```\n", s.input))
|
||||||
|
|
||||||
writeOrPanic(w, "then\n")
|
writeOrPanic(w, "then\n")
|
||||||
writeOrPanic(w, "```bash\nyq -o=xml '.' sample.yml\n```\n")
|
writeOrPanic(w, "```bash\nyq -o=xml sample.yml\n```\n")
|
||||||
writeOrPanic(w, "will output\n")
|
writeOrPanic(w, "will output\n")
|
||||||
|
|
||||||
writeOrPanic(w, fmt.Sprintf("```xml\n%v```\n\n", mustProcessFormatScenario(s, NewYamlDecoder(ConfiguredYamlPreferences), NewXMLEncoder(2, ConfiguredXMLPreferences))))
|
writeOrPanic(w, fmt.Sprintf("```xml\n%v```\n\n", mustProcessFormatScenario(s, NewYamlDecoder(ConfiguredYamlPreferences), NewXMLEncoder(2, ConfiguredXMLPreferences))))
|
||||||
|
Loading…
Reference in New Issue
Block a user