From 2adcf00548519838d18bf36a49d99ab21ce89409 Mon Sep 17 00:00:00 2001 From: zxj Date: Thu, 12 Dec 2024 10:27:20 +0800 Subject: [PATCH] impl FromPrimitive/ToPrimitive --- src/types/decimal.rs | 44 +++++++++++++++++++++++++++++++++++++------- 1 file changed, 37 insertions(+), 7 deletions(-) diff --git a/src/types/decimal.rs b/src/types/decimal.rs index 3b6ea65..2b4e3b7 100644 --- a/src/types/decimal.rs +++ b/src/types/decimal.rs @@ -53,7 +53,6 @@ impl Decimal { Some(Decimal::from(n)) } - ///Return a new Decimal object equivalent to self, /// with internal scaling set to the number specified. /// If the new_scale is lower than the current value (indicating a larger power of 10), @@ -144,7 +143,6 @@ impl From for Decimal { } } - impl From for Decimal { fn from(arg: u128) -> Self { Self::from(BigDecimal::from(arg)) @@ -181,7 +179,7 @@ impl FromStr for Decimal { } } -impl ToPrimitive for Decimal{ +impl ToPrimitive for Decimal { fn to_i64(&self) -> Option { self.0.to_i64() } @@ -200,6 +198,38 @@ impl ToPrimitive for Decimal{ } } +impl FromPrimitive for Decimal { + #[inline] + fn from_i64(n: i64) -> Option { + Some(Self::from(BigDecimal::from_i64(n)?)) + } + + #[inline] + fn from_u64(n: u64) -> Option { + Some(Self::from(BigDecimal::from_u64(n)?)) + } + + #[inline] + fn from_i128(n: i128) -> Option { + Some(Self::from(BigDecimal::from_i128(n)?)) + } + + #[inline] + fn from_u128(n: u128) -> Option { + Some(Self::from(BigDecimal::from_u128(n)?)) + } + + #[inline] + fn from_f32(n: f32) -> Option { + Some(Self::from(BigDecimal::from_f32(n)?)) + } + + #[inline] + fn from_f64(n: f64) -> Option { + Some(Self::from(BigDecimal::from_f64(n)?)) + } +} + impl Default for Decimal { fn default() -> Self { Decimal(BigDecimal::from(0)) @@ -373,11 +403,11 @@ mod test { #[test] fn test_try_from_f64() { - let f=1.1; + let f = 1.1; let v = Decimal::from_f64(f); - println!("{:?}",v); - if let Some(v)=v{ - println!("{}",v.to_string()); + println!("{:?}", v); + if let Some(v) = v { + println!("{}", v.to_string()); } } }