#primitive #enums #derive #tryfrom #custom #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

#365 in Procedural macros

Download history 12109/week @ 2023-12-14 5593/week @ 2023-12-21 6387/week @ 2023-12-28 10101/week @ 2024-01-04 8770/week @ 2024-01-11 8962/week @ 2024-01-18 10029/week @ 2024-01-25 11597/week @ 2024-02-01 13216/week @ 2024-02-08 12687/week @ 2024-02-15 12093/week @ 2024-02-22 12146/week @ 2024-02-29 15615/week @ 2024-03-07 15188/week @ 2024-03-14 16968/week @ 2024-03-21 10797/week @ 2024-03-28

60,978 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
~34K SLoC