Write array splat

This commit is contained in:
Mike Farah 2019-05-01 08:49:50 +10:00
parent cda9a82906
commit 53289366a5
2 changed files with 29 additions and 4 deletions

View File

@ -786,6 +786,26 @@ b:
assertResult(t, expectedOutput, result.Output) assertResult(t, expectedOutput, result.Output)
} }
func TestWriteCmd_SplatArray(t *testing.T) {
content := `b:
- c: thing
- c: another thing
`
filename := writeTempYamlFile(content)
defer removeTempYamlFile(filename)
cmd := getRootCommand()
result := runCmd(cmd, fmt.Sprintf("write -v %s b[*].c new", filename))
if result.Error != nil {
t.Error(result.Error)
}
expectedOutput := `b:
- c: new
- c: new
`
assertResult(t, expectedOutput, result.Output)
}
func TestDeleteYaml(t *testing.T) { func TestDeleteYaml(t *testing.T) {
content := `a: 2 content := `a: 2
b: b:

View File

@ -73,14 +73,14 @@ func updatedChildValue(child interface{}, remainingPaths []string, value interfa
log.Debugf("updatedChildValue for child %v with path %v to set value %v", child, remainingPaths, value) log.Debugf("updatedChildValue for child %v with path %v to set value %v", child, remainingPaths, value)
log.Debugf("type of child is %v", reflect.TypeOf(child)) log.Debugf("type of child is %v", reflect.TypeOf(child))
_, nextIndexErr := strconv.ParseInt(remainingPaths[0], 10, 64) _, nextIndexErr := strconv.ParseInt(remainingPaths[0], 10, 64)
arrayCommand := nextIndexErr == nil || remainingPaths[0] == "+" || remainingPaths[0] == "*"
switch child := child.(type) { switch child := child.(type) {
case nil: case nil:
if nextIndexErr == nil || remainingPaths[0] == "+" { // || remainingPaths[0] == "*" if arrayCommand {
return writeArray(child, remainingPaths, value) return writeArray(child, remainingPaths, value)
} }
case []interface{}: case []interface{}:
if nextIndexErr == nil || remainingPaths[0] == "+" { // || remainingPaths[0] == "*" if arrayCommand {
return writeArray(child, remainingPaths, value) return writeArray(child, remainingPaths, value)
} }
} }
@ -98,10 +98,16 @@ func writeArray(context interface{}, paths []string, value interface{}) []interf
log.Debugf("\tarray %v\n", array) log.Debugf("\tarray %v\n", array)
rawIndex := paths[0] rawIndex := paths[0]
remainingPaths := paths[1:]
var index int64 var index int64
// the append array indicator // the append array indicator
if rawIndex == "+" { if rawIndex == "+" {
index = int64(len(array)) index = int64(len(array))
} else if rawIndex == "*" {
for index, oldChild := range array {
array[index] = updatedChildValue(oldChild, remainingPaths, value)
}
return array
} else { } else {
index, _ = strconv.ParseInt(rawIndex, 10, 64) // nolint index, _ = strconv.ParseInt(rawIndex, 10, 64) // nolint
// writeArray is only called by updatedChildValue which handles parsing the // writeArray is only called by updatedChildValue which handles parsing the
@ -115,7 +121,6 @@ func writeArray(context interface{}, paths []string, value interface{}) []interf
log.Debugf("\tcurrentChild %v\n", currentChild) log.Debugf("\tcurrentChild %v\n", currentChild)
remainingPaths := paths[1:]
array[index] = updatedChildValue(currentChild, remainingPaths, value) array[index] = updatedChildValue(currentChild, remainingPaths, value)
log.Debugf("\tReturning array %v\n", array) log.Debugf("\tReturning array %v\n", array)
return array return array