#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

#5 in #equivalents

Download history 16/week @ 2024-04-29 13/week @ 2024-05-06 20/week @ 2024-05-13 15/week @ 2024-05-20 23/week @ 2024-05-27 17/week @ 2024-06-03 8/week @ 2024-06-10 14/week @ 2024-06-17 21/week @ 2024-06-24 16/week @ 2024-07-15 23/week @ 2024-07-22 16/week @ 2024-07-29 9/week @ 2024-08-05 19/week @ 2024-08-12

68 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
~36K SLoC