use crate::SingleItemStorage;
#[cfg(feature = "alloc")]
use alloc::{string::String, vec::Vec};
pub trait CapacityUpperBound {
fn capacity_upper_bound(&self) -> usize;
}
impl<T> CapacityUpperBound for Option<T> {
#[inline]
fn capacity_upper_bound(&self) -> usize {
1
}
}
impl<T> CapacityUpperBound for SingleItemStorage<T> {
#[inline]
fn capacity_upper_bound(&self) -> usize {
1
}
}
impl<T, const N: usize> CapacityUpperBound for [T; N] {
#[inline]
fn capacity_upper_bound(&self) -> usize {
N
}
}
impl<T> CapacityUpperBound for &'_ [T] {
#[inline]
fn capacity_upper_bound(&self) -> usize {
self.len()
}
}
impl<T> CapacityUpperBound for &'_ mut [T] {
#[inline]
fn capacity_upper_bound(&self) -> usize {
self.len()
}
}
#[cfg(feature = "alloc")]
impl CapacityUpperBound for String {
#[inline]
fn capacity_upper_bound(&self) -> usize {
_capacity_upper_bound_for_heap::<u8>()
}
}
#[cfg(feature = "alloc")]
impl<T> CapacityUpperBound for Vec<T> {
#[inline]
fn capacity_upper_bound(&self) -> usize {
_capacity_upper_bound_for_heap::<T>()
}
}
#[cfg(feature = "arrayvec")]
impl<const N: usize> CapacityUpperBound for arrayvec::ArrayString<N> {
#[inline]
fn capacity_upper_bound(&self) -> usize {
N
}
}
#[cfg(feature = "arrayvec")]
impl<T, const N: usize> CapacityUpperBound for arrayvec::ArrayVec<T, N> {
#[inline]
fn capacity_upper_bound(&self) -> usize {
N
}
}
#[cfg(feature = "smallvec")]
impl<A> CapacityUpperBound for smallvec::SmallVec<A>
where
A: smallvec::Array,
{
#[inline]
fn capacity_upper_bound(&self) -> usize {
_capacity_upper_bound_for_heap::<A::Item>()
}
}
#[cfg(feature = "staticvec")]
impl<T, const N: usize> CapacityUpperBound for staticvec::StaticVec<T, N> {
#[inline]
fn capacity_upper_bound(&self) -> usize {
N
}
}
#[cfg(feature = "tinyvec")]
impl<A> CapacityUpperBound for tinyvec::ArrayVec<A>
where
A: tinyvec::Array,
A::Item: Default,
{
#[inline]
fn capacity_upper_bound(&self) -> usize {
A::CAPACITY
}
}
#[cfg(feature = "tinyvec")]
impl<A> CapacityUpperBound for tinyvec::TinyVec<A>
where
A: tinyvec::Array,
A::Item: Default,
{
#[inline]
fn capacity_upper_bound(&self) -> usize {
_capacity_upper_bound_for_heap::<A::Item>()
}
}
#[allow(
// `E0080` does not allow `T`s larger than `isize::MAX`
clippy::unwrap_used,
)]
#[inline]
fn _capacity_upper_bound_for_heap<T>() -> usize {
let size_of_t = core::mem::size_of::<T>();
let isize_max_usize = isize::MAX.unsigned_abs();
isize_max_usize.checked_div(size_of_t).unwrap()
}