Crates.io | decimal-rs |
lib.rs | decimal-rs |
version | 0.1.43 |
source | src |
created_at | 2021-02-02 16:02:52.585857 |
updated_at | 2023-04-11 09:39:51.643656 |
description | High precision decimal implementation for Rust |
homepage | https://github.com/cod-technologies/decimal-rs |
repository | https://github.com/cod-technologies/decimal-rs.git |
max_upload_size | |
id | 349806 |
size | 290,208 |
High precision decimal with maximum precision of 38.
serde
: When this optional dependency is enabled, Decimal
implements the serde::Serialize
and serde::Deserialize
traits.To build a decimal, use Decimal
:
use decimal_rs::Decimal;
let n1: Decimal = "123".parse().unwrap();
let n2: Decimal = "456".parse().unwrap();
let result = n1 + n2;
assert_eq!(result.to_string(), "579");
To build a decimal from Rust primitive types:
use decimal_rs::Decimal;
let n1 = Decimal::from(123_i32);
let n2 = Decimal::from(456_i32);
let result = n1 + n2;
assert_eq!(result, Decimal::from(579_i32));
Decimal supports high precision arithmetic operations.
use decimal_rs::Decimal;
let n1: Decimal = "123456789.987654321".parse().unwrap();
let n2: Decimal = "987654321.123456789".parse().unwrap();
let result = n1 * n2;
assert_eq!(result.to_string(), "121932632103337905.662094193112635269");
Decimal can be encoded to bytes and decoded from bytes.
use decimal_rs::Decimal;
let n1 = "123456789.987654321".parse::<Decimal>().unwrap();
let mut bytes = Vec::new();
n1.encode(&mut bytes).unwrap();
let n2 = Decimal::decode(&bytes);
assert_eq!(n1, n2);
This version of decimal-rs
requires Rust 1.51 or later.
This project is licensed under the Apache-2.0 license (LICENSE or http://www.apache.org/licenses/LICENSE-2.0).
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in decimal-rs
by you, shall be licensed as Apache-2.0, without any additional
terms or conditions.