1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
//! Unfortunate implementation detail required to construct `heapless` types in const context

use core::{marker::PhantomData, mem::MaybeUninit};

use crate::spsc::{Atomic, MultiCore};

/// `const-fn` version of [`BinaryHeap`](../binary_heap/struct.BinaryHeap.html)
pub struct BinaryHeap<A, K> {
    pub(crate) _kind: PhantomData<K>,
    pub(crate) data: Vec<A>,
}

/// `const-fn` version of [`LinearMap`](../struct.LinearMap.html)
pub struct LinearMap<A> {
    pub(crate) buffer: Vec<A>,
}

/// `const-fn` version of [`spsc::Queue`](../spsc/struct.Queue.html)
pub struct Queue<A, U = usize, C = MultiCore> {
    // this is from where we dequeue items
    pub(crate) head: Atomic<U, C>,

    // this is where we enqueue new items
    pub(crate) tail: Atomic<U, C>,

    pub(crate) buffer: MaybeUninit<A>,
}

/// `const-fn` version of [`String`](../struct.String.html)
pub struct String<A> {
    pub(crate) vec: Vec<A>,
}

/// `const-fn` version of [`Vec`](../struct.Vec.html)
pub struct Vec<A> {
    pub(crate) buffer: MaybeUninit<A>,
    pub(crate) len: usize,
}