#primitive #enums #derive #conversion #tryfrom #try-from

macro derive-try-from-primitive

Custom derive a try_from method for primitive to enum conversions

2 releases (1 stable)

1.0.0 Mar 30, 2020
0.1.0 Jul 12, 2017

#320 in Procedural macros

Download history 8668/week @ 2024-01-14 9394/week @ 2024-01-21 10478/week @ 2024-01-28 12037/week @ 2024-02-04 13729/week @ 2024-02-11 11477/week @ 2024-02-18 12386/week @ 2024-02-25 13382/week @ 2024-03-03 15939/week @ 2024-03-10 16076/week @ 2024-03-17 15708/week @ 2024-03-24 14549/week @ 2024-03-31 15456/week @ 2024-04-07 15540/week @ 2024-04-14 15180/week @ 2024-04-21 16238/week @ 2024-04-28

62,754 downloads per month
Used in 11 crates (8 directly)

MIT/Apache

10KB
191 lines

Example

use core::convert::TryFrom;
use derive_try_from_primitive::TryFromPrimitive;


#[derive(TryFromPrimitive)]
#[repr(u16)]
enum Foo {
    Bar,
    Baz = 100,
    Quix = 200,
}

// Generated Code:
impl core::convert::TryFrom<u16> for Foo {
    type Error = u16;

    fn try_from(n: 16) -> Result<Self, Self::Error> {
        match n {
            0 => Ok(Foo::Bar),
            100 => Ok(Foo::Baz),
            200 => Ok(Foo::Quix),
            _ => Err(n),
        }
    }
}

fn main() {
    let bar = Foo::try_from(0);
    let baz = Foo::try_from(100);
    let quix = Foo::try_from(200);
    let bad = Foo::try_from(300);
    assert_eq!(bar.unwrap() as u16, 0);
    assert_eq!(baz.unwrap() as u16, 100);
    assert_eq!(quix.unwrap() as u16, 200);
    if let Err(value) = bad {
        assert_eq!(value, 300, "Input is returned for convenience");
    }
}

Dependencies

~1.5MB
~33K SLoC