use crate::SingleItemStorage;
#[cfg(feature = "alloc")]
use alloc::{string::String, vec::Vec};
pub trait CapacityUpperBound {
const CAPACITY_UPPER_BOUND: usize;
#[inline]
fn capacity_upper_bound(&self) -> usize {
Self::CAPACITY_UPPER_BOUND
}
}
impl CapacityUpperBound for () {
const CAPACITY_UPPER_BOUND: usize = 0;
}
impl<T> CapacityUpperBound for Option<T> {
const CAPACITY_UPPER_BOUND: usize = 1;
}
impl<T> CapacityUpperBound for SingleItemStorage<T> {
const CAPACITY_UPPER_BOUND: usize = 1;
}
impl<T, const N: usize> CapacityUpperBound for [T; N] {
const CAPACITY_UPPER_BOUND: usize = N;
}
impl<T> CapacityUpperBound for &'_ [T] {
const CAPACITY_UPPER_BOUND: usize = _capacity_upper_bound_of_type::<T>();
}
impl<T> CapacityUpperBound for &'_ mut [T] {
const CAPACITY_UPPER_BOUND: usize = _capacity_upper_bound_of_type::<T>();
}
#[cfg(feature = "alloc")]
impl CapacityUpperBound for String {
const CAPACITY_UPPER_BOUND: usize = _capacity_upper_bound_of_type::<u8>();
}
#[cfg(feature = "alloc")]
impl<T> CapacityUpperBound for Vec<T> {
const CAPACITY_UPPER_BOUND: usize = _capacity_upper_bound_of_type::<T>();
}
#[cfg(feature = "arrayvec")]
impl<const N: usize> CapacityUpperBound for arrayvec::ArrayString<N> {
const CAPACITY_UPPER_BOUND: usize = N;
}
#[cfg(feature = "arrayvec")]
impl<T, const N: usize> CapacityUpperBound for arrayvec::ArrayVec<T, N> {
const CAPACITY_UPPER_BOUND: usize = N;
}
#[cfg(feature = "smallvec")]
impl<A> CapacityUpperBound for smallvec::SmallVec<A>
where
A: smallvec::Array,
{
const CAPACITY_UPPER_BOUND: usize = _capacity_upper_bound_of_type::<A::Item>();
}
#[cfg(feature = "staticvec")]
impl<T, const N: usize> CapacityUpperBound for staticvec::StaticVec<T, N> {
const CAPACITY_UPPER_BOUND: usize = N;
}
#[cfg(feature = "tinyvec")]
impl<A> CapacityUpperBound for tinyvec::ArrayVec<A>
where
A: tinyvec::Array,
A::Item: Default,
{
const CAPACITY_UPPER_BOUND: usize = A::CAPACITY;
}
#[cfg(feature = "tinyvec")]
impl<A> CapacityUpperBound for tinyvec::TinyVec<A>
where
A: tinyvec::Array,
A::Item: Default,
{
const CAPACITY_UPPER_BOUND: usize = _capacity_upper_bound_of_type::<A::Item>();
}
#[inline]
const fn _capacity_upper_bound_of_type<T>() -> usize {
let size_of_t = core::mem::size_of::<T>();
let isize_max_usize = isize::MAX.unsigned_abs();
if let Some(elem) = isize_max_usize.checked_div(size_of_t) {
elem
} else {
0
}
}