Crates.io | variant-map |
lib.rs | variant-map |
version | 0.1.1 |
source | src |
created_at | 2023-09-06 16:57:27.293055 |
updated_at | 2023-09-06 17:23:19.264959 |
description | defines maps to store variants of enums |
homepage | |
repository | https://github.com/mxyns/variant-map |
max_upload_size | |
id | 965479 |
size | 30,374 |
Enum variants stored in Maps.
Provides different kinds of map-equivalent types to store enum variants into. As those data structures are maps, they store one value of each variant. All Maps are serde::Serialize-able and serde::Deserialize-able
Those maps can be generated easily using the derive macros from variant_map_derive.
variant_map_derive provides a derive macro for a StructMap
(a struct type with a field per enum variant).
variant_map_derive can be included using the derive
feature of variant_map
This crate also provide simple macros to lighten the syntax with the macros
feature.
use variant_map_derive::VariantStore;
#[derive(VariantStore)]
enum MyEnum {
A,
B(i32),
}
fn main() {
use variant_map::{as_key, as_map};
let mut map = <as_map!(MyEnum)>::default();
let _: &MyEnum = map.get(&<as_key!(MyEnum)>::A).unwrap();
let _: &MyEnum = map.get(&MyEnumKey::A).unwrap();
map[&MyEnumKey::B] = MyEnum::B(69);
}
For more customizability of the [Map][common::MapValue::Map] check out the [variant_map_derive] crate documentation
For more detailed examples check out the example project on this crates' repo