mirror of
https://github.com/roc-lang/roc.git
synced 2025-09-26 21:39:07 +00:00
gen-dev: complete Num{Mul,Add,Sub}Saturated impls
MulSaturated and AddSaturated are now implemented for u128, i128 SubSaturated is now implemented for Dec even if it's a little strange to saturate at a decimal value: ``` » Num.subSaturated -170_141_183_460_469_231_731dec 1 -170141183460469231731.687303715884105728 : Dec ``` I decided to rm the `build_num_{mul,add}_saturated` methods because they don't require any asm-specifics. They either call out to bitcode, or use the non-saturated version for floats.
This commit is contained in:
parent
49ab969ff3
commit
8fd2fbc3a1
4 changed files with 231 additions and 192 deletions
|
@ -3000,161 +3000,199 @@ fn u8_mul_greater_than_i8() {
|
|||
#[test]
|
||||
#[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))]
|
||||
fn add_saturated() {
|
||||
assert_evals_to!("Num.addSaturated 200u8 200u8", 255u8, u8);
|
||||
assert_evals_to!("Num.addSaturated 100i8 100i8", 127i8, i8);
|
||||
assert_evals_to!("Num.addSaturated -100i8 -100i8", -128i8, i8);
|
||||
assert_evals_to!("Num.addSaturated 40000u16 40000u16", 65535u16, u16);
|
||||
assert_evals_to!("Num.addSaturated 20000i16 20000i16", 32767i16, i16);
|
||||
assert_evals_to!("Num.addSaturated -20000i16 -20000i16", -32768i16, i16);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : U8
|
||||
x = 200
|
||||
y : U8
|
||||
y = 200
|
||||
Num.addSaturated x y
|
||||
"
|
||||
),
|
||||
255,
|
||||
u8
|
||||
"Num.addSaturated 3000000000u32 3000000000u32",
|
||||
4294967295u32,
|
||||
u32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated 2000000000i32 2000000000i32",
|
||||
2147483647i32,
|
||||
i32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated -2000000000i32 -2000000000i32",
|
||||
-2147483648i32,
|
||||
i32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated 10000000000000000000u64 10000000000000000000u64",
|
||||
18446744073709551615u64,
|
||||
u64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated 5000000000000000000i64 5000000000000000000i64 ",
|
||||
9223372036854775807i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated -5000000000000000000i64 -5000000000000000000i64 ",
|
||||
-9223372036854775808i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated -5000000000000000000i64 -5000000000000000000i64 ",
|
||||
-9223372036854775808i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated Num.maxF32 Num.maxF32",
|
||||
std::f32::INFINITY,
|
||||
f32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated Num.minF32 Num.minF32",
|
||||
std::f32::NEG_INFINITY,
|
||||
f32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated Num.maxF64 Num.maxF64",
|
||||
std::f64::INFINITY,
|
||||
f64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.addSaturated Num.minF64 Num.minF64",
|
||||
std::f64::NEG_INFINITY,
|
||||
f64
|
||||
);
|
||||
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = 100
|
||||
y : I8
|
||||
y = 100
|
||||
Num.addSaturated x y
|
||||
"
|
||||
),
|
||||
127,
|
||||
i8
|
||||
"Num.addSaturated 170_141_183_460_469_231_731dec 1",
|
||||
RocDec::from_str("170141183460469231731.687303715884105727").unwrap(),
|
||||
RocDec
|
||||
);
|
||||
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = -100
|
||||
y : I8
|
||||
y = -100
|
||||
Num.addSaturated x y
|
||||
"
|
||||
),
|
||||
-128,
|
||||
i8
|
||||
"Num.addSaturated -170_141_183_460_469_231_731dec -1",
|
||||
RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(),
|
||||
RocDec
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))]
|
||||
fn sub_saturated() {
|
||||
assert_evals_to!("Num.subSaturated 1u8 10u8", 0u8, u8);
|
||||
assert_evals_to!("Num.subSaturated 100i8 -100i8", 127i8, i8);
|
||||
assert_evals_to!("Num.subSaturated -100i8 100i8", -128i8, i8);
|
||||
assert_evals_to!("Num.subSaturated 1u16 10u16", 0u16, u16);
|
||||
assert_evals_to!("Num.subSaturated 20000i16 -20000i16", 32767i16, i16);
|
||||
assert_evals_to!("Num.subSaturated -20000i16 20000i16", -32768i16, i16);
|
||||
assert_evals_to!("Num.subSaturated 1u32 10u32", 0u32, u32);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : U8
|
||||
x = 10
|
||||
y : U8
|
||||
y = 20
|
||||
Num.subSaturated x y
|
||||
"
|
||||
),
|
||||
0,
|
||||
u8
|
||||
"Num.subSaturated 2000000000i32 -2000000000i32",
|
||||
2147483647i32,
|
||||
i32
|
||||
);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = -100
|
||||
y : I8
|
||||
y = 100
|
||||
Num.subSaturated x y
|
||||
"
|
||||
),
|
||||
-128,
|
||||
i8
|
||||
"Num.subSaturated -2000000000i32 2000000000i32",
|
||||
-2147483648i32,
|
||||
i32
|
||||
);
|
||||
assert_evals_to!("Num.subSaturated 1u64 10u64", 0u64, u64);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated 5000000000000000000i64 -5000000000000000000i64 ",
|
||||
9223372036854775807i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = 100
|
||||
y : I8
|
||||
y = -100
|
||||
Num.subSaturated x y
|
||||
"
|
||||
),
|
||||
127,
|
||||
i8
|
||||
"Num.subSaturated -5000000000000000000i64 5000000000000000000i64 ",
|
||||
-9223372036854775808i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated -5000000000000000000i64 5000000000000000000i64 ",
|
||||
-9223372036854775808i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated Num.maxF32 -Num.maxF32",
|
||||
std::f32::INFINITY,
|
||||
f32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated Num.minF32 -Num.minF32",
|
||||
std::f32::NEG_INFINITY,
|
||||
f32
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated Num.maxF64 -Num.maxF64",
|
||||
std::f64::INFINITY,
|
||||
f64
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated Num.minF64 -Num.minF64",
|
||||
std::f64::NEG_INFINITY,
|
||||
f64
|
||||
);
|
||||
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated 170_141_183_460_469_231_731dec -1",
|
||||
RocDec::from_str("170141183460469231731.687303715884105727").unwrap(),
|
||||
RocDec
|
||||
);
|
||||
assert_evals_to!(
|
||||
"Num.subSaturated -170_141_183_460_469_231_731dec 1",
|
||||
RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(),
|
||||
RocDec
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[cfg(any(feature = "gen-llvm", feature = "gen-wasm", feature = "gen-dev"))]
|
||||
fn mul_saturated() {
|
||||
assert_evals_to!("Num.mulSaturated 200u8 2", 255u8, u8);
|
||||
assert_evals_to!("Num.mulSaturated 100i8 2", 127i8, i8);
|
||||
assert_evals_to!("Num.mulSaturated -100i8 2", -128i8, i8);
|
||||
assert_evals_to!("Num.mulSaturated 40000u16 2", 65535u16, u16);
|
||||
assert_evals_to!("Num.mulSaturated 20000i16 2", 32767i16, i16);
|
||||
assert_evals_to!("Num.mulSaturated -20000i16 2", -32768i16, i16);
|
||||
assert_evals_to!("Num.mulSaturated 3000000000u32 2", 4294967295u32, u32);
|
||||
assert_evals_to!("Num.mulSaturated 2000000000i32 2", 2147483647i32, i32);
|
||||
assert_evals_to!("Num.mulSaturated -2000000000i32 2", -2147483648i32, i32);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : U8
|
||||
x = 20
|
||||
y : U8
|
||||
y = 20
|
||||
Num.mulSaturated x y
|
||||
"
|
||||
),
|
||||
255,
|
||||
u8
|
||||
"Num.mulSaturated 10000000000000000000u64 2",
|
||||
18446744073709551615u64,
|
||||
u64
|
||||
);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = -20
|
||||
y : I8
|
||||
y = -20
|
||||
Num.mulSaturated x y
|
||||
"
|
||||
),
|
||||
127,
|
||||
i8
|
||||
"Num.mulSaturated 5000000000000000000i64 2",
|
||||
9223372036854775807i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = 20
|
||||
y : I8
|
||||
y = -20
|
||||
Num.mulSaturated x y
|
||||
"
|
||||
),
|
||||
-128,
|
||||
i8
|
||||
"Num.mulSaturated -5000000000000000000i64 2",
|
||||
-9223372036854775808i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = -20
|
||||
y : I8
|
||||
y = 20
|
||||
Num.mulSaturated x y
|
||||
"
|
||||
),
|
||||
-128,
|
||||
i8
|
||||
"Num.mulSaturated -5000000000000000000i64 2",
|
||||
-9223372036854775808i64,
|
||||
i64
|
||||
);
|
||||
assert_evals_to!("Num.mulSaturated Num.maxF32 2", std::f32::INFINITY, f32);
|
||||
assert_evals_to!("Num.mulSaturated Num.minF32 2", std::f32::NEG_INFINITY, f32);
|
||||
assert_evals_to!("Num.mulSaturated Num.maxF64 2", std::f64::INFINITY, f64);
|
||||
assert_evals_to!("Num.mulSaturated Num.minF64 2", std::f64::NEG_INFINITY, f64);
|
||||
|
||||
// TODO: This doesn't work anywhere? It returns -1.374607431768211456 : Dec ?
|
||||
/*
|
||||
assert_evals_to!(
|
||||
"Num.mulSaturated 170_141_183_460_469_231_731dec 2",
|
||||
RocDec::from_str("170141183460469231731.687303715884105727").unwrap(),
|
||||
RocDec
|
||||
);
|
||||
assert_evals_to!(
|
||||
indoc!(
|
||||
r"
|
||||
x : I8
|
||||
x = 20
|
||||
y : I8
|
||||
y = 20
|
||||
Num.mulSaturated x y
|
||||
"
|
||||
),
|
||||
127,
|
||||
i8
|
||||
"Num.mulSaturated -170_141_183_460_469_231_731dec 2",
|
||||
RocDec::from_str("-170141183460469231731.687303715884105728").unwrap(),
|
||||
RocDec
|
||||
);
|
||||
*/
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue