Skip to content

Commit

Permalink
Merge pull request #2246 from dtolnay/valuedenew
Browse files Browse the repository at this point in the history
Add constructor function for all IntoDeserializer impls
  • Loading branch information
dtolnay authored Jul 11, 2022
2 parents 4b622f6 + 8170ffe commit 7e1486d
Showing 1 changed file with 52 additions and 8 deletions.
60 changes: 52 additions & 8 deletions serde/src/de/value.rs
Original file line number Diff line number Diff line change
Expand Up @@ -128,9 +128,7 @@ where
type Deserializer = UnitDeserializer<E>;

fn into_deserializer(self) -> UnitDeserializer<E> {
UnitDeserializer {
marker: PhantomData,
}
UnitDeserializer::new()
}
}

Expand All @@ -141,6 +139,15 @@ pub struct UnitDeserializer<E> {

impl_copy_clone!(UnitDeserializer);

impl<E> UnitDeserializer<E> {
#[allow(missing_docs)]
pub fn new() -> Self {
UnitDeserializer {
marker: PhantomData,
}
}
}

impl<'de, E> de::Deserializer<'de> for UnitDeserializer<E>
where
E: de::Error,
Expand Down Expand Up @@ -236,8 +243,15 @@ macro_rules! primitive_deserializer {
type Deserializer = $name<E>;

fn into_deserializer(self) -> $name<E> {
$name::new(self)
}
}

impl<E> $name<E> {
#[allow(missing_docs)]
pub fn new(value: $ty) -> Self {
$name {
value: self,
value: value,
marker: PhantomData,
}
}
Expand Down Expand Up @@ -308,8 +322,15 @@ where
type Deserializer = U32Deserializer<E>;

fn into_deserializer(self) -> U32Deserializer<E> {
U32Deserializer::new(self)
}
}

impl<E> U32Deserializer<E> {
#[allow(missing_docs)]
pub fn new(value: u32) -> Self {
U32Deserializer {
value: self,
value: value,
marker: PhantomData,
}
}
Expand Down Expand Up @@ -390,8 +411,15 @@ where
type Deserializer = StrDeserializer<'a, E>;

fn into_deserializer(self) -> StrDeserializer<'a, E> {
StrDeserializer::new(self)
}
}

impl<'a, E> StrDeserializer<'a, E> {
#[allow(missing_docs)]
pub fn new(value: &'a str) -> Self {
StrDeserializer {
value: self,
value: value,
marker: PhantomData,
}
}
Expand Down Expand Up @@ -561,8 +589,16 @@ where
type Deserializer = StringDeserializer<E>;

fn into_deserializer(self) -> StringDeserializer<E> {
StringDeserializer::new(self)
}
}

#[cfg(any(feature = "std", feature = "alloc"))]
impl<E> StringDeserializer<E> {
#[allow(missing_docs)]
pub fn new(value: String) -> Self {
StringDeserializer {
value: self,
value: value,
marker: PhantomData,
}
}
Expand Down Expand Up @@ -656,8 +692,16 @@ where
type Deserializer = CowStrDeserializer<'a, E>;

fn into_deserializer(self) -> CowStrDeserializer<'a, E> {
CowStrDeserializer::new(self)
}
}

#[cfg(any(feature = "std", feature = "alloc"))]
impl<'a, E> CowStrDeserializer<'a, E> {
#[allow(missing_docs)]
pub fn new(value: Cow<'a, str>) -> Self {
CowStrDeserializer {
value: self,
value: value,
marker: PhantomData,
}
}
Expand Down

0 comments on commit 7e1486d

Please sign in to comment.