ArrayMap

Struct ArrayMap 

Source
pub struct ArrayMap<K: ArrayFinite<V>, V>(/* private fields */);
Expand description

A complete mapping from keys of type K to values of type V, implemented using an array indexed by Finite::index_of of the key.

§Example

use cantor::{Finite, ArrayMap};

// Define key type
#[derive(Finite, PartialEq, Eq, PartialOrd, Ord, Clone, Copy, Debug)]
enum MyType {
    A,
    B(bool),
    C(bool, bool)
};

// Initialize map
let mut map = ArrayMap::new(|x: MyType| match x {
    MyType::A => false,
    MyType::B(a) => a,
    MyType::C(a, _) => a,
});

// Use map
map[MyType::C(true, true)] = false;
assert_eq!(map[MyType::A], false);
assert_eq!(map[MyType::B(true)], true);
assert_eq!(map[MyType::C(true, true)], false);

Implementations§

Source§

impl<K: ArrayFinite<V>, V> ArrayMap<K, V>

Source

pub fn new(f: impl FnMut(K) -> V) -> Self

Constructs a new ArrayMap with initial values populated using the given function.

Source

pub fn from(array: K::Array) -> Self

Constructs a new ArrayMap from an array of values, each corresponding to the key determined by Finite::nth.

§Example
use cantor::*;
let map = ArrayMap::from([1, 3]);
assert_eq!(map[false], 1);
assert_eq!(map[true], 3);
Source

pub fn map_with_key<N>(&self, f: impl FnMut(K, &V) -> N) -> ArrayMap<K, N>
where K: ArrayFinite<N>,

Applies a mapping function the values of this map.

Source

pub fn map<N>(&self, f: impl FnMut(&V) -> N) -> ArrayMap<K, N>
where K: ArrayFinite<N>,

Applies a mapping function the values of this map.

Trait Implementations§

Source§

impl<K: ArrayFinite<V>, V> Clone for ArrayMap<K, V>
where K::Array: Clone,

Source§

fn clone(&self) -> Self

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<K: ArrayFinite<V>, V: Default> Default for ArrayMap<K, V>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<K: CompressFinite + ArrayFinite<V>, V> Index<Compress<K>> for ArrayMap<K, V>

Source§

type Output = V

The returned type after indexing.
Source§

fn index(&self, index: Compress<K>) -> &Self::Output

Performs the indexing (container[index]) operation. Read more
Source§

impl<K: ArrayFinite<V>, V> Index<K> for ArrayMap<K, V>

Source§

type Output = V

The returned type after indexing.
Source§

fn index(&self, index: K) -> &Self::Output

Performs the indexing (container[index]) operation. Read more
Source§

impl<K: CompressFinite + ArrayFinite<V>, V> IndexMut<Compress<K>> for ArrayMap<K, V>

Source§

fn index_mut(&mut self, index: Compress<K>) -> &mut Self::Output

Performs the mutable indexing (container[index]) operation. Read more
Source§

impl<K: ArrayFinite<V>, V> IndexMut<K> for ArrayMap<K, V>

Source§

fn index_mut(&mut self, index: K) -> &mut Self::Output

Performs the mutable indexing (container[index]) operation. Read more
Source§

impl<K: ArrayFinite<V>, V> Ord for ArrayMap<K, V>
where K::Array: Ord,

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<K: ArrayFinite<V>, V> PartialEq for ArrayMap<K, V>
where K::Array: PartialEq,

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<K: ArrayFinite<V>, V> PartialOrd for ArrayMap<K, V>
where K::Array: PartialOrd,

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<K: ArrayFinite<V>, V> Copy for ArrayMap<K, V>
where K::Array: Copy,

Source§

impl<K: ArrayFinite<V>, V> Eq for ArrayMap<K, V>
where K::Array: Eq,

Auto Trait Implementations§

§

impl<K, V> Freeze for ArrayMap<K, V>
where <K as ArrayFinite<V>>::Array: Freeze,

§

impl<K, V> RefUnwindSafe for ArrayMap<K, V>
where <K as ArrayFinite<V>>::Array: RefUnwindSafe,

§

impl<K, V> Send for ArrayMap<K, V>
where <K as ArrayFinite<V>>::Array: Send,

§

impl<K, V> Sync for ArrayMap<K, V>
where <K as ArrayFinite<V>>::Array: Sync,

§

impl<K, V> Unpin for ArrayMap<K, V>
where <K as ArrayFinite<V>>::Array: Unpin,

§

impl<K, V> UnwindSafe for ArrayMap<K, V>
where <K as ArrayFinite<V>>::Array: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.