mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-26 08:25:38 +00:00
Adding shebang documentation
This commit is contained in:
parent
86bb90f989
commit
796b4a0955
@ -1,4 +1,4 @@
|
|||||||
#!yq
|
#! yq
|
||||||
.[] |(
|
.[] |(
|
||||||
( select(kind == "scalar") | key + "='" + . + "'"),
|
( select(kind == "scalar") | key + "='" + . + "'"),
|
||||||
( select(kind == "seq") | key + "=(" + (map("'" + . + "'") | join(",")) + ")")
|
( select(kind == "seq") | key + "=(" + (map("'" + . + "'") | join(",")) + ")")
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
You can put expressions into `.yq` files, use whitespace and comments to break up complex expressions and explain what's going on.
|
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
|
## Using expression files and comments
|
||||||
|
Note that you can execute the file directly - but make sure you make the expression file executable.
|
||||||
|
|
||||||
Given a sample.yaml file of:
|
Given a sample.yaml file of:
|
||||||
```yaml
|
```yaml
|
||||||
a:
|
a:
|
||||||
@ -12,6 +14,8 @@ a:
|
|||||||
```
|
```
|
||||||
And an 'update.yq' expression file of:
|
And an 'update.yq' expression file of:
|
||||||
```bash
|
```bash
|
||||||
|
#! yq
|
||||||
|
|
||||||
# This is a yq expression that updates the map
|
# This is a yq expression that updates the map
|
||||||
# for several great reasons outlined here.
|
# for several great reasons outlined here.
|
||||||
|
|
||||||
@ -22,7 +26,7 @@ And an 'update.yq' expression file of:
|
|||||||
```
|
```
|
||||||
then
|
then
|
||||||
```bash
|
```bash
|
||||||
yq --from-file update.yq sample.yml
|
./update.yq sample.yaml
|
||||||
```
|
```
|
||||||
will output
|
will output
|
||||||
```yaml
|
```yaml
|
||||||
@ -32,7 +36,7 @@ a:
|
|||||||
```
|
```
|
||||||
|
|
||||||
## Commenting out yq expressions
|
## Commenting out yq expressions
|
||||||
Note that `c` is no longer set to 'frog'.
|
Note that `c` is no longer set to 'frog'. In this example we're calling yq directly and passing the expression file into `--from-file`, this is no different from executing the expression file directly.
|
||||||
|
|
||||||
Given a sample.yaml file of:
|
Given a sample.yaml file of:
|
||||||
```yaml
|
```yaml
|
||||||
@ -41,6 +45,7 @@ a:
|
|||||||
```
|
```
|
||||||
And an 'update.yq' expression file of:
|
And an 'update.yq' expression file of:
|
||||||
```bash
|
```bash
|
||||||
|
#! yq
|
||||||
# This is a yq expression that updates the map
|
# This is a yq expression that updates the map
|
||||||
# for several great reasons outlined here.
|
# for several great reasons outlined here.
|
||||||
|
|
||||||
|
@ -11,15 +11,24 @@ import (
|
|||||||
var formattingExpressionScenarios = []formatScenario{
|
var formattingExpressionScenarios = []formatScenario{
|
||||||
{
|
{
|
||||||
description: "Using expression files and comments",
|
description: "Using expression files and comments",
|
||||||
|
skipDoc: true,
|
||||||
input: "a:\n b: old",
|
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",
|
expression: "#! yq\n\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",
|
expected: "a:\n b: new\n c: frog\n",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
description: "Commenting out yq expressions",
|
description: "Using expression files and comments",
|
||||||
subdescription: "Note that `c` is no longer set to 'frog'.",
|
subdescription: "Note that you can execute the file directly - but make sure you make the expression file executable.",
|
||||||
input: "a:\n b: old",
|
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",
|
expression: "#! yq\n\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",
|
||||||
|
scenarioType: "shebang",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
description: "Commenting out yq expressions",
|
||||||
|
subdescription: "Note that `c` is no longer set to 'frog'. In this example we're calling yq directly and passing the expression file into `--from-file`, this is no different from executing the expression file directly.",
|
||||||
|
input: "a:\n b: old",
|
||||||
|
expression: "#! yq\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",
|
expected: "a:\n b: new\n",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
@ -41,10 +50,14 @@ func documentExpressionScenario(_ *testing.T, w *bufio.Writer, i interface{}) {
|
|||||||
writeOrPanic(w, fmt.Sprintf("```yaml\n%v\n```\n", s.input))
|
writeOrPanic(w, fmt.Sprintf("```yaml\n%v\n```\n", s.input))
|
||||||
|
|
||||||
writeOrPanic(w, "And an 'update.yq' expression file of:\n")
|
writeOrPanic(w, "And an 'update.yq' expression file of:\n")
|
||||||
writeOrPanic(w, fmt.Sprintf("```bash%v```\n", s.expression))
|
writeOrPanic(w, fmt.Sprintf("```bash\n%v```\n", s.expression))
|
||||||
|
|
||||||
writeOrPanic(w, "then\n")
|
writeOrPanic(w, "then\n")
|
||||||
writeOrPanic(w, "```bash\nyq --from-file update.yq sample.yml\n```\n")
|
if s.scenarioType == "shebang" {
|
||||||
|
writeOrPanic(w, "```bash\n./update.yq sample.yaml\n```\n")
|
||||||
|
} else {
|
||||||
|
writeOrPanic(w, "```bash\nyq --from-file update.yq sample.yml\n```\n")
|
||||||
|
}
|
||||||
writeOrPanic(w, "will output\n")
|
writeOrPanic(w, "will output\n")
|
||||||
|
|
||||||
writeOrPanic(w, fmt.Sprintf("```yaml\n%v```\n\n", mustProcessFormatScenario(s, NewYamlDecoder(ConfiguredYamlPreferences), NewYamlEncoder(2, false, ConfiguredYamlPreferences))))
|
writeOrPanic(w, fmt.Sprintf("```yaml\n%v```\n\n", mustProcessFormatScenario(s, NewYamlDecoder(ConfiguredYamlPreferences), NewYamlEncoder(2, false, ConfiguredYamlPreferences))))
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
4.42.1 (not released):
|
||||||
|
- Can execute yq expression files directly with shebang (#1851)
|
||||||
|
|
||||||
4.41.1:
|
4.41.1:
|
||||||
- Can now comment in yq expressions! #1919
|
- Can now comment in yq expressions! #1919
|
||||||
- Fixed Toml decoding when table array defined before parent #1922
|
- Fixed Toml decoding when table array defined before parent #1922
|
||||||
|
Loading…
Reference in New Issue
Block a user