diff --git a/internal/encoder/compiler.go b/internal/encoder/compiler.go index 3ae39ba8..37b7aa38 100644 --- a/internal/encoder/compiler.go +++ b/internal/encoder/compiler.go @@ -480,7 +480,7 @@ func (c *Compiler) mapCode(typ *runtime.Type) (*MapCode, error) { func (c *Compiler) listElemCode(typ *runtime.Type) (Code, error) { switch { - case c.isPtrMarshalJSONType(typ): + case c.implementsMarshalJSONType(typ) || c.implementsMarshalJSONType(runtime.PtrTo(typ)): return c.marshalJSONCode(typ) case !typ.Implements(marshalTextType) && runtime.PtrTo(typ).Implements(marshalTextType): return c.marshalTextCode(typ) diff --git a/test/cover/cover_slice_test.go b/test/cover/cover_slice_test.go index 61de9a5d..557bab75 100644 --- a/test/cover/cover_slice_test.go +++ b/test/cover/cover_slice_test.go @@ -16,6 +16,12 @@ func (coverSliceMarshalJSON) MarshalJSON() ([]byte, error) { return []byte(`"hello"`), nil } +type coverSliceMarshalJSONMap map[string]any + +func (c coverSliceMarshalJSONMap) MarshalJSON() ([]byte, error) { + return json.Marshal(map[string]any(c)) +} + type coverSliceMarshalText struct { A int } @@ -152,6 +158,10 @@ func TestCoverSlice(t *testing.T) { name: "SliceMarshalJSON", data: []coverSliceMarshalJSON{{A: 1}, {A: 2}}, }, + { + name: "SliceMarshalJSONMap", + data: []coverSliceMarshalJSONMap{{"foo": "bar"}, {"some": 1}}, + }, { name: "SliceMarshalText", data: []coverSliceMarshalText{{A: 1}, {A: 2}},