1
0
mirror of https://github.com/danog/strum.git synced 2024-11-26 12:04:38 +01:00
Go to file
Peter Glotfelty d8278db866
add allows to prevent lint errors (#231)
Co-authored-by: Peter Glotfelty <peter@glotfelty.us>
2022-08-07 16:32:28 -07:00
.devcontainer Made a fix for #80 2020-03-01 23:55:53 +00:00
strum Get ready to publish 0.24.1 2022-06-12 13:33:21 -07:00
strum_macros add allows to prevent lint errors (#231) 2022-08-07 16:32:28 -07:00
strum_nostd_tests Add updates for 0.24 2022-02-21 14:07:48 -08:00
strum_tests Revert "Add TryFrom to FromRepr (#217)" (#228) 2022-06-24 17:47:32 -07:00
.clippy.toml Clippy lints and some minor nitpicks (#212) 2022-02-18 16:04:31 -08:00
.gitignore Implemented initial version of macros and code 2017-02-04 18:52:48 -08:00
.travis.yml Update msrv because of heck. (#150) 2021-02-21 12:54:28 -08:00
appveyor.yml See if this gets the build fixed 2022-04-30 15:26:54 -07:00
Cargo.toml Add tests for nostd environment (#196) 2021-11-20 11:30:11 -08:00
CHANGELOG.md Publishing a new version without #217 to enable phf 2022-06-24 17:53:45 -07:00
LICENSE Macro renames (#46) 2019-03-26 20:44:39 -07:00
README.md Add updates for 0.24 2022-02-21 14:07:48 -08: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 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.

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.24"
strum_macros = "0.24"

# You can also use the "derive" feature, and import the macros directly from "strum"
# strum = { version = "0.24", features = ["derive"] }

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
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.

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.