1
0
mirror of https://github.com/danog/strum.git synced 2024-11-30 04:28:59 +01:00
Go to file
Michael Kefeder 89b9c14731
Wiki to doc tests (#121)
* example usage as doctests added to the strum_macros crate

* removed links to to wiki example code and documentation of the macros

* added attribute documentation as a module in strum and linked to it
2020-10-06 10:17:06 -07:00
.devcontainer Made a fix for #80 2020-03-01 23:55:53 +00:00
strum Wiki to doc tests (#121) 2020-10-06 10:17:06 -07:00
strum_macros Wiki to doc tests (#121) 2020-10-06 10:17:06 -07:00
strum_tests Re-Enable Travis via travis.com (#112) 2020-09-17 11:21:41 -07:00
strum_tests_rename Update strum to Rust edition 2018 (#110) 2020-09-17 11:21:21 -07:00
.gitignore Implemented initial version of macros and code 2017-02-04 18:52:48 -08:00
.travis.yml Re-Enable Travis via travis.com (#112) 2020-09-17 11:21:41 -07:00
appveyor.yml fix indentation 2020-09-17 05:09:18 +00:00
Cargo.toml Macro renames (#46) 2019-03-26 20:44:39 -07:00
CHANGELOG.md Fixes a panic caused by unwrapping an option (#105) 2020-08-05 21:36:47 -07:00
LICENSE Macro renames (#46) 2019-03-26 20:44:39 -07:00
README.md Re-Enable Travis via travis.com (#112) 2020-09-17 11:21:41 -07:00
travis.sh Re-Enable Travis via travis.com (#112) 2020-09-17 11:21:41 -07:00

Strum

Build Status Build status Latest Version Rust Documentation Crates.io Crates.io

Strum is a set of macros and traits for working with enums and strings easier in Rust.

Compatibility

Strum is compatible with versions of rustc >= 1.31.0. That's the earliest version of stable rust that supports impl trait. Pull Requests that improve compatibility with older versions are welcome, but new feature work will focus on the current version of rust with an effort to avoid breaking compatibility with older versions.

Including Strum in Your Project

Import strum and strum_macros into your project by adding the following lines to your Cargo.toml. Strum_macros contains the macros needed to derive all the traits in Strum.

[dependencies]
strum = "0.19"
strum_macros = "0.19"

Strum Macros

Strum has implemented the following macros:

Macro Description
EnumString Converts strings to enum variants based on their name
Display Converts enum variants to strings
AsRefStr Converts enum variants to &'static str
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.

Contributing

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.

Debugging

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.

Name

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.