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

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

#546 in Procedural macros

Download history 24125/week @ 2024-11-17 28010/week @ 2024-11-24 30373/week @ 2024-12-01 34433/week @ 2024-12-08 34261/week @ 2024-12-15 7707/week @ 2024-12-22 11856/week @ 2024-12-29 29138/week @ 2025-01-05 32177/week @ 2025-01-12 29787/week @ 2025-01-19 31057/week @ 2025-01-26 29477/week @ 2025-02-02 28931/week @ 2025-02-09 27157/week @ 2025-02-16 30036/week @ 2025-02-23 28948/week @ 2025-03-02

115,759 downloads per month
Used in 13 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
~39K SLoC