#data-structures #enums #enum-map #array #no-std

no-std enum-map

A map with C-like enum keys represented internally as an array

78 releases (21 stable)

3.0.0-beta.2 Nov 8, 2023
3.0.0-0.gat.0 Sep 23, 2023
2.7.3 Nov 24, 2023
2.6.0 Jun 30, 2023
0.2.9 Jul 26, 2017

#28 in Rust patterns

Download history 171309/week @ 2024-12-14 65843/week @ 2024-12-21 88428/week @ 2024-12-28 161223/week @ 2025-01-04 178361/week @ 2025-01-11 156742/week @ 2025-01-18 173175/week @ 2025-01-25 198333/week @ 2025-02-01 294218/week @ 2025-02-08 264666/week @ 2025-02-15 325290/week @ 2025-02-22 341464/week @ 2025-03-01 347131/week @ 2025-03-08 328729/week @ 2025-03-15 298484/week @ 2025-03-22 251279/week @ 2025-03-29

1,276,471 downloads per month
Used in 762 crates (117 directly)

MIT/Apache

40KB
740 lines

An enum mapping type.

It is implemented using an array type, so using it is as fast as using Rust arrays.

Examples

use enum_map::{enum_map, Enum, EnumMap};

#[derive(Debug, Enum)]
enum Example {
    A(bool),
    B,
    C,
}

let mut map = enum_map! {
    Example::A(false) => 0,
    Example::A(true) => 1,
    Example::B => 2,
    Example::C => 3,
};
map[Example::C] = 4;

assert_eq!(map[Example::A(true)], 1);

for (key, &value) in &map {
    println!("{:?} has {} as value.", key, value);
}

enum-map

A library providing enum map providing type safe enum array. It is implemented using regular Rust arrays, so using them is as fast as using regular Rust arrays.

This crate follows the "N minus two" MSRV policy. This means that it supports the current Rust release, as well as the two before that.

Examples

#[macro_use]
extern crate enum_map;

use enum_map::EnumMap;

#[derive(Debug, Enum)]
enum Example {
    A,
    B,
    C,
}

fn main() {
    let mut map = enum_map! {
        Example::A => 1,
        Example::B => 2,
        Example::C => 3,
    };
    map[Example::C] = 4;

    assert_eq!(map[Example::A], 1);

    for (key, &value) in &map {
        println!("{:?} has {} as value.", key, value);
    }
}

Dependencies

~185KB