orn

Crates.ioorn
lib.rsorn
version0.6.1
sourcesrc
created_at2023-10-08 04:28:14.865025
updated_at2024-10-30 04:14:29.615595
descriptionA general implementation of the sum type. Meant to be a generic counterpart to tuples.
homepage
repositoryhttps://github.com/Magicolo/orn
max_upload_size
id996904
size22,044
Magicolo (Magicolo)

documentation

https://docs.rs/orn/latest/orn/

README

orn 0.6.1

A general implementation of the sum type. Meant to be a generic counterpart to tuples.


Cheat Sheet

use orn::*;

/// Often, the type of iterator is conditional to some input value. Typically,
/// to unify the return type, one would need to implement a custom iterator, but
/// here `orn` types are used instead.
pub fn unify_divergent(array_or_range: bool) -> impl Iterator<Item = u8> {
    if array_or_range {
        Or2::T0([1u8, 2u8])
    } else {
        Or2::T1(0u8..10u8)
    }
    .into_iter()
    // The item of the `Or` iterator is `Or<u8, u8>`. `Or::into` collapses an `Or` value into a
    // specified type.
    .map(Or2::into)
}

/// Using the `tn` methods, items of an `Or` value can be retrieved.
pub fn retrieve_dynamically(input: Or3<u8, usize, [char; 1]>) {
    let _a: Option<u8> = input.t0();
    let _b: Option<usize> = input.t1();
    let _c: Option<[char; 1]> = input.t2();
}

/// Using the `At<I>` trait, items of an `Or` value can be retrieved
/// generically.
pub fn retrieve_statically(input: Or4<char, bool, isize, u32>) {
    let _a: Option<char> = At::<0>::at(input);
    let _b: Option<bool> = At::<1>::at(input);
    let _c: Option<isize> = At::<2>::at(input);
    let _d: Option<u32> = At::<3>::at(input);
}

fn main() {}
Commit count: 41

cargo fmt