2 releases
0.1.1 | Jan 30, 2019 |
---|---|
0.1.0 | Jan 30, 2019 |
#9 in #variations
25 downloads per month
Used in 2 crates
(via dasn1-notation)
10KB
143 lines
Variation
A procedural macro to generate enum to variant conversion methods.
Methods generated
is_*
methods
An is_variant
method is generated for each for variant in an enum.
use variation::Variation;
#[derive(Variation)]
enum Type {
Unit,
Integer(i32),
}
fn main() {
let return_type = Type::Unit;
assert!(return_type.is_unit());
assert!(!return_type.is_integer());
}
as_*
& as_*_mut
methods
Variants that have one or more inner types have as
and as_mut
allowing you
to get a immutable or mutable reference to the inner types. Variants with a
single inner type will return &{mut} T
. Variants that have more than one inner
type will return a tuple with a reference to each type.
use variation::Variation;
#[derive(Variation)]
enum Type {
Unit,
Integer(i32),
Real(i32, u32),
}
fn main() {
let mut return_type = Type::Integer(5);
let real_value = Type::Real(3, 14);
assert_eq!(Some(&mut 5), return_type.as_integer_mut());
assert_eq!(Some((&3, &14)), real_value.as_real());
assert_eq!(None, real_value.as_integer());
}
into_*
methods
Variants that have one or more inner types have an into
method, allowing you
to attempt to convert a enum into its inner values. This method will panic when
called on a variant that does not match the method.
use variation::Variation;
#[derive(Variation)]
enum Type {
Unit,
Integer(i32),
Real(i32, u32),
}
fn main() {
let mut return_type = Type::Integer(5);
let real_value = Type::Real(3, 14);
let unit = Type::Unit;
assert_eq!(5, return_type.into_integer());
assert_eq!((3, 14), real_value.into_real());
// Panics
unit.into_integer();
}
Dependencies
~2.5MB
~53K SLoC