Releases: fxamacker/cbor
v2.6.0
This release adds important new features, optimizations, bug fixes, and 3 new contributors. Fuzz tests passed 5+ billion execs for CBOR encoding and decoding functions. Minimum officially supported Go is bumped to Go 1.17.
⭐ Features and Optimizations
- Add FieldNameMatching decode option. by @benluddy in #433
- Add option to decode CBOR bignum to
interface{}
as*big.Int
by @fxamacker in #456 - Add 2 more options for decoding CBOR integers to
interface{}
by @fxamacker in #457 - Add encoding option to specify how omitempty fields are encoded by @dinhxuanvu in #453
- New options for encoding Go strings to and from CBOR byte strings by @benluddy in #465
- Add options to support byte string map keys as struct field names by @benluddy in #472
- Add option to specify how to decode unrecognized CBOR tag to
any
by @ssuriyan7 in #475
🚀 Notable Optimizations
-
Improve memory allocs 🗜️ and speed 🚀 of encoding maps by using Go 1.18-1.20 features by @dinhxuanvu in #468
NOTE: Go 1.17 is the minimum version supported by v2.6.0. Go 1.20+ will use optimizations introduced by PR 468.
🛠 Improvements
- Refactor valid() to reject negative values for integer modes by @fxamacker in #434
- Refactor tests to improve consistency and readability by @fxamacker in #458
- Add another test and fix lint errors by @fxamacker in #466
- Refactor map encoding to prep for Go version bump by @fxamacker in #473
- Add
UnrecognizedTagToAny
option toTestDecOptions
by @fxamacker in #484 - Update go.mod to require go 1.17 by @fxamacker in #489
🐞 Bug Fixes
- Fix panic when decoding CBOR nil to
*cbor.SimpleValue
by @fxamacker in #461 - Fix cbor.SimpleValue encoding and decoding by @fxamacker in #464
- Fix EncOption/DecOption unset fields on mode regurgitation. by @benluddy in #480
📖 Docs and CI
- Update README for error handling of CBOR extraneous data by @fxamacker in #426
- Update README for changes in cbor v2.5.0 by @fxamacker in #427
- Update CI and README by @fxamacker in #430
- Update README to add FIDO Alliance, Let's Encrypt, Matrix.org by @fxamacker in #431
- Pin actions/checkout and actions/setup-go by @x448 in #436
- Enable more linters by @fxamacker in #437
- Bump github/codeql-action from 2.22.5 to 2.22.8 by @dependabot in #443
- Document behavior of Unmarshal of unrecognized tags into interface{} by @benluddy in #448
- Bump github/codeql-action from 2.22.8 to 3.22.12 by @dependabot in #455
- Bump github/codeql-action from 3.22.12 to 3.23.0 by @dependabot in #469
New Contributors
- @benluddy made their first contribution in #433
- @dinhxuanvu made their first contribution in #453
- @ssuriyan7 made their first contribution in #475
Full Changelog: v2.5.0...v2.6.0
v2.6.0-rc.0
⭐ Features and Optimizations
- Add FieldNameMatching decode option. by @benluddy in #433
- Add option to decode CBOR bignum to
interface{}
as*big.Int
by @fxamacker in #456 - Add 2 more options for decoding CBOR integers to
interface{}
by @fxamacker in #457 - Add encoding option to specify how omitempty fields are encoded by @dinhxuanvu in #453
- New options for encoding Go strings to and from CBOR byte strings by @benluddy in #465
- Add options to support byte string map keys as struct field names by @benluddy in #472
- Add option to specify how to decode unrecognized CBOR tag to
any
by @ssuriyan7 in #475
🚀 Notable Optimizations
-
Improve memory allocs 🗜️ and speed 🚀 of encoding maps by using Go 1.18-1.20 features by @dinhxuanvu in #468
NOTE: Go 1.17 is the minimum version supported by v2.6.0. Go 1.20+ will use optimizations introduced by PR 468.
🛠 Improvements
- Refactor valid() to reject negative values for integer modes by @fxamacker in #434
- Refactor tests to improve consistency and readability by @fxamacker in #458
- Add another test and fix lint errors by @fxamacker in #466
- Refactor map encoding to prep for Go version bump by @fxamacker in #473
- Add
UnrecognizedTagToAny
option toTestDecOptions
by @fxamacker in #484 - Update go.mod to require go 1.17 by @fxamacker in #489
🐞 Bug Fixes
- Fix panic when decoding CBOR nil to
*cbor.SimpleValue
by @fxamacker in #461 - Fix cbor.SimpleValue encoding and decoding by @fxamacker in #464
- Fix EncOption/DecOption unset fields on mode regurgitation. by @benluddy in #480
📖 Docs and CI
- Update README for error handling of CBOR extraneous data by @fxamacker in #426
- Update README for changes in cbor v2.5.0 by @fxamacker in #427
- Update CI and README by @fxamacker in #430
- Update README to add FIDO Alliance, Let's Encrypt, Matrix.org by @fxamacker in #431
- Pin actions/checkout and actions/setup-go by @x448 in #436
- Enable more linters by @fxamacker in #437
- Bump github/codeql-action from 2.22.5 to 2.22.8 by @dependabot in #443
- Document behavior of Unmarshal of unrecognized tags into interface{} by @benluddy in #448
- Bump github/codeql-action from 2.22.8 to 3.22.12 by @dependabot in #455
- Bump github/codeql-action from 3.22.12 to 3.23.0 by @dependabot in #469
New Contributors
- @benluddy made their first contribution in #433
- @dinhxuanvu made their first contribution in #453
- @ssuriyan7 made their first contribution in #475
Full Changelog: v2.5.0...v2.6.0-rc.0
v2.5.0
This release adds important new features, optimizations, bug fixes, and 8 new contributors. Fuzz tests passed 5+ billion execs for CBOR encoding and decoding functions.
Notable changes are split into 3 categories.
⭐ Notable Changes to Review Before Upgrading
These new features and bug fixes were cherry-picked to highlight for review (for projects using older version).
- PR 370: Add
SimpleValue
type to more fully support CBOR Simple Values, including values not assigned by IANA and... - PR 376: Add
ByteString
type to support CBOR maps with byte string keys because Go doesn't allow []byte as map keys and... - PR 379: Make
Decoder.Decode()
returnio.ErrUnexpectedEOF
instead ofio.EOF
on EOF if current CBOR data item is incomplete. - PR 380: Make
Unmarshal()
andValid()
returncbor.ExtraneousDataError
(instead of ignoring extraneous data if any remain). - PR 387: Retry in Decoder if io.Reader's Read() returns 0 bytes read with nil error. Add tests to get 100% code coverage for stream.go.
⭐ More Notable Changes
- PR 342: Add
DecOptions.UTF8
to decode invalid UTF-8. Default is unchanged (reject invalid UTF-8 and return error). - PR 355 Allow
MaxNestedLevels
setting to be configured up to 65535. - PR 352, 377: Add
EncOptions.NilContainersMode
to encode nil Go maps and slices as either CBOR nil (default) or empty container. - PR 381: Add
Decoder.Skip()
to skip CBOR data item in CBOR Sequences (RFC 8742). - PR 386 Add functions for Extended Diagnostic Notation (RFC 8610 Appendix G).
- PR 398 Add
UnmarshalFirst()
to decode CBOR data item and also return remaining bytes. - PR 400 Deprecate
Valid
and addWellformed
to replace it. - PR 402 Add
UnmarshalFirst()
toDecMode
interface. - PR 412 Add
Decoder.Buffered
to return remaining data in buffer.
🚀 Notable Changes Affecting Speed or Memory Use
- PR 335: Reuse underlying array if
RawMessage
has sufficient capacity. - PR 382: Return buffer to pool in
Encode()
. It adds a bit of overhead toEncode()
butNewEncoder().Encode()
is faster and uses less memory.
Benchmark comparison for PR 382 shows significant improvement in speed and memory use.
🚀 (click to expand) 🚀
Benchmarks provided by @x448 for NewEncoder().Encode()
optimized in PR 382.
$ benchstat bench-v2.4.0.log bench-f9e6291.log
goos: linux
goarch: amd64
pkg: github.com/fxamacker/cbor/v2
cpu: 12th Gen Intel(R) Core(TM) i7-12700H
│ bench-v2.4.0.log │ bench-f9e6291.log │
│ sec/op │ sec/op vs base │
NewEncoderEncode/Go_bool_to_CBOR_bool-20 236.70n ± 2% 58.04n ± 1% -75.48% (p=0.000 n=10)
NewEncoderEncode/Go_uint64_to_CBOR_positive_int-20 238.00n ± 2% 63.93n ± 1% -73.14% (p=0.000 n=10)
NewEncoderEncode/Go_int64_to_CBOR_negative_int-20 238.65n ± 2% 64.88n ± 1% -72.81% (p=0.000 n=10)
NewEncoderEncode/Go_float64_to_CBOR_float-20 242.00n ± 2% 63.00n ± 1% -73.97% (p=0.000 n=10)
NewEncoderEncode/Go_[]uint8_to_CBOR_bytes-20 245.60n ± 1% 68.55n ± 1% -72.09% (p=0.000 n=10)
NewEncoderEncode/Go_string_to_CBOR_text-20 243.20n ± 3% 68.39n ± 1% -71.88% (p=0.000 n=10)
NewEncoderEncode/Go_[]int_to_CBOR_array-20 563.0n ± 2% 378.3n ± 0% -32.81% (p=0.000 n=10)
NewEncoderEncode/Go_map[string]string_to_CBOR_map-20 2.043µ ± 2% 1.906µ ± 2% -6.75% (p=0.000 n=10)
geomean 349.7n 122.7n -64.92%
│ bench-v2.4.0.log │ bench-f9e6291.log │
│ B/op │ B/op vs base │
NewEncoderEncode/Go_bool_to_CBOR_bool-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_uint64_to_CBOR_positive_int-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_int64_to_CBOR_negative_int-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_float64_to_CBOR_float-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]uint8_to_CBOR_bytes-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_string_to_CBOR_text-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]int_to_CBOR_array-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_map[string]string_to_CBOR_map-20 544.0 ± 0% 416.0 ± 0% -23.53% (p=0.000 n=10)
geomean 153.4 ? ¹ ²
¹ summaries must be >0 to compute geomean
² ratios must be >0 to compute geomean
│ bench-v2.4.0.log │ bench-f9e6291.log │
│ allocs/op │ allocs/op vs base │
NewEncoderEncode/Go_bool_to_CBOR_bool-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_uint64_to_CBOR_positive_int-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_int64_to_CBOR_negative_int-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_float64_to_CBOR_float-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]uint8_to_CBOR_bytes-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_string_to_CBOR_text-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]int_to_CBOR_array-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_map[string]string_to_CBOR_map-20 28.00 ± 0% 26.00 ± 0% -7.14% (p=0.000 n=10)
geomean 2.782 ? ¹ ²
¹ summaries must be >0 to compute geomean
² ratios must be >0 to compute geomean
What's Changed
All merged pull requests are listed here (including the already highlighted ones).
(click to expand)
Changes to Code
Most coding changes here were already mentioned.
- Reuse underlying array if RawMessage has sufficient capacity by @zensh in #335
- Add decoding option to allow invalid UTF-8 by @fxamacker in #342
- Allow MaxNestedLevels to be up to 65535 by @immesys in #355
- Add support for unassigned/reserved CBOR simple values by @fxamacker in #370
- Add ByteString type to support any CBOR byte string by @fxamacker in #376
- add option to enforce nil container marshaling as empty containers by @dedefer in #352
- Refactor NilContainersMode option by @fxamacker in #377
- Make Decoder.Decode() return io.UnexpectedEOF instead of io.EOF if CBOR data item is truncated by @fxamacker in #379
- Fix handling of extra data in Unmarshal() & Valid() by @fxamacker in #380
- Add Decoder.Skip() to skip CBOR data item in CBOR Sequences (RFC 8742) by @fxamacker in #381
- Return buffer to pool when using Encoder by @fxamacker in #382
- Retry in decoder if Read() returns 0 bytes read with nil error by @fxamacker in #387
- Deprecate Valid() and add Wellformed() to replace it by @fxamacker in #400
- Add UnmarshalFirst by @immesys in #398
- Add UnmarshalFirst to DecMode interface by @fxamacker in #402
- Add functions for Extended Diagnostic Notation (RFC 8610 Appendix G) by @zensh in #386
- Add more tests for Diagnose and DiagnoseFirst by @fxamacker in #405
- Fix Diagnose to return io.EOF error on empty data by @fxamacker in #410
- Add
Decoder.Buffered
to return buffered data by @fxamacker in #412 - Fix
Diagnose()
to returnio.EOF
error on empty data by @fxamacker in #410
Changes to CI, Comments, and Docs
- Remove trailing whitespaces in .golangci.yml by @CodingVoid in #333
- Update ci.yml by @fxamacker in #334
- Update ci.yml by ...
v2.5.0-beta5
v2.5.0-beta5 is fuzz tested and production quality, but docs need to be updated before releasing v2.5.0.
IMPORTANT: Please view these release notes (esp. v2.5.0-beta) before upgrading from v2.4 or earlier:
- v2.5.0-beta4 - Bugfix for
Diagnose
to returnio.EOF
on empty data. - v2.5.0-beta3 - Add functions:
Diagnose
,DiagnoseFirst
,UnmarshalFirst
,Wellformed
. - v2.5.0-beta2 - Bugfix to retry in
Decoder
ifio.Reader
'sRead()
returns 0 bytes read with nil error. - v2.5.0-beta - Notable improvements, optimizations, bugfixes, and 8 new contributors!
What's Changed since v2.5.0-beta4
- Add
Decoder.Buffered
to return remaining data in buffer by @fxamacker in #412 - Update README.md for v2.5.0-beta5 by @fxamacker in #413
Full Changelog: v2.5.0-beta4...v2.5.0-beta5
v2.5.0-beta4
Features already present in v2.4 are release quality. Newly added functions require more fuzzing and docs.
IMPORTANT: Please view these release notes (esp. v2.5.0-beta) before upgrading from v2.4:
- v2.5.0-beta3 - Add
Diagnose()
,DiagnoseFirst()
,UnmarshalFirst()
,Wellformed()
. - v2.5.0-beta2 - Bugfix and release notes include benchmark comparison of v2.5.0-beta2 vs v2.4.0.
- v2.5.0-beta - Notable improvements, optimizations, bugfixes, and 8 new contributors!
What's Changed Since v2.5.0-beta3
- Bump safer-golangci-lint to 1.52.2 by @x448 in #408
- Fix
Diagnose()
to returnio.EOF
error on empty data by @fxamacker in #410 - Update README.md for cbor v2.5.0-beta4 by @fxamacker in #411
Full Changelog: v2.5.0-beta3...v2.5.0-beta4
v2.5.0-beta3
This release adds 4 new functions: UnmarshalFirst
, Diagnose
, DiagnoseFirst
, and Wellformed
. In addition Valid
function is deprecated (use Wellformed
instead).
UnmarshalFirst
decodes first CBOR data item and returns remaining bytes. This is useful for CBOR Sequences (RFC 8742) and also becauseUnmarshal
was fixed in v2.5.0-beta to returnExtraneousDataError
if there are remaining bytes.Diagnose
andDiagnoseFirst
returns human-readable Extended Diagnostic Notation (RFC 8610 Appendix G) for the given CBOR encoding. These are useful for debugging and allows more user-friendly error logging.
What's Changed (since v2.5.0-beta2)
- Deprecate Valid() and add Wellformed() to replace it by @fxamacker in #400
- Add UnmarshalFirst by @immesys in #398
- Add UnmarshalFirst to DecMode interface by @fxamacker in #402
- Add functions for Extended Diagnostic Notation (RFC 8610 Appendix G) by @zensh in #386
- Add more tests for Diagnose and DiagnoseFirst by @fxamacker in #405
Changes to CI and Documentation
- Create govulncheck.yml by @fxamacker in #393
- Update README for cbor v2.5.0-beta2 by @fxamacker in #394
- Bump actions/setup-go from 3 to 4 by @dependabot in #395
- Update ci-go-cover.yml by @x448 in #404
- Update README for CBOR Sequences RFC 8742 by @fxamacker in #406
- Update README.md for v2.5.0-beta3 by @fxamacker in #407
Special Thanks
Thank you @immesys, @zensh, and @x448 for your contributions!
Full Changelog: v2.5.0-beta2...v2.5.0-beta3
v2.5.0-beta2
There are fewer changes in v2.5.0-beta2 compared to v2.5.0-beta. Speed and memory improvements since v2.4.0 are from v2.5.0-beta. Tests cover 98.5% and reached 100% coverage for stream.go (e.g. Decoder using the provided io.Reader).
What's Changed Since v2.5.0-beta
- Retry in Decoder if io.Reader's Read() returns 0 bytes read with nil error by @fxamacker in #387
- This PR also added more tests so we have 100% coverage for stream.go.
- Update fxamacker_cbor_banner.png for v2.5 by @x448 in #383
- bump safer-golangci-lint.yml to 1.51.1 by @x448 in #389
Go language recommends that Read
implementations for io.Reader avoid returning 0 with nil error. It also recommends that callers receiving 0 and nil from Read
should treat it as if nothing happened. This edge case is handled properly now.
@x448 shared benchmarks comparison of v2.4.0 vs v2.5.0-beta2. Performance improvements are from v2.5.0-beta.
Comparison of v2.5.0-beta2 vs v2.4.0
$ benchstat benchNewEncoderEncode-v2.4.0.log benchNewEncoderEncode-f9e6291.log
goos: linux
goarch: amd64
pkg: github.com/fxamacker/cbor/v2
cpu: 12th Gen Intel(R) Core(TM) i7-12700H
│ benchNewEncoderEncode-v2.4.0.log │ benchNewEncoderEncode-f9e6291.log │
│ sec/op │ sec/op vs base │
NewEncoderEncode/Go_bool_to_CBOR_bool-20 236.70n ± 2% 58.04n ± 1% -75.48% (p=0.000 n=10)
NewEncoderEncode/Go_uint64_to_CBOR_positive_int-20 238.00n ± 2% 63.93n ± 1% -73.14% (p=0.000 n=10)
NewEncoderEncode/Go_int64_to_CBOR_negative_int-20 238.65n ± 2% 64.88n ± 1% -72.81% (p=0.000 n=10)
NewEncoderEncode/Go_float64_to_CBOR_float-20 242.00n ± 2% 63.00n ± 1% -73.97% (p=0.000 n=10)
NewEncoderEncode/Go_[]uint8_to_CBOR_bytes-20 245.60n ± 1% 68.55n ± 1% -72.09% (p=0.000 n=10)
NewEncoderEncode/Go_string_to_CBOR_text-20 243.20n ± 3% 68.39n ± 1% -71.88% (p=0.000 n=10)
NewEncoderEncode/Go_[]int_to_CBOR_array-20 563.0n ± 2% 378.3n ± 0% -32.81% (p=0.000 n=10)
NewEncoderEncode/Go_map[string]string_to_CBOR_map-20 2.043µ ± 2% 1.906µ ± 2% -6.75% (p=0.000 n=10)
geomean 349.7n 122.7n -64.92%
│ benchNewEncoderEncode-v2.4.0.log │ benchNewEncoderEncode-f9e6291.log │
│ B/op │ B/op vs base │
NewEncoderEncode/Go_bool_to_CBOR_bool-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_uint64_to_CBOR_positive_int-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_int64_to_CBOR_negative_int-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_float64_to_CBOR_float-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]uint8_to_CBOR_bytes-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_string_to_CBOR_text-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]int_to_CBOR_array-20 128.0 ± 0% 0.0 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_map[string]string_to_CBOR_map-20 544.0 ± 0% 416.0 ± 0% -23.53% (p=0.000 n=10)
geomean 153.4 ? ¹ ²
¹ summaries must be >0 to compute geomean
² ratios must be >0 to compute geomean
│ benchNewEncoderEncode-v2.4.0.log │ benchNewEncoderEncode-f9e6291.log │
│ allocs/op │ allocs/op vs base │
NewEncoderEncode/Go_bool_to_CBOR_bool-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_uint64_to_CBOR_positive_int-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_int64_to_CBOR_negative_int-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_float64_to_CBOR_float-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]uint8_to_CBOR_bytes-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_string_to_CBOR_text-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_[]int_to_CBOR_array-20 2.000 ± 0% 0.000 ± 0% -100.00% (p=0.000 n=10)
NewEncoderEncode/Go_map[string]string_to_CBOR_map-20 28.00 ± 0% 26.00 ± 0% -7.14% (p=0.000 n=10)
geomean 2.782 ? ¹ ²
¹ summaries must be >0 to compute geomean
² ratios must be >0 to compute geomean
Full Changelog: v2.5.0-beta...v2.5.0-beta2
v2.5.0-beta
This release is larger than usual because it has been a year since last release. It adds new features, bug fixes, and 8 new contributors.
All unit tests pass (98.4% coverage). Fuzz tests passed hundreds of millions of execs. Fuzzing will continue until v2.5.0 is tagged.
Notable Changes to Review Before Upgrading
These new features and bug fixes were cherry-picked to highlight for review (for projects using older version in production).
-
PR 370: Add
SimpleValue
type to more fully support CBOR Simple Values, including values not assigned by IANA and... -
PR 376: Add
ByteString
type to support CBOR maps with byte string keys because Go doesn't allow []byte as map keys and... -
PR 379: Make
Decoder.Decode()
returnio.ErrUnexpectedEOF
instead ofio.EOF
on EOF if current CBOR data item is incomplete. -
PR 380: Make
Unmarshal()
andValid()
returncbor.ExtraneousDataError
(instead of ignoring extraneous data if any remain).
Notable Changes Affecting Speed or Memory Use
-
PR 335: Reuse underlying array if
RawMessage
has sufficient capacity. -
PR 382: Return buffer to pool in
Encode()
. It adds a bit of overhead toEncode()
butNewEncoder().Encode()
is a lot faster and uses less memory.
Other Notable Changes:
-
PR 342: Add
DecOptions.UTF8
to decode invalid UTF-8. Default is unchanged (reject invalid UTF-8 and return error). -
PR 355 Allow MaxNestedLevels setting to be configured up to 65535.
-
PR 352, 377: Add
EncOptions.NilContainersMode
to encode nil Go maps and slices as either CBOR nil (default) or empty container. -
PR 381: Add
Decoder.Skip()
to skip CBOR data item in CBOR Sequences (RFC 8742).
What's Changed
Most coding changes are already mentioned. Other changes include CI, comments, and docs.
(click to expand)
All Changes to Code
- Add support for unassigned/reserved CBOR simple values by @fxamacker in #370
- Add ByteString type to support any CBOR byte string by @fxamacker and @agaffney in #376
- Make Decoder.Decode() return io.ErrUnexpectedEOF instead of io.EOF on EOF if CBOR data item is truncated by @fxamacker in #379
- Fix handling of extra data in Unmarshal() & Valid() by @fxamacker in #380
- Add Decoder.Skip() to skip CBOR data item in CBOR Sequences (RFC 8742) by @fxamacker in #381
- Reuse underlying array if RawMessage has sufficient capacity by @zensh in #335
- Return buffer to pool when using Encoder.Encode by @fxamacker in #382
- Add decoding option to allow invalid UTF-8 by @fxamacker in #342
- Allow MaxNestedLevels to be up to 65535 by @immesys in #355
- add option to enforce nil container marshaling as empty containers by @dedefer in #352
- Refactor NilContainersMode option by @fxamacker in #377
Changes to CI, Comments, and Docs
-
Remove trailing whitespaces in .golangci.yml by @CodingVoid in #333
-
Update ci.yml by @fxamacker in #334
-
Remove default permissions from GitHub Actions workflows by @x448 in #341
-
Fix ci for stream mode branch by @fxamacker in #344
-
Bump github/codeql-action from 1 to 2 by @dependabot in #347
-
Mention security assessment by NCC Group by @fxamacker in #358
-
godoc.org link in Readme should point to v2 by @jdharms in #361
-
Add Go 1.19 to ci.yml test matrix by @fxamacker in #363
-
Mention 1276 repos depend on fxamacker/cbor/v2 by @x448 in #371
-
Fix EncMode example in the package comment by @creachadair in #375
New Contributors (alphabetically)
- @agaffney made their first contribution in #376
- @CodingVoid made their first contribution in #333
- @creachadair made their first contribution in #375
- @dedefer made their first contribution in #352
- @deeglaze made their first contribution in #353
- @immesys made their first contribution in #355
- @jdharms made their first contribution in #361
- @zensh made their first contribution in #335
Non-coding contibutions were made by opening notable issues that directly or indirectly improved this release.
- @burdiyan opened issue and followups that led to
Encode()
returning buffer to pool as default behavior. - @espoal opened issue and followups that led to adding Skip() feature for CBOR Sequences (RFC 8742).
- @qmuntal opened issue and @x448 added feedback that led to improved support for CBOR Simple Values.
- @x448 opened multiple issues and provided helpful feedback in addition to his merged PR.
- @zensh opened multiple issues and provided helpful feedback in addition to his merged PR.
Full Changelog: v2.4.0...v2.5.0-beta
v2.4.0 (January 3, 2022)
This release adds two user-requested features to the decoder. It passed 3+ billion execs fuzzing before being tagged.
What's Changed
- Add option to specify default Go map type when decoding CBOR map into interface{} by @fxamacker in #316
- Add support for decoding registered CBOR tag to interface type by @fxamacker in #308
- Update CBOR docs for v2.4.0 by @x448 in #318
Special Thanks
Full Changelog: v2.3.1...v2.4.0
v2.3.1 (Dec 28, 2021)
IMPORTANT:
- This release fixes an important typo in README and omission in CONTRIBUTING.
- No changes to code outside _test.go files.
- Changes to non-test files are limited to comments.
- Next release (v2.4.0) started fuzz testing and is expected to be tagged within 1-2 weeks.
Changes to v2.3.1 include:
- Fix typo in docs (example code snippet) that can cause bugs. Thanks @herrjemand!
- Update CONTRIBUTING to mention signing requirements. Thanks @lukseven and @x448!
- Update README. Thanks @x448 and @rumpelsepp!
- Update ci.yml to use Go 1.17.x. Thanks @x448!
- Add Revive as a lint checker.
- Cleanup lint messages in _test.go files
- Cleanup lint messages in non-test files if the changes are limited to comments (no actual coding changes).
Full Changelog: v2.3.0...v2.3.1