Skip to content

Commit

Permalink
Merge pull request #1971 from arthurprs/untagged-enum-fix-pr
Browse files Browse the repository at this point in the history
Allow floats to be deserialized from ints in untagged unions (part 2)
  • Loading branch information
dtolnay authored Jan 26, 2021
2 parents 3d6c414 + de8ac1c commit 9a84622
Showing 1 changed file with 21 additions and 13 deletions.
34 changes: 21 additions & 13 deletions serde/src/private/de.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1741,6 +1741,25 @@ mod content {
_ => Err(self.invalid_type(&visitor)),
}
}

fn deserialize_float<V>(self, visitor: V) -> Result<V::Value, E>
where
V: Visitor<'de>,
{
match *self.content {
Content::F32(v) => visitor.visit_f32(v),
Content::F64(v) => visitor.visit_f64(v),
Content::U8(v) => visitor.visit_u8(v),
Content::U16(v) => visitor.visit_u16(v),
Content::U32(v) => visitor.visit_u32(v),
Content::U64(v) => visitor.visit_u64(v),
Content::I8(v) => visitor.visit_i8(v),
Content::I16(v) => visitor.visit_i16(v),
Content::I32(v) => visitor.visit_i32(v),
Content::I64(v) => visitor.visit_i64(v),
_ => Err(self.invalid_type(&visitor)),
}
}
}

fn visit_content_seq_ref<'a, 'de, V, E>(
Expand Down Expand Up @@ -1888,25 +1907,14 @@ mod content {
where
V: Visitor<'de>,
{
match *self.content {
Content::F32(v) => visitor.visit_f32(v),
Content::F64(v) => visitor.visit_f64(v),
Content::U64(v) => visitor.visit_u64(v),
Content::I64(v) => visitor.visit_i64(v),
_ => Err(self.invalid_type(&visitor)),
}
self.deserialize_float(visitor)
}

fn deserialize_f64<V>(self, visitor: V) -> Result<V::Value, Self::Error>
where
V: Visitor<'de>,
{
match *self.content {
Content::F64(v) => visitor.visit_f64(v),
Content::U64(v) => visitor.visit_u64(v),
Content::I64(v) => visitor.visit_i64(v),
_ => Err(self.invalid_type(&visitor)),
}
self.deserialize_float(visitor)
}

fn deserialize_char<V>(self, visitor: V) -> Result<V::Value, Self::Error>
Expand Down

0 comments on commit 9a84622

Please sign in to comment.