#arithmetic #crypto #proc-macro #wrapping #operator #u32 #equivalents

macro wrapping_arithmetic

Proc macro #[wrappit] to rewrite operators into their wrapping equivalents

1 unstable release

0.1.0 Oct 17, 2019

#8 in #equivalents

Download history 1/week @ 2023-12-04 9/week @ 2023-12-11 6/week @ 2023-12-18 6/week @ 2024-01-08 8/week @ 2024-02-12 18/week @ 2024-02-19 31/week @ 2024-02-26 21/week @ 2024-03-04 23/week @ 2024-03-11 22/week @ 2024-03-18

98 downloads per month
Used in rand_krull

Apache-2.0

7KB
95 lines

This crate provides a proc macro that rewrites arithemtic operators +,-,* into their wrapping equivalents wrapping_add, wrapping_sub, wrapping_mul as well as their assigning versions +=,-=,*=.

The following function for example

#[wrappit]
fn mix(a: u32, b: u32, c: [u32; 8]) -> u32 {
    let mut r = a + b;
    for u in c {
        r *= u;
    }
    r
}

is rewritten to

fn mix(a: u32, b: u32, c: [u32; 8]) -> u32 {
    let mut r = a.wrapping_add(b);
    for u in c {
        r = r.wrapping_mul(u);
    }
    r
}

Dependencies

~1.5MB
~34K SLoC