use crate::ir::{Expr, Program};
use crate::ops::primitive;
use crate::ops::{AlgebraicLaw, OpSpec, U32_OUTPUTS, U32_U32_INPUTS};
pub const LAWS: &[AlgebraicLaw] = &[
AlgebraicLaw::Commutative,
AlgebraicLaw::Bounded {
lo: 0,
hi: u32::MAX,
},
];
#[derive(Debug, Clone, Copy, Default)]
pub struct AddSat;
impl AddSat {
pub const SPEC: OpSpec = OpSpec::composition_inlinable(
"primitive.math.add_sat",
U32_U32_INPUTS,
U32_OUTPUTS,
LAWS,
Self::program,
);
#[must_use]
pub fn program() -> Program {
primitive::binary_u32_program(|a, b| {
let sum = Expr::add(a.clone(), b);
Expr::select(Expr::lt(sum.clone(), a), Expr::u32(u32::MAX), sum)
})
}
}