#enums #variant #cast #macro-derive #encapsulation

enumcapsulate

Safe casting for newtype enums and their variants

9 releases (5 breaking)

new 0.6.2 Jan 3, 2025
0.6.0 Dec 31, 2024
0.4.0 Nov 18, 2024
0.3.0 May 24, 2024
0.2.0 Mar 21, 2024

#848 in Rust patterns

Download history 3/week @ 2024-09-21 17/week @ 2024-10-05 4/week @ 2024-10-12 2/week @ 2024-10-19 157/week @ 2024-11-16 34/week @ 2024-11-23 165/week @ 2024-11-30 41/week @ 2024-12-07 5/week @ 2024-12-14 1/week @ 2024-12-21 180/week @ 2024-12-28

238 downloads per month

MPL-2.0 license

30KB
75 lines

enumcapsulate

Crates.io Crates.io Crates.io docs.rs

Safe casting for newtype enums and their variants.


Traits

The enumcapsulate crate exports the following traits:

Traits Functionality
Encapsulate Umbrella derive macro for AsVariant, AsVariantMut, AsVariantRef, From, FromVariant, IntoVariant, TryInto, and VariantDowncast.
FromVariant Creates an instance of Self from the unambiguous field type of one of its variants.
IntoVariant Returns the current variant's field, consuming self.
AsVariant Provides owned access to the current variant's field.
AsVariantMut Provides mutable borrowed access to the current variant's field.
AsVariantRef Provides borrowed access to the current variant's field.
VariantDowncast Convenience umbrella trait utilizing AsVariant, AsVariantRef, AsVariantMut, and IntoVariant.
VariantDiscriminant Used to obtain an enum variant's discriminant.

Derive macros

The enumcapsulate crate exports the following corresponding derive macros, if the "derive" feature is enabled (which is the default):

  • Encapsulate
  • From
  • TryInto
  • FromVariant
  • IntoVariant
  • AsVariant
  • AsVariantMut
  • AsVariantRef
  • VariantDowncast
  • VariantDiscriminant

Find more information on above derive macros in enumcapsulate-macros's own README file.

Documentation

Please refer to the documentation on docs.rs.

Contributing

Please read CONTRIBUTING.md for details on our code of conduct,
and the process for submitting pull requests to us.

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

License

This project is licensed under the MPL-2.0 – see the LICENSE.md file for details.

Dependencies

~105KB