Content-Length: 284322 | pFad | http://github.com/0xC0A1/financial-ops

6B GitHub - 0xC0A1/financial-ops: This crate provides a set of operations for working with financial data, more specifically, avoiding the usage of floating point types.
Skip to content

This crate provides a set of operations for working with financial data, more specifically, avoiding the usage of floating point types.

License

Notifications You must be signed in to change notification settings

0xC0A1/financial-ops

Repository files navigation

Financial Ops

Crates.io Docs.rs License

This crate provides a set of operations for working with financial data, more specifically, avoiding the usage of floating point types.

Usage

use financial_ops::CheckedDecimalOperations;

fn test_add_decimals() {
    let a: u64 = 1_0000;
    let a_decimals = 4;
    let b: u64 = 2_00;
    let b_decimals = 2;

    let (result, decimals) = a.add_decimals_checked(b, a_decimals, b_decimals)?;
    assert_eq!(result, 3_0000);
    assert_eq!(decimals, 4);

    let a: u32 = 123_45;
    let a_decimals = 2;
    let b: u32 = 0_45;
    let b_decimals = 2;

    let (result, decimals) = a.add_decimals_checked(b, a_decimals, b_decimals)?;
    assert_eq!(result, 123_90);
    assert_eq!(decimals, 2);
}

Very useful when dealing with money or blockchain transactions.

Supported operations

Checked

This set of operations will return an Result with the result and the number of decimals, if the operation is successful. If the operation is not successful, it will return a DecimalOperationError.

use financial_ops::CheckedDecimalOperations;
  • add_decimals_checked
  • sub_decimals_checked
  • mul_decimals_checked
  • div_decimals_checked
  • rem_decimals_checked

Unchecked

This set of operations will return the result and the number of decimals, without any checks, carrying the underlying operation way of handling overflows and underflows.

use financial_ops::DecimalOperations;
  • add_decimals
  • sub_decimals
  • mul_decimals
  • div_decimals
  • rem_decimals

About

This crate provides a set of operations for working with financial data, more specifically, avoiding the usage of floating point types.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages









ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://github.com/0xC0A1/financial-ops

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy