#![allow(overflowing_literals)]
#![allow(clippy::excessive_precision)]
#![allow(clippy::approx_constant)]
#[path = "../src/dec2flt/mod.rs"]
mod dec2flt;
#[path = "dec2flt/decimal.rs"]
mod decimal;
#[path = "dec2flt/decimal_seq.rs"]
mod decimal_seq;
#[path = "dec2flt/float.rs"]
mod float;
#[path = "dec2flt/lemire.rs"]
mod lemire;
#[path = "dec2flt/parse.rs"]
mod parse;
macro_rules! test_literal {
($x: expr) => {{
let x32: f32 = $x;
let x64: f64 = $x;
let inputs = &[
stringify!($x).into(),
format!("{:?}", x64),
format!("{:e}", x64),
];
for input in inputs {
assert_eq!(
dec2flt::dec2flt(&input).map(|(n, _)| n),
Some(x64),
"failed f64 {input}"
);
assert_eq!(
dec2flt::dec2flt(&input).map(|(n, _)| n),
Some(x32),
"failed f32 {input}"
);
let neg_input = format!("-{input}");
assert_eq!(
dec2flt::dec2flt(&neg_input).map(|(n, _)| n),
Some(-x64),
"failed f64 {neg_input}"
);
assert_eq!(
dec2flt::dec2flt(&neg_input).map(|(n, _)| n),
Some(-x32),
"failed f32 {neg_input}"
);
}
}};
}
#[test]
fn ordinary() {
test_literal!(1.0);
test_literal!(3e-5);
test_literal!(0.1);
test_literal!(12345.);
test_literal!(0.9999999);
test_literal!(2.2250738585072014e-308);
}
#[test]
fn special_code_paths() {
test_literal!(36893488147419103229.0); test_literal!(101e-33); test_literal!(1e23); test_literal!(2075e23); test_literal!(8713e-23); }
#[test]
fn large() {
test_literal!(1e300);
test_literal!(123456789.34567e250);
test_literal!(943794359898089732078308743689303290943794359843568973207830874368930329.);
}
#[test]
fn subnormals() {
test_literal!(5e-324);
test_literal!(91e-324);
test_literal!(1e-322);
test_literal!(13245643e-320);
test_literal!(2.22507385851e-308);
test_literal!(2.1e-308);
test_literal!(4.9406564584124654e-324);
}
#[test]
fn infinity() {
test_literal!(1e400);
test_literal!(1e309);
test_literal!(2e308);
test_literal!(1.7976931348624e308);
}
#[test]
fn zero() {
test_literal!(0.0);
test_literal!(1e-325);
test_literal!(1e-326);
test_literal!(1e-500);
}
#[test]
fn fast_path_correct() {
test_literal!(1.448997445238699);
}
#[test]
fn lonely_dot() {
assert!(".".parse::<f32>().is_err());
assert!(".".parse::<f64>().is_err());
}
#[test]
fn exponentiated_dot() {
assert!(".e0".parse::<f32>().is_err());
assert!(".e0".parse::<f64>().is_err());
}
#[test]
fn lonely_sign() {
assert!("-".parse::<f32>().is_err());
assert!("+".parse::<f64>().is_err());
}
#[test]
fn whitespace() {
assert!(" 1.0".parse::<f32>().is_err());
assert!("1.0 ".parse::<f64>().is_err());
}
#[test]
fn nan() {
assert!("NaN".parse::<f32>().unwrap().is_nan());
assert!("-NaN".parse::<f32>().unwrap().is_nan());
assert!("NaN".parse::<f64>().unwrap().is_nan());
assert!("-NaN".parse::<f64>().unwrap().is_nan());
}
#[test]
fn inf() {
assert_eq!("inf".parse(), Ok(f32::INFINITY));
assert_eq!("-inf".parse(), Ok(f32::NEG_INFINITY));
assert_eq!("inf".parse(), Ok(f64::INFINITY));
assert_eq!("-inf".parse(), Ok(f64::NEG_INFINITY));
}
#[test]
fn massive_exponent() {
let max = i32::MAX;
assert_eq!(format!("1e{max}000").parse(), Ok(f32::INFINITY));
assert_eq!(format!("1e-{max}000").parse(), Ok(0.0f32));
assert_eq!(format!("1e{max}000").parse(), Ok(f32::INFINITY));
let max = i64::MAX;
assert_eq!(format!("1e{max}000").parse(), Ok(f64::INFINITY));
assert_eq!(format!("1e-{max}000").parse(), Ok(0.0f64));
assert_eq!(format!("1e{max}000").parse(), Ok(f64::INFINITY));
}