#count #macro #compile-time #procedural

macro count-macro

A simple Rust macro to perform compile time counting

6 releases

0.2.3 Aug 22, 2024
0.2.2 May 21, 2022
0.2.1 Feb 22, 2022
0.1.1 Jan 9, 2022

#2305 in Procedural macros

Download history 49/week @ 2024-07-26 13/week @ 2024-08-02 25/week @ 2024-08-09 107/week @ 2024-08-16 55/week @ 2024-08-23 12/week @ 2024-08-30 5/week @ 2024-09-06 8/week @ 2024-09-13 32/week @ 2024-09-20 10/week @ 2024-09-27 11/week @ 2024-10-04 58/week @ 2024-10-11 23/week @ 2024-10-18 13/week @ 2024-10-25 51/week @ 2024-11-01 22/week @ 2024-11-08

114 downloads per month
Used in 2 crates (via bool_vec)

MIT license

10KB
107 lines

Count macro

A macro to allow for compile time counting

How to use this

Every instance of _int_ will be replaced with either a literal or an ident.

count_macro::count will panic in debug mode if counter exceeds usize.

If you wish to wrap to 0, please use count_macro::wrapping_count.

Examples

Ident to literal

use count_macro::count;

let a = count!(vec![_int_, _int_, _int_]);
assert_eq!(a, vec![0, 1, 2]);

Ident to ident

use count_macro::count;

count! {
    let a_int_ = "Hello";
    let a_int_ = "World";
}

assert_eq!(a0, "Hello");
assert_eq!(a1, "World");

In macro

use count_macro::count;

macro_rules! my_macro {
    ($($v:expr),*) => {
        count!{
            $(
                let _ = $v; // Ignoring $v

                println!("{}", _int_);
            )*
        }
    };
}

my_macro!('@', '@', '@', '@'); // Will print from 0 to 3

Multiple counters

with _int_countername_ you'll be able to create a new counter called "countername".

This won't be incremented by _int_ or any other counter such as _int_0_ or _int_x_.

use count_macro::count;

// With two different counters
// _int_ does not increment _int_name_
count! {
    let a_int_ = _int_name_;
    let a_int_ = _int_name_;
    let a_int_ = _int_name_;
}

assert_eq!(a0, 0);
assert_eq!(a1, 1);
assert_eq!(a2, 2);

Dependencies

~2.2–3MB
~55K SLoC