Strum is a set of macros and traits for working with enums and strings easier in Rust.
Strum is currently with versions of rustc >= 1.32.0. Pull Requests that improve compatibility with older versions are welcome. The project goal is to support a rust version for at least 2 years after release and even longer is preferred since this project changes slowly.
Import strum and strummacros into your project by adding the following lines to your Cargo.toml. Strummacros contains the macros needed to derive all the traits in Strum.
```toml [dependencies] strum = "0.24" strum_macros = "0.24"
```
Strum has implemented the following macros:
| Macro | Description |
| --- | ----------- |
| [EnumString] | Converts strings to enum variants based on their name. |
| [Display] | Converts enum variants to strings |
| [FromRepr] | Convert from an integer to an enum. |
| [AsRefStr] | Implement AsRef<str>
for MyEnum
|
| [IntoStaticStr] | Implements From<MyEnum> for &'static str
on an enum |
| [EnumVariantNames] | Adds an associated VARIANTS
constant which is an array of discriminant names |
| [EnumIter] | Creates a new type that iterates of the variants of an enum. |
| [EnumProperty] | Add custom properties to enum variants. |
| [EnumMessage] | Add a verbose message to an enum variant. |
| [EnumDiscriminants] | Generate a new type with only the discriminant names. |
| [EnumCount] | Add a constant usize
equal to the number of variants. |
Thanks for your interest in contributing. The project is divided into 3 parts, the traits are in the
/strum
folder. The procedural macros are in the /strum_macros
folder, and the integration tests are
in /strum_tests
. If you are adding additional features to strum
or strum_macros
, you should make sure
to run the tests and add new integration tests to make sure the features work as expected.
To see the generated code, set the STRUM_DEBUG environment variable before compiling your code.
STRUM_DEBUG=1
will dump all of the generated code for every type. STRUM_DEBUG=YourType
will
only dump the code generated on a type named YourType
.
Strum is short for STRing enUM because it's a library for augmenting enums with additional information through strings.
Strumming is also a very whimsical motion, much like writing Rust code.