lean-decimal 0.1.0

Fast, fixed-precision, floating-point decimal types.
Documentation
use lean_decimal::Decimal;

type Dec = Decimal<u128>;

fn test_add(a: Dec, b: Dec, r: Dec) {
    dbg!(a, b, r);
    assert_eq!(a + -b, a - b);
    assert_eq!(-a + b, b - a);
    assert_eq!(-a + -b, -(b + a));
    assert_eq!(-a + -b, -r);

    assert_eq!(a + b, r);
    assert_eq!(b + a, r);
    assert_eq!(r - a, b);
    assert_eq!(r - b, a);
}

#[test]
fn add_base() {
    // normal
    let a = Dec::from_parts(1000, 10);
    let b = Dec::from_parts(2000, 10);
    let c = Dec::from_parts(3000, 10);
    test_add(a, a, b);
    test_add(a, b, c);

    // zero
    test_add(a, Dec::ZERO, a);
    test_add(a, -Dec::ZERO, a);

    // different scales
    let d = Dec::from_parts(1000, 13);
    let e = Dec::from_parts(1001000, 13);
    test_add(a, d, e);

    let max_mantissa = (1_i128 << 121) - 1;

    // different scales with big mantissa
    let big1 = Dec::from_parts(max_mantissa - 1, 7);
    let big2 = Dec::from_parts(max_mantissa, 7);
    test_add(a, big1, big2);

    // overflow in addition, so reduce scale
    let big1 = Dec::from_parts(max_mantissa - 1, 10);
    let big2 = Dec::from_parts(max_mantissa / 5, 9);
    test_add(big1, big1, big2);

    // overflow without scale to reduced
    let big1 = Dec::from_parts(max_mantissa, 0);
    assert!(big1.checked_add(big1).is_none());
}