#[cfg(feature = "gc")]
mod enabled;
#[cfg(feature = "gc")]
pub use enabled::*;
#[cfg(not(feature = "gc"))]
mod disabled;
#[cfg(not(feature = "gc"))]
pub use disabled::*;
mod noextern;
pub use noextern::NoExtern;
mod none_ref;
pub use none_ref::NoneRef;
use core::fmt;
use core::ops::Deref;
pub trait GcRef: GcRefImpl {}
impl<T> GcRef for T where T: GcRefImpl {}
pub trait RootedGcRef<T>: RootedGcRefImpl<T> + Deref<Target = T>
where
T: GcRef,
{
}
impl<T, U> RootedGcRef<T> for U
where
T: GcRef,
U: RootedGcRefImpl<T> + Deref<Target = T>,
{
}
pub struct GcHeapOutOfMemory<T> {
inner: T,
bytes_needed: u64,
}
impl<T> fmt::Debug for GcHeapOutOfMemory<T> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt::Display::fmt(self, f)
}
}
impl<T> fmt::Display for GcHeapOutOfMemory<T> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(
f,
"GC heap out of memory: no capacity for allocation of {} bytes",
self.bytes_needed
)
}
}
impl<T> core::error::Error for GcHeapOutOfMemory<T> {}
impl<T> GcHeapOutOfMemory<T> {
pub(crate) fn new(inner: T, bytes_needed: u64) -> Self {
Self {
inner,
bytes_needed,
}
}
#[cfg(feature = "gc")]
pub(crate) fn bytes_needed(&self) -> u64 {
self.bytes_needed
}
#[cfg(feature = "gc")]
pub(crate) fn map_inner<U>(self, f: impl FnOnce(T) -> U) -> GcHeapOutOfMemory<U> {
GcHeapOutOfMemory {
inner: f(self.inner),
bytes_needed: self.bytes_needed,
}
}
pub fn into_inner(self) -> T {
self.inner
}
pub fn take_inner(self) -> (T, GcHeapOutOfMemory<()>) {
(self.inner, GcHeapOutOfMemory::new((), self.bytes_needed))
}
}