Skip to content

Commit

Permalink
Preserve defaults for zero initialised structs as well (#442)
Browse files Browse the repository at this point in the history
  • Loading branch information
yhabteab authored Jul 30, 2024
1 parent 237df0e commit 3a90d71
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 4 deletions.
12 changes: 8 additions & 4 deletions decode.go
Original file line number Diff line number Diff line change
Expand Up @@ -989,18 +989,22 @@ func (d *Decoder) createDecodedNewValue(
return newValue, nil
}
}
var newValue reflect.Value
if node.Type() == ast.NullType {
return reflect.Zero(typ), nil
newValue = reflect.New(typ).Elem()
} else {
newValue = d.createDecodableValue(typ)
}
newValue := d.createDecodableValue(typ)
for defaultVal.Kind() == reflect.Ptr {
defaultVal = defaultVal.Elem()
}
if defaultVal.IsValid() && defaultVal.Type().AssignableTo(newValue.Type()) {
newValue.Set(defaultVal)
}
if err := d.decodeValue(ctx, newValue, node); err != nil {
return newValue, errors.Wrapf(err, "failed to decode value")
if node.Type() != ast.NullType {
if err := d.decodeValue(ctx, newValue, node); err != nil {
return newValue, errors.Wrapf(err, "failed to decode value")
}
}
return newValue, nil
}
Expand Down
25 changes: 25 additions & 0 deletions decode_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3027,3 +3027,28 @@ func TestMapKeyCustomUnmarshaler(t *testing.T) {
t.Fatalf("expected to have value \"value\", but got %q", val)
}
}

func TestDecoderPreservesDefaultValues(t *testing.T) {
type nested struct {
Val string `yaml:"val"`
}

type test struct {
First string `yaml:"first"`
Default nested `yaml:"nested"`
}

yml := `
first: "Test"
nested:
# Just some comment here
# val: "default"
`
v := test{Default: nested{Val: "default"}}
if err := yaml.Unmarshal([]byte(yml), &v); err != nil {
t.Fatal(err)
}
if v.Default.Val != "default" {
t.Fatal("decoder doesn't preserve struct defaults")
}
}

0 comments on commit 3a90d71

Please sign in to comment.