#arithmetic #checked #overflow #no-panic #no-alloc

no-std smooth-operator

Procedural macro that transforms regular infix arithmetic expressions into checked arithmetic expressions

1 unstable release

0.7.2 Dec 13, 2024

#1187 in Rust patterns

Download history 285/week @ 2024-12-12 73/week @ 2024-12-19 106/week @ 2024-12-26 129/week @ 2025-01-02 182/week @ 2025-01-09

577 downloads per month

MIT license

7KB
77 lines

smooth-operator

Procedural macro that transforms regular infix arithmetic expressions into checked arithmetic expressions.

Example

The following invocation of checked!():

fn the_answer() -> Result<i32, Error> {
    let answer = checked!(410 / 10 + 1)?;
    Ok(answer)
}

Results in this output:

fn the_answer() -> Result<i32, Error> {
    let answer = (|| -> ::core::result::Result<_, crate::Error> {
        type Err = crate::Error;
        const ORIGINAL_EXPR: &'static str = "410 / 10 + 1";
        Ok(
            #[allow(clippy::needless_question_mark)]
            #[allow(unused_parens)]
            {
                410.checked_div(10)
                    .ok_or(Err {
                        expr: ORIGINAL_EXPR,
                        __op_ix: 5usize,
                        __op_len: 1usize,
                    })?
                    .checked_add(1)
                    .ok_or(Err {
                        expr: ORIGINAL_EXPR,
                        __op_ix: 10usize,
                        __op_len: 1usize,
                    })?
            },
        )
    })()?;
    Ok(answer)
}

Dependencies

~210–650KB
~15K SLoC