#enums #extracting #discriminant #traits #minimalist #zero #compatible

macro no-std safe-discriminant-derive

A minimalistic, no_std compatible trait and procedural macro for extracting discriminants from enums at zero cost

2 unstable releases

0.2.0 Aug 19, 2024
0.1.0 Aug 16, 2024

#19 in #discriminant

Download history 93/week @ 2024-08-10 196/week @ 2024-08-17 31/week @ 2024-08-24 7/week @ 2024-08-31 123/week @ 2024-09-14 42/week @ 2024-09-21 63/week @ 2024-09-28 39/week @ 2024-10-05 107/week @ 2024-10-12 195/week @ 2024-10-19 173/week @ 2024-10-26 20/week @ 2024-11-02

496 downloads per month
Used in safe-discriminant

BSD-3-Clause

9KB
128 lines

safe-discriminant

safe-discriminant provides a minimalistic, no_std compatible trait and procedural macro for extracting discriminants from enums at zero cost. It automatically generates unsafe { ... } blocks, ensuring semantic safety so you don’t have to worry about it.

Installation

This crate is available on crates.io and can be easily included in your project by:

  • Adding the following line to your Cargo.toml:
    [dependencies]
    safe-discriminant = "0.2.0"
    
  • Or runing this command in your cargo project:
    $ cargo add safe-discriminant
    

Usage

use safe_discriminant::Discriminant;

#[derive(Discriminant)]
#[repr(i64)]
pub enum Foo<T> {
    A = 1,
    B(T) = -1,
    C { fst: T, snd: T } = -2,
}

fn main() {
    let a: Foo<u8> = Foo::A;
    let b = Foo::B(5);
    let c = Foo::C { fst: 2, snd: 3 };
    assert_eq!(a.discriminant(), 1);
    assert_eq!(b.discriminant(), -1);
    assert_eq!(c.discriminant(), -2);
}

Similar Projects

  • strum provides a collection of macros designed to simplify working with enums. Among these macros is EnumDiscriminants, which extracts the name of each variant from the enum and organizes them into a separate enum.

Dependencies

~240–690KB
~16K SLoC