-
Notifications
You must be signed in to change notification settings - Fork 18k
encoding/json, encoding/xml: add full support for marshalers with pointer receivers #68920
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
encoding/json, encoding/xml: add full support for marshalers with pointer receivers #68920
Conversation
…ter receivers even for non-addressable values of non-pointer types on marshalling JSON
…defined with pointer receivers even for non-addressable values of non-pointer types on marshalling XML
Thanks for your pull request! It looks like this may be your first contribution to a Google open source project. Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). View this failed invocation of the CLA check for more information. For the most up to date status, view the checks section at the bottom of the pull request. |
This PR (HEAD: 928e3d9) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/606495. Important tips:
|
Message from Gopher Robot: Patch Set 1: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Gopher Robot: Patch Set 1: Congratulations on opening your first change. Thank you for your contribution! Next steps: Most changes in the Go project go through a few rounds of revision. This can be During May-July and Nov-Jan the Go project is in a code freeze, during which Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Dmitry Zenovich: Patch Set 2: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Dmitry Zenovich: Patch Set 2: Code-Review+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
…data/chardata fields even when they are non-addressable of non-pointer types on marshalling XML; call MarshalXML(), MarshalXMLAttr(), and MarshalText() even if the struct field has an interface type; introduce the GODEBUG setting "xmlinconsistentmarshal" allowing to revert the new consistent XML marshalling
…ith_pointer_receivers
This PR (HEAD: 8241a96) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/606495. Important tips:
|
…" allowing to revert the new consistent JSON marshalling, rework marshaling-related tests
This PR (HEAD: 7dd9c40) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/606495. Important tips:
|
This PR (HEAD: 049782d) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/606495. Important tips:
|
Message from Dmitry Zenovich: Patch Set 11: Code-Review+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Ian Lance Taylor: Patch Set 12: Commit-Queue+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Go LUCI: Patch Set 12: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2024-08-21T17:12:20Z","revision":"20f11786ecf62e1ded81ae8af001de8e6d951a69"} Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Ian Lance Taylor: Patch Set 12: -Commit-Queue Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Go LUCI: Patch Set 12: This CL has passed the run Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Go LUCI: Patch Set 12: LUCI-TryBot-Result+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Joseph Tsai: Patch Set 12: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Dmitry Zenovich: Patch Set 12: Code-Review+1 (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Ian Lance Taylor: Patch Set 12: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Dmitry Zenovich: Patch Set 12: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Joseph Tsai: Patch Set 12: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Dmitry Zenovich: Patch Set 12: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
Message from Dmitry Zenovich: Patch Set 12: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/606495. |
encoding/json: call MarshalJSON() and MarshalText() defined
with pointer receivers even for non-addressable values of
non-pointer types on marshalling JSON;
introduce the GODEBUG setting "jsoninconsistentmarshal"
allowing to revert the new consistent XML marshalling.
encoding/xml: call MarshalXML(), MarshalXMLAttr(),
and MarshalText() defined with pointer receivers even for
non-addressable values of non-pointer types on marshalling XML;
call MarshalXML(), MarshalXMLAttr(), and MarshalText()
even if the struct field has an interface type;
introduce the GODEBUG setting "xmlinconsistentmarshal"
allowing to revert the new consistent XML marshalling.
Fixes #22967
Fixes #55890
Fixes #48624
Fixes #6468
Partially fixes #6094