#options #collection #items #ordered #zero #enums #ot

zot

Provides Option-like enums for working with ordered collections of zero, one, or two items (Zot), or ordered collections of one or two items (Ot)

1 unstable release

0.1.0 Apr 8, 2021

#1350 in Data structures

Download history 1/week @ 2023-12-11 4/week @ 2023-12-18 11/week @ 2024-02-12 20/week @ 2024-02-19 20/week @ 2024-02-26 25/week @ 2024-03-04 33/week @ 2024-03-11 18/week @ 2024-03-18

97 downloads per month
Used in 2 crates (via triangulate)

MIT/Apache

64KB
927 lines

Zot

Provides Option-like enums for working with ordered collections of zero, one, or two items (Zot), or ordered collections of one or two items (Ot).

let zot = Zot::Two("one", "two");
assert_eq!(zot.last(), Some("two"));
let ot = Ot::One("just one");
assert!(ot.is_one());

Most functionality mimics Option with a few exceptions:

  • Some new functions relating to the relative positions have been added:
    • first gets the singular element from *::One or the first element from *::Two. Zot<T> returns an Option<T>, with Zot::Zero returning None.
    • second gets the second element from *::Two. Both Ot<T> and Zot<T> return an Option<T>.
    • last gets the second element from *::Two or the singular element from *::One. Zot<T> returns an Option<T>, Ot<T> returns a T.
    • *_mut, replace_*, and take_* (Zot only) variations are also included.
  • Some functions which don't have a clear analogue when working with 2 values are not included (e.g. zip).
  • map requires a FnMut parameter instead of FnOnce as the function may need to be called twice.

Dependencies

~180KB