#![cfg(feature = "alloc")]
#![allow(missing_docs)]
use alloc::vec::Vec;
use core::ffi::c_void;
use core::marker::PhantomData;
use core::mem::{self, MaybeUninit};
use core::ptr;
#[repr(C)]
pub struct RustVec<T> {
repr: [MaybeUninit<usize>; mem::size_of::<Vec<c_void>>() / mem::size_of::<usize>()],
marker: PhantomData<Vec<T>>,
}
impl<T> RustVec<T> {
pub fn new() -> Self {
Self::from(Vec::new())
}
pub fn from(v: Vec<T>) -> Self {
unsafe { mem::transmute::<Vec<T>, RustVec<T>>(v) }
}
pub fn from_ref(v: &Vec<T>) -> &Self {
unsafe { &*(ptr::from_ref::<Vec<T>>(v).cast::<RustVec<T>>()) }
}
pub fn from_mut(v: &mut Vec<T>) -> &mut Self {
unsafe { &mut *(ptr::from_mut::<Vec<T>>(v).cast::<RustVec<T>>()) }
}
pub fn into_vec(self) -> Vec<T> {
unsafe { mem::transmute::<RustVec<T>, Vec<T>>(self) }
}
pub fn as_vec(&self) -> &Vec<T> {
unsafe { &*(ptr::from_ref::<RustVec<T>>(self).cast::<Vec<T>>()) }
}
pub fn as_mut_vec(&mut self) -> &mut Vec<T> {
unsafe { &mut *(ptr::from_mut::<RustVec<T>>(self).cast::<Vec<T>>()) }
}
pub fn len(&self) -> usize {
self.as_vec().len()
}
pub fn capacity(&self) -> usize {
self.as_vec().capacity()
}
pub fn as_ptr(&self) -> *const T {
self.as_vec().as_ptr()
}
pub fn reserve_total(&mut self, new_cap: usize) {
let vec = self.as_mut_vec();
if new_cap > vec.capacity() {
let additional = new_cap - vec.len();
vec.reserve(additional);
}
}
pub unsafe fn set_len(&mut self, len: usize) {
unsafe { self.as_mut_vec().set_len(len) }
}
pub fn truncate(&mut self, len: usize) {
self.as_mut_vec().truncate(len);
}
}
impl<T> Drop for RustVec<T> {
fn drop(&mut self) {
unsafe { ptr::drop_in_place(self.as_mut_vec()) }
}
}