2 releases
0.1.1 | Dec 30, 2023 |
---|---|
0.1.0 | Dec 28, 2023 |
#2676 in Rust patterns
101 downloads per month
Used in 2 crates
7KB
enum-extract
A deriving proc-macro that generates functions to the inner members of the enum.
This is a heavily modified fork of enum-as-inner. Some of the key differences are listed below:
as_[variant]
,into_[variant]
andas_[variant]_mut
methods return a Result that can contain a concrete error typeEnumExtractError
.- The error is returned when the actual variant does not match the expected variant, and it contains both the name of the expected variant and the name of the actual variant for troubleshooting purposes.
- The error also implements Display with a message of
expected {expected}, got {actual}
, so that you have a place to start troubleshooting rather than callingunwrap
on anOption
, or repeatedly writing better error messages by hand.
- Added
extract_as_[variant]
,extract_into_[variant]
andextract_as_[variant]_mut
methods, which panic if the actual variant does not match the expected variant.- These are very useful in tests where panicking is acceptable,
especially when combined with the better error messages supported by the
EnumExtractError
struct.
- These are very useful in tests where panicking is acceptable,
especially when combined with the better error messages supported by the
Crates
This project consists of two crates that should be used together. They are separate because crates the export procedural macros can only export procedural macros. They should be treated as a single project, and will therefore be versioned in lock-step.
enum-extract-macro
Provides the EnumExtract
derive macro that can be used on enums to get as_[variant]
functions for each variant,
along with other useful functions.
See the documentation for examples and more details.
enum-extract-error
Provides the EnumExtractError
used as a return value for the as_[variant]
functions.
See the documentation for examples and more details.
Dependencies
~220–670KB
~16K SLoC