use alloc::alloc::Layout;
use core::convert::TryInto;
use core::fmt;
use core::marker::PhantomData;
pub struct PageHeader<H> {
pub header: H,
pub desc: PageDesc,
}
impl<H> fmt::Debug for PageHeader<H> {
#[inline(always)]
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
write!(fmt, "PageHeader[{}]", self.desc.items)
}
}
#[derive(Clone,Copy)]
pub struct PageDesc {
pub items: u32,
pub data: u32,
}
impl fmt::Debug for PageDesc {
#[inline(always)]
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
write!(fmt, "PageDesc[{}]", self.items)
}
}
impl<H, T> From<PageLayout<H, T>> for PageDesc {
#[inline(always)]
fn from(layout: PageLayout<H, T>) -> Self { layout.desc }
}
pub struct PageLayout<H, T> {
pub(crate) desc: PageDesc,
layout: Layout,
_phantom: PhantomData<(H, T)>,
}
impl<H, T> PageLayout<H, T> {
#[inline(always)]
pub fn with_capacity(items: u32) -> Self {
assert!(items > 0); let header = Layout::new::<PageHeader<H>>();
let array = Layout::array::<T>(items as usize).unwrap();
let (layout, data) = header.extend(array).unwrap();
let layout = layout.pad_to_align();
let desc = PageDesc { items, data: data.try_into().unwrap() };
Self { desc, layout, _phantom: PhantomData }
}
#[inline(always)]
pub fn layout(self) -> Layout { self.layout }
}
impl<H, T> Clone for PageLayout<H, T> {
#[inline(always)]
fn clone(&self) -> Self {
PageLayout { desc: self.desc, layout: self.layout, _phantom: self._phantom }
}
}
impl<H, T> Copy for PageLayout<H, T> {}