Skip to content

Commit

Permalink
Merge pull request #353 from orisano/fix/#342
Browse files Browse the repository at this point in the history
fix: an incompatible behavior on map key decoder
  • Loading branch information
goccy committed Mar 24, 2022
2 parents 05585c6 + 4235ca0 commit 7cb5120
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 0 deletions.
18 changes: 18 additions & 0 deletions decode_test.go
Expand Up @@ -3889,3 +3889,21 @@ func TestIssue348(t *testing.T) {
}
}
}

type issue342 string

func (t *issue342) UnmarshalJSON(b []byte) error {
panic("unreachable")
}

func TestIssue342(t *testing.T) {
var v map[issue342]int
in := []byte(`{"a":1}`)
if err := json.Unmarshal(in, &v); err != nil {
t.Errorf("unexpected error: %v", err)
}
expected := 1
if got := v["a"]; got != expected {
t.Errorf("unexpected result: got(%v) != expected(%v)", got, expected)
}
}
3 changes: 3 additions & 0 deletions internal/decoder/compile.go
Expand Up @@ -154,6 +154,9 @@ func compileMapKey(typ *runtime.Type, structName, fieldName string, structTypeTo
if runtime.PtrTo(typ).Implements(unmarshalTextType) {
return newUnmarshalTextDecoder(runtime.PtrTo(typ), structName, fieldName), nil
}
if typ.Kind() == reflect.String {
return newStringDecoder(structName, fieldName), nil
}
dec, err := compile(typ, structName, fieldName, structTypeToDecoder)
if err != nil {
return nil, err
Expand Down

0 comments on commit 7cb5120

Please sign in to comment.