#enums #variant #iterator #cardinality #enumerate

enum-iterator

Tools to iterate over all values of a type (e.g. all variants of an enumeration)

24 releases (13 stable)

2.1.0 May 1, 2024
2.0.0 Feb 25, 2024
1.5.0 Jan 15, 2024
1.4.1 May 4, 2023
0.2.0 Jul 2, 2018

#35 in Rust patterns

Download history 149550/week @ 2024-09-21 167109/week @ 2024-09-28 150682/week @ 2024-10-05 174606/week @ 2024-10-12 158806/week @ 2024-10-19 163989/week @ 2024-10-26 154368/week @ 2024-11-02 185978/week @ 2024-11-09 197238/week @ 2024-11-16 122216/week @ 2024-11-23 193341/week @ 2024-11-30 188295/week @ 2024-12-07 169555/week @ 2024-12-14 74669/week @ 2024-12-21 89171/week @ 2024-12-28 148419/week @ 2025-01-04

515,777 downloads per month
Used in 1,429 crates (165 directly)

0BSD license

34KB
628 lines

Overview

Tools to iterate over the values of a type.

Examples

use enum_iterator::{all, cardinality, first, last, next, previous, reverse_all, Sequence};

#[derive(Debug, PartialEq, Sequence)]
enum Day { Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday }

assert_eq!(cardinality::<Day>(), 7);
assert_eq!(all::<Day>().collect::<Vec<_>>(), [
    Day::Monday,
    Day::Tuesday,
    Day::Wednesday,
    Day::Thursday,
    Day::Friday,
    Day::Saturday,
    Day::Sunday,
]);
assert_eq!(first::<Day>(), Some(Day::Monday));
assert_eq!(last::<Day>(), Some(Day::Sunday));
assert_eq!(next(&Day::Tuesday), Some(Day::Wednesday));
assert_eq!(previous(&Day::Wednesday), Some(Day::Tuesday));
assert_eq!(reverse_all::<Day>().collect::<Vec<_>>(), [
    Day::Sunday,
    Day::Saturday,
    Day::Friday,
    Day::Thursday,
    Day::Wednesday,
    Day::Tuesday,
    Day::Monday,
]);
use enum_iterator::{cardinality, first, last, Sequence};

#[derive(Debug, PartialEq, Sequence)]
struct Foo {
    a: bool,
    b: u8,
}

assert_eq!(cardinality::<Foo>(), 512);
assert_eq!(first::<Foo>(), Some(Foo { a: false, b: 0 }));
assert_eq!(last::<Foo>(), Some(Foo { a: true, b: 255 }));

Rust version

This crate tracks stable Rust. Minor releases may require a newer Rust version. Patch releases must not require a newer Rust version.

Contribute

All contributions shall be licensed under the 0BSD license.

Dependencies

~230–670KB
~16K SLoC