mirror of
https://github.com/mikefarah/yq.git
synced 2024-12-19 20:19:04 +00:00
Added ability to update yaml files inplace
This commit is contained in:
parent
da4b1a6449
commit
6823d43325
27
yaml.go
27
yaml.go
@ -19,15 +19,21 @@ func main() {
|
|||||||
{
|
{
|
||||||
Name: "read",
|
Name: "read",
|
||||||
Aliases: []string{"r"},
|
Aliases: []string{"r"},
|
||||||
Usage: "read <filename> <path>\n\te.g.: yaml read sample.json a.b.c\n\t(default) reads a property from a given yaml file\n",
|
Usage: "read <filename> <path>\n\te.g.: yaml read sample.yaml a.b.c\n\t(default) reads a property from a given yaml file\n",
|
||||||
Action: readProperty,
|
Action: readProperty,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Name: "write",
|
Name: "write",
|
||||||
Aliases: []string{"w"},
|
Aliases: []string{"w"},
|
||||||
Usage: "write <filename> <path> <value>\n\te.g.: yaml write sample.json a.b.c 5\n\tupdates a property from a given yaml file, outputs to stdout\n",
|
Usage: "write <filename> <path> <value>\n\te.g.: yaml write sample.yaml a.b.c 5\n\tupdates a property from a given yaml file, outputs to stdout\n",
|
||||||
Action: writeProperty,
|
Action: writeProperty,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Name: "write-inplace",
|
||||||
|
Aliases: []string{"wi"},
|
||||||
|
Usage: "wi <filename> <path> <value>\n\te.g.: yaml wi sample.yaml a.b.c 5\n\tupdates a property from a given yaml file and saves it to the given filename (sample.yaml)\n",
|
||||||
|
Action: writePropertyInPlace,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
app.Action = readProperty
|
app.Action = readProperty
|
||||||
app.Run(os.Args)
|
app.Run(os.Args)
|
||||||
@ -50,6 +56,15 @@ func readProperty(c *cli.Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func writeProperty(c *cli.Context) {
|
func writeProperty(c *cli.Context) {
|
||||||
|
printYaml(updateProperty(c))
|
||||||
|
}
|
||||||
|
|
||||||
|
func writePropertyInPlace(c *cli.Context) {
|
||||||
|
updatedYaml := updateProperty(c)
|
||||||
|
ioutil.WriteFile(c.Args()[0], []byte(updatedYaml), 0644)
|
||||||
|
}
|
||||||
|
|
||||||
|
func updateProperty(c *cli.Context) string {
|
||||||
var parsedData map[interface{}]interface{}
|
var parsedData map[interface{}]interface{}
|
||||||
readYaml(c, &parsedData)
|
readYaml(c, &parsedData)
|
||||||
|
|
||||||
@ -61,7 +76,7 @@ func writeProperty(c *cli.Context) {
|
|||||||
|
|
||||||
write(parsedData, paths[0], paths[1:len(paths)], getValue(c.Args()[2]))
|
write(parsedData, paths[0], paths[1:len(paths)], getValue(c.Args()[2]))
|
||||||
|
|
||||||
printYaml(parsedData)
|
return yamlToString(parsedData)
|
||||||
}
|
}
|
||||||
|
|
||||||
func getValue(argument string) interface{} {
|
func getValue(argument string) interface{} {
|
||||||
@ -82,6 +97,10 @@ func getValue(argument string) interface{} {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func printYaml(context interface{}) {
|
func printYaml(context interface{}) {
|
||||||
|
fmt.Println(yamlToString(context))
|
||||||
|
}
|
||||||
|
|
||||||
|
func yamlToString(context interface{}) string {
|
||||||
out, err := yaml.Marshal(context)
|
out, err := yaml.Marshal(context)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("error printing yaml: %v", err)
|
log.Fatalf("error printing yaml: %v", err)
|
||||||
@ -89,7 +108,7 @@ func printYaml(context interface{}) {
|
|||||||
outStr := string(out)
|
outStr := string(out)
|
||||||
// trim the trailing new line as it's easier for a script to add
|
// trim the trailing new line as it's easier for a script to add
|
||||||
// it in if required than to remove it
|
// it in if required than to remove it
|
||||||
fmt.Println(strings.Trim(outStr, "\n "))
|
return strings.Trim(outStr, "\n ")
|
||||||
}
|
}
|
||||||
|
|
||||||
func readYaml(c *cli.Context, parsedData *map[interface{}]interface{}) {
|
func readYaml(c *cli.Context, parsedData *map[interface{}]interface{}) {
|
||||||
|
Loading…
Reference in New Issue
Block a user