#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

#1676 in Data structures

Download history 33/week @ 2024-07-22 33/week @ 2024-07-29 26/week @ 2024-08-05 34/week @ 2024-08-12 16/week @ 2024-08-19 35/week @ 2024-08-26 28/week @ 2024-09-02 28/week @ 2024-09-09 26/week @ 2024-09-16 61/week @ 2024-09-23 29/week @ 2024-09-30 23/week @ 2024-10-14 18/week @ 2024-10-21 20/week @ 2024-10-28 36/week @ 2024-11-04

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

~165KB