-
Notifications
You must be signed in to change notification settings - Fork 61
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
fix(deps): update rust crate serde_with to v3 #185
Conversation
d3163de
to
abecb0e
Compare
abecb0e
to
b6fb1c6
Compare
b6fb1c6
to
381114e
Compare
381114e
to
6b901a1
Compare
6b901a1
to
406676e
Compare
↑ sorry, had a mistake |
Haha, no worries. Do we need this upgrade? |
Upgrading to the latest is great, but no reason to be hurry. My mistake was during my routine approving and merging my Renovate PRs 😔 |
Prepared upgrading PR: #214. Could you please review it when if you have time? |
Signed-off-by: Natsuki Ikeguchi <[email protected]>
Edited/Blocked NotificationRenovate will not automatically rebase this PR, because it does not recognize the last commit author and assumes somebody else may have edited the PR. You can manually request rebase by checking the rebase/retry box above. ⚠ Warning: custom changes will be lost. |
Thanks for the contributions 🚀 |
I'll find time to do that! |
I've been preparing next release with hyper v1/axum 0.7, I'd like to solve this issue as well, so I'll merge this and try to do a bit testing. Thanks for the fixes! |
This PR contains the following updates:
1.14
->3.4
Release Notes
jonasbb/serde_with (serde_with)
v3.4.0
: serde_with v3.4.0Compare Source
Lower minimum required serde version to 1.0.152 (#653)
Thanks to @banool for submitting the PR.
This allows people that have a problem with 1.0.153 to still use
serde_with
.Add support for
core::ops::Bound
(#655)Thanks to @qsantos for submitting the PR.
v3.3.0
: serde_with v3.3.0Compare Source
Added
Support the
hashbrown
typeHashMap
andHashSet
(#636, #637)Thanks to @OliverNChalk for raising the issue and submitting a PR.
This extends the existing support for
HashMap
s andHashSet
s to thehashbrown
crate v0.14.The same conversions as for the
std
andindexmap
types are available, like general support for#[serde_as]
and converting it to/from sequences or maps.Changed
Generalize some trait bounds for
DeserializeAs
implementationsWhile working on #637 it came to light that some of the macros for generating
DeserializeAs
implementations were not as generic as they could.This means they didn't work with custom hasher types, but only the default hashers.
This has now been fixed and custom hashers should work better, as long as they implement
BuildHasher + Default
.(internal) Change how features are documented (#639)
This change moves the feature documentation into
Cargo.toml
in a format that can be read by lib.rs.It will improve the generated features documentation there.
The page with all features remains in the guide but is now generated from the
Cargo.toml
information.v3.2.0
: serde_with v3.2.0Compare Source
Added
Support for v1 is already available using the
indexmap_1
feature.This adds identical support for v2 of indexmap using the
indexmap_2
feature.Changed
Fixed
i64::MIN
usingTimestampSeconds<i64>
(#632, #633)Thanks to @hollmmax for reporting and fixing the issue.
v3.1.0
: serde_with v3.1.0Compare Source
Added
Add
FromIntoRef
andTryFromIntoRef
(#618)Thanks to @oblique for submitting the PR.
The new types are similar to the existing
FromInto
andTryFromInto
types.They behave different during serialization, allowing the removal of the
Clone
bound on theirSerializeAs
trait implementationChanged
serde_as
(#607)cfg_eval
.v3.0.0
: serde_with v3.0.0Compare Source
This breaking release should not impact most users.
It only affects custom character sets used for base64 of which there are no instances of on GitHub.
Changed
Upgrade base64 to v0.21 (#543)
Thanks to @jeff-hiner for submitting the PR.
Remove support for custom character sets.
This is technically a breaking change.
A code search on GitHub revealed no instances of anyone using that, and
serde_with
ships with many predefined character sets.The removal means that future base64 upgrade will no longer be breaking changes.
v2.3.3
: serde_with v2.3.3Compare Source
Changed
syn
to v2 anddarling
to v0.20 (#578)Update proc-macro dependencies.
This change should have no impact on users, but now uses the same dependency as
serde_derive
.v2.3.2
: serde_with v2.3.2Compare Source
Changed
Improve the error message when deserializing
OneOrMany
orPickFirst
fails.It now includes the original error message for each of the individual variants.
This is possible by dropping untagged enums as the internal implementations, since they will likely never support this, as these old PRs show serde#2376 and serde#1544.
The new errors look like:
Fixed
Thanks to @nox for submitting a PR.
v2.3.1
: serde_with v2.3.1Compare Source
Fixed
Undo the changes to the trait bound for
Seq
. (#570, #571)The new implementation caused issues with serialization formats that require the sequence length beforehand.
It also caused problems, that certain attributes which worked before no longer worked, due to mismatching number of references.
Thanks to @stefunctional for reporting and for @stephaneyfx for providing a test case.
v2.3.0
: serde_with v2.3.0Compare Source
Added
Add
serde_as
compatible versions for the existing duplicate key and value handling. (#534)The new types
MapPreventDuplicates
,MapFirstKeyWins
,SetPreventDuplicates
, andSetLastValueWins
can replace the existing modulesmaps_duplicate_key_is_error
,maps_first_key_wins
,sets_duplicate_value_is_error
, andsets_last_value_wins
.Added a new
KeyValueMap
type using the map key as a struct field. (#341)This conversion is useful for maps, where an ID value is the map key, but the ID should become part of a single struct.
The conversion allows this, by using a special field named
$key$
.This conversion is possible for structs and maps, using the
$key$
field.Tuples, tuple structs, and sequences are supported by turning the first value into the map key.
Each of the
SimpleStruct
swill turn into a JSON snippet like this.
Changed
Seq
to allow for more custom types. (#565)This extends the support beyond tuples.
Fixed
EnumMap
passes thehuman_readable
status of theSerializer
to more places.alloc
on targets withouttarget_has_atomic = "ptr"
. (#560)Thanks to @vembacher for reporting and fixing the issue.
v2.2.0
: serde_with v2.2.0Compare Source
Added
Add new
Map
andSeq
types for converting between maps and tuple lists. (#527)The behavior is not new, but already present using
BTreeMap
/HashMap
orVec
.However, the new types
Map
andSeq
are also available onno_std
, even without thealloc
feature.Changed
serde_with_macros
dependency to the same version as the main crate.This simplifies publishing and ensures that always a compatible version is picked.
Fixed
serde_with::apply
had an issue matching types when invisible token groups where in use (#538)The token groups can stem from macro_rules expansion, but should be treated mostly transparent.
The old code required a group to match a group, while now groups are silently removed when checking for type patterns.
v2.1.0
: serde_with v2.1.0Compare Source
Added
Add new
apply
attribute to simplify repetitive attributes over many fields.Multiple rules and multiple attributes can be provided each.
The
apply
attribute will expand into this, applying the attributs to the matching fields:The attribute supports field matching using many rules, such as
_
to apply to all fields and partial generics likeOption
to match anyOption
be itOption<String>
,Option<bool>
, orOption<T>
.Fixed
The derive macros
SerializeDisplay
andDeserializeFromStr
now take better care not to use conflicting names for generic values. (#526)All used generics now start with
__
to make conflicts with manually written code unlikely.Thanks to @Elrendio for submitting a PR fixing the issue.
v2.0.1
: serde_with v2.0.1Compare Source
Added
time
added support for the well-knownIso8601
format.This extends the existing support of
Rfc2822
andRfc3339
.Changed
serde_as
is used on an enum variant.Attributes on enum variants were never supported.
But
#[serde(with = "...")]
can be added on variants, such that some confusion can occur when migration (#499).Note
A cargo bug (cargo#10801) means that upgrading from v1 to v2 may add unnecessary crates to the
Cargo.lock
file.A diff of the lock-file makes it seem that
serde_with
depends on new crates, even though these crates are unused and will not get compiled or linked.However, tools consuming
Cargo.lock
orcargo metadata
might give wrong results.v2.0.0
: serde_with v2.0.0Compare Source
Added
Make
JsonString<T>
smarter by allowing nestingserde_as
definitions.This allows applying custom serialization logic, before the value gets converted into a JSON string.
Changed
Make
#[serde_as]
behave more intuitive onOption<T>
fields.The
#[serde_as]
macro now detects if a#[serde_as(as = "Option<S>")]
is used on a field of typeOption<T>
and applies#[serde(default)]
to the field.This restores the ability to deserialize with missing fields and fixes a common annoyance (#183, #185, #311, #417).
This is a breaking change, since now deserialization will pass where it did not before and this might be undesired.
The
Option
field and transformation are detected by directly matching on the type name.These variants are detected as
Option
.Option
std::option::Option
, with or without leading::
core::option::Option
, with or without leading::
If an existing
default
attribute is detected, the attribute is not applied again.This behavior can be suppressed by using
#[serde_as(no_default)]
or#[serde_as(as = "Option<S>", no_default)]
.NoneAsEmptyString
andstring_empty_as_none
use a different serialization bound (#388).Both types used
AsRef<str>
as the serialization bound.This is limiting for non-string types like
Option<i32>
.The deserialization often was already more flexible, due to the
FromStr
bound.For most std types this should have little impact, as the types implementing
AsRef<str>
mostly implementDisplay
, too, such asString
,Cow<str>
, orRc<str>
.Bump MSRV to 1.60. This is required for the optional dependency feature syntax in cargo.
Removed
Remove old module based conversions.
The newer
serde_as
based conversions are preferred.seq_display_fromstr
: UseDisplayFromStr
in combination with your container type:tuple_list_as_map
: UseBTreeMap
on aVec
of tuples:map_as_tuple_list
can be replaced with#[serde_as(as = "Vec<(_, _)>")]
.display_fromstr
can be replaced with#[serde_as(as = "DisplayFromStr")]
.bytes_or_string
can be replaced with#[serde_as(as = "BytesOrString")]
.default_on_error
can be replaced with#[serde_as(as = "DefaultOnError")]
.default_on_null
can be replaced with#[serde_as(as = "DefaultOnNull")]
.string_empty_as_none
can be replaced with#[serde_as(as = "NoneAsEmptyString")]
.StringWithSeparator
can now only be used inserde_as
.The definition of the
Separator
trait and its implementations have been moved to theformats
module.json::nested
can be replaced with#[serde_as(as = "json::JsonString")]
.Remove previously deprecated modules.
sets_first_value_wins
btreemap_as_tuple_list
andhashmap_as_tuple_list
can be replaced with#[serde_as(as = "Vec<(_, _)>")]
.Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by Mend Renovate. View repository job log here.