You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
cfa6b4f7c8
Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com> |
2 years ago | |
---|---|---|
.. | ||
internal/golang/encoding/json | 2 years ago | |
CONTRIBUTING.md | 2 years ago | |
LICENSE | 2 years ago | |
Makefile | 2 years ago | |
OWNERS | 2 years ago | |
README.md | 2 years ago | |
SECURITY.md | 2 years ago | |
SECURITY_CONTACTS | 2 years ago | |
code-of-conduct.md | 2 years ago | |
doc.go | 2 years ago | |
json.go | 2 years ago |
README.md
sigs.k8s.io/json
Introduction
This library is a subproject of sig-api-machinery.
It provides case-sensitive, integer-preserving JSON unmarshaling functions based on encoding/json
Unmarshal()
.
Compatibility
The UnmarshalCaseSensitivePreserveInts()
function behaves like encoding/json#Unmarshal()
with the following differences:
- JSON object keys are treated case-sensitively. Object keys must exactly match json tag names (for tagged struct fields) or struct field names (for untagged struct fields).
- JSON integers are unmarshaled into
interface{}
fields as anint64
instead of afloat64
when possible, falling back tofloat64
on any parse or overflow error. - Syntax errors do not return an
encoding/json
*SyntaxError
error. Instead, they return an error which can be passed toSyntaxErrorOffset()
to obtain an offset.
Additional capabilities
The UnmarshalStrict()
function decodes identically to UnmarshalCaseSensitivePreserveInts()
,
and also returns non-fatal strict errors encountered while decoding:
- Duplicate fields encountered
- Unknown fields encountered
Community, discussion, contribution, and support
You can reach the maintainers of this project via the sig-api-machinery mailing list / channels.
Code of conduct
Participation in the Kubernetes community is governed by the Kubernetes Code of Conduct.