Decoder expands exact objects into lists
This commit is contained in:
parent
efca695ce4
commit
8e81ec8b57
39
decoder.go
39
decoder.go
@ -66,23 +66,14 @@ func decodeInterface(name string, raw ast.Node, result reflect.Value) error {
|
|||||||
|
|
||||||
switch n := raw.(type) {
|
switch n := raw.(type) {
|
||||||
case ast.ObjectNode:
|
case ast.ObjectNode:
|
||||||
redecode = false
|
var temp map[string]interface{}
|
||||||
result := make(map[string]interface{})
|
tempVal := reflect.ValueOf(temp)
|
||||||
|
result := reflect.MakeMap(
|
||||||
|
reflect.MapOf(
|
||||||
|
reflect.TypeOf(""),
|
||||||
|
tempVal.Type().Elem()))
|
||||||
|
|
||||||
for _, elem := range n.Elem {
|
set = result
|
||||||
n := elem.(ast.AssignmentNode)
|
|
||||||
|
|
||||||
raw := new(interface{})
|
|
||||||
err := decode(
|
|
||||||
name, n.Value, reflect.Indirect(reflect.ValueOf(raw)))
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
result[n.Key()] = *raw
|
|
||||||
}
|
|
||||||
|
|
||||||
set = reflect.ValueOf(result)
|
|
||||||
case ast.ListNode:
|
case ast.ListNode:
|
||||||
redecode = false
|
redecode = false
|
||||||
result := make([]interface{}, 0, len(n.Elem))
|
result := make([]interface{}, 0, len(n.Elem))
|
||||||
@ -155,6 +146,14 @@ func decodeMap(name string, raw ast.Node, result reflect.Value) error {
|
|||||||
// Go through each element and decode it.
|
// Go through each element and decode it.
|
||||||
for _, elem := range obj.Elem {
|
for _, elem := range obj.Elem {
|
||||||
n := elem.(ast.AssignmentNode)
|
n := elem.(ast.AssignmentNode)
|
||||||
|
objValue := n.Value
|
||||||
|
|
||||||
|
// If we have an object node, expand to a list of objects
|
||||||
|
if _, ok := objValue.(ast.ObjectNode); ok {
|
||||||
|
objValue = ast.ListNode{
|
||||||
|
Elem: []ast.Node{objValue},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Make the field name
|
// Make the field name
|
||||||
fieldName := fmt.Sprintf("%s.%s", name, n.Key())
|
fieldName := fmt.Sprintf("%s.%s", name, n.Key())
|
||||||
@ -170,7 +169,7 @@ func decodeMap(name string, raw ast.Node, result reflect.Value) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Decode!
|
// Decode!
|
||||||
if err := decode(fieldName, n.Value, val); err != nil {
|
if err := decode(fieldName, objValue, val); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,8 +177,10 @@ func decodeMap(name string, raw ast.Node, result reflect.Value) error {
|
|||||||
resultMap.SetMapIndex(key, val)
|
resultMap.SetMapIndex(key, val)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the final map
|
// Set the final map if we can
|
||||||
result.Set(resultMap)
|
if result.CanAddr() {
|
||||||
|
result.Set(resultMap)
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,6 +68,10 @@ func TestDecode_equal(t *testing.T) {
|
|||||||
"structure.hcl",
|
"structure.hcl",
|
||||||
"structure.json",
|
"structure.json",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"structure.hcl",
|
||||||
|
"structure_flat.json",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range cases {
|
for _, tc := range cases {
|
||||||
@ -96,7 +100,10 @@ func TestDecode_equal(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if !reflect.DeepEqual(i1, i2) {
|
if !reflect.DeepEqual(i1, i2) {
|
||||||
t.Fatalf("%#v\n\n%#v", i1, i2)
|
t.Fatalf(
|
||||||
|
"%s != %s\n\n%#v\n\n%#v",
|
||||||
|
tc.One, tc.Two,
|
||||||
|
i1, i2)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
8
test-fixtures/structure_flat.json
Normal file
8
test-fixtures/structure_flat.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"foo": {
|
||||||
|
"baz": {
|
||||||
|
"key": 7,
|
||||||
|
"foo": "bar"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user