enum-methods

Build Status crates.io

Enum getter/is_* method generation.

Please note that this crate is unstable and is subject to change frequently.

I will attempt to prevent seriously breaking changes after we hit 0.1.0.

Links

Usage

In your Cargo.toml, add this line under your [dependencies] section:

toml,no_run enum-methods = "0.0.8"

To use, simply derive and call methods (see the example below).

Why?

Usually when you write an enum with one or zero values, you might want to add a set of getters for them. As such:

```rust

[derive(Debug)]

enum MyEnum { FooBarBaz(i64), BazBarFoo(String), // ... and others }

impl MyEnum { pub fn foobarbaz(&self) -> i64 { if let &MyEnum::FooBarBaz(i) = self { i } else { panic!("called MyEnum::FooBarBaz() on {:?}", self) } } // et cetera }

```

But this gets tedious, and adds a lot code for this simple functionality. Enter enum-methods.

Instead of doing the above with the if let ... else { panic!(...) }, you simply derive from the EnumIntoGetters

```rust

[macro_use]

extern crate enum_methods;

[derive(EnumIntoGetters, EnumAsGetters, EnumIsA, Debug)]

enum MyEnum { FooBarBaz(i64), BazBarFoo(String), // ... and others }

fn main() { let myfoo = MyEnum::FooBarBaz(42); // EnumIsA - creates is* methods for every member if myfoo.isfoobarbaz() { // EnumAsGetters - gets a reference to the enum, panicking if it is // not the specified variant asserteq!(*myfoo.asfoobarbaz(), 42); // EnumIntoGetters - consumes the enum, yielding its owned value, // and panicking if it is not the specified variant asserteq!(myfoo.intofoobarbaz(), 42); } } ```

Requirements and gotchas

Right now, enum-methods has four derivable options:

EnumAsGetters, EnumIntoGetters, and EnumToGetters have some limitations.

Furthermore, EnumToGetters is only for enums whose variants implement Clone. There is not yet support for th

EnumIsA is much simpler than the previous; it simply adds is_* methods returning a boolean for whether the variant matches or not.

For all generated methods, all names are automatically converted to snake_case.

License

This software is released under the Apache license 2.0. See the LICENSE file for more details.