mirror of
https://github.com/serde-rs/json.git
synced 2025-10-02 23:35:59 +00:00
commit
2a2adb13a9
@ -146,19 +146,6 @@ impl Number {
|
|||||||
self.n.parse().ok()
|
self.n.parse().ok()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// If the `Number` is an integer, represent it as i128 if possible. Returns
|
|
||||||
/// None otherwise.
|
|
||||||
pub fn as_i128(&self) -> Option<i128> {
|
|
||||||
#[cfg(not(feature = "arbitrary_precision"))]
|
|
||||||
match self.n {
|
|
||||||
N::PosInt(n) => Some(n as i128),
|
|
||||||
N::NegInt(n) => Some(n as i128),
|
|
||||||
N::Float(_) => None,
|
|
||||||
}
|
|
||||||
#[cfg(feature = "arbitrary_precision")]
|
|
||||||
self.n.parse().ok()
|
|
||||||
}
|
|
||||||
|
|
||||||
/// If the `Number` is an integer, represent it as u64 if possible. Returns
|
/// If the `Number` is an integer, represent it as u64 if possible. Returns
|
||||||
/// None otherwise.
|
/// None otherwise.
|
||||||
pub fn as_u64(&self) -> Option<u64> {
|
pub fn as_u64(&self) -> Option<u64> {
|
||||||
@ -211,6 +198,31 @@ impl Number {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// If the `Number` is an integer, represent it as i128 if possible. Returns
|
||||||
|
/// None otherwise.
|
||||||
|
pub fn as_i128(&self) -> Option<i128> {
|
||||||
|
#[cfg(not(feature = "arbitrary_precision"))]
|
||||||
|
match self.n {
|
||||||
|
N::PosInt(n) => Some(n as i128),
|
||||||
|
N::NegInt(n) => Some(n as i128),
|
||||||
|
N::Float(_) => None,
|
||||||
|
}
|
||||||
|
#[cfg(feature = "arbitrary_precision")]
|
||||||
|
self.n.parse().ok()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// If the `Number` is an integer, represent it as u128 if possible. Returns
|
||||||
|
/// None otherwise.
|
||||||
|
pub fn as_u128(&self) -> Option<u128> {
|
||||||
|
#[cfg(not(feature = "arbitrary_precision"))]
|
||||||
|
match self.n {
|
||||||
|
N::PosInt(n) => Some(n as u128),
|
||||||
|
N::NegInt(_) | N::Float(_) => None,
|
||||||
|
}
|
||||||
|
#[cfg(feature = "arbitrary_precision")]
|
||||||
|
self.n.parse().ok()
|
||||||
|
}
|
||||||
|
|
||||||
/// Converts an `i128` to a `Number`. Numbers smaller than i64::MIN or
|
/// Converts an `i128` to a `Number`. Numbers smaller than i64::MIN or
|
||||||
/// larger than u64::MAX can only be represented in `Number` if serde_json's
|
/// larger than u64::MAX can only be represented in `Number` if serde_json's
|
||||||
/// "arbitrary_precision" feature is enabled.
|
/// "arbitrary_precision" feature is enabled.
|
||||||
@ -240,6 +252,33 @@ impl Number {
|
|||||||
Some(Number { n })
|
Some(Number { n })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Converts a `u128` to a `Number`. Numbers greater than u64::MAX can only
|
||||||
|
/// be represented in `Number` if serde_json's "arbitrary_precision" feature
|
||||||
|
/// is enabled.
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// # use serde_json::Number;
|
||||||
|
/// #
|
||||||
|
/// assert!(Number::from_u128(256).is_some());
|
||||||
|
/// ```
|
||||||
|
pub fn from_u128(i: u128) -> Option<Number> {
|
||||||
|
let n = {
|
||||||
|
#[cfg(not(feature = "arbitrary_precision"))]
|
||||||
|
{
|
||||||
|
if let Ok(u) = u64::try_from(i) {
|
||||||
|
N::PosInt(u)
|
||||||
|
} else {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#[cfg(feature = "arbitrary_precision")]
|
||||||
|
{
|
||||||
|
i.to_string()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Some(Number { n })
|
||||||
|
}
|
||||||
|
|
||||||
/// Returns the exact original JSON representation that this Number was
|
/// Returns the exact original JSON representation that this Number was
|
||||||
/// parsed from.
|
/// parsed from.
|
||||||
///
|
///
|
||||||
@ -376,13 +415,22 @@ impl<'de> Deserialize<'de> for Number {
|
|||||||
where
|
where
|
||||||
E: de::Error,
|
E: de::Error,
|
||||||
{
|
{
|
||||||
Number::from_i128(value).ok_or_else(|| de::Error::custom("not a JSON number"))
|
Number::from_i128(value)
|
||||||
|
.ok_or_else(|| de::Error::custom("JSON number out of range"))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn visit_u64<E>(self, value: u64) -> Result<Number, E> {
|
fn visit_u64<E>(self, value: u64) -> Result<Number, E> {
|
||||||
Ok(value.into())
|
Ok(value.into())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn visit_u128<E>(self, value: u128) -> Result<Number, E>
|
||||||
|
where
|
||||||
|
E: de::Error,
|
||||||
|
{
|
||||||
|
Number::from_u128(value)
|
||||||
|
.ok_or_else(|| de::Error::custom("JSON number out of range"))
|
||||||
|
}
|
||||||
|
|
||||||
fn visit_f64<E>(self, value: f64) -> Result<Number, E>
|
fn visit_f64<E>(self, value: f64) -> Result<Number, E>
|
||||||
where
|
where
|
||||||
E: de::Error,
|
E: de::Error,
|
||||||
@ -503,6 +551,8 @@ macro_rules! deserialize_any {
|
|||||||
return visitor.visit_u64(u);
|
return visitor.visit_u64(u);
|
||||||
} else if let Some(i) = self.as_i64() {
|
} else if let Some(i) = self.as_i64() {
|
||||||
return visitor.visit_i64(i);
|
return visitor.visit_i64(i);
|
||||||
|
} else if let Some(u) = self.as_u128() {
|
||||||
|
return visitor.visit_u128(u);
|
||||||
} else if let Some(i) = self.as_i128() {
|
} else if let Some(i) = self.as_i128() {
|
||||||
return visitor.visit_i128(i);
|
return visitor.visit_i128(i);
|
||||||
} else if let Some(f) = self.as_f64() {
|
} else if let Some(f) = self.as_f64() {
|
||||||
|
@ -57,6 +57,14 @@ impl<'de> Deserialize<'de> for Value {
|
|||||||
Ok(Value::Number(value.into()))
|
Ok(Value::Number(value.into()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn visit_u128<E>(self, value: u128) -> Result<Value, E>
|
||||||
|
where
|
||||||
|
E: serde::de::Error,
|
||||||
|
{
|
||||||
|
let de = serde::de::value::U128Deserializer::new(value);
|
||||||
|
Number::deserialize(de).map(Value::Number)
|
||||||
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
fn visit_f64<E>(self, value: f64) -> Result<Value, E> {
|
fn visit_f64<E>(self, value: f64) -> Result<Value, E> {
|
||||||
Ok(Number::from_f64(value).map_or(Value::Null, Value::Number))
|
Ok(Number::from_f64(value).map_or(Value::Null, Value::Number))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user