use crate::rust_string::RustString; use alloc::string::String; use alloc::vec::Vec; use core::mem::ManuallyDrop; #[repr(C)] pub struct RustVec { pub(crate) repr: Vec, } impl RustVec { pub fn new() -> Self { RustVec { repr: Vec::new() } } pub fn from(v: Vec) -> Self { RustVec { repr: v } } pub fn from_ref(v: &Vec) -> &Self { unsafe { &*(v as *const Vec as *const RustVec) } } pub fn from_mut(v: &mut Vec) -> &mut Self { unsafe { &mut *(v as *mut Vec as *mut RustVec) } } pub fn into_vec(self) -> Vec { self.repr } pub fn as_vec(&self) -> &Vec { &self.repr } pub fn as_mut_vec(&mut self) -> &mut Vec { &mut self.repr } pub fn len(&self) -> usize { self.repr.len() } pub fn capacity(&self) -> usize { self.repr.capacity() } pub fn as_ptr(&self) -> *const T { self.repr.as_ptr() } pub fn reserve_total(&mut self, cap: usize) { let len = self.repr.len(); if cap > len { self.repr.reserve(cap - len); } } pub unsafe fn set_len(&mut self, len: usize) { self.repr.set_len(len); } } impl RustVec { pub fn from_vec_string(v: Vec) -> Self { let mut v = ManuallyDrop::new(v); let ptr = v.as_mut_ptr().cast::(); let len = v.len(); let cap = v.capacity(); Self::from(unsafe { Vec::from_raw_parts(ptr, len, cap) }) } pub fn from_ref_vec_string(v: &Vec) -> &Self { Self::from_ref(unsafe { &*(v as *const Vec as *const Vec) }) } pub fn from_mut_vec_string(v: &mut Vec) -> &mut Self { Self::from_mut(unsafe { &mut *(v as *mut Vec as *mut Vec) }) } pub fn into_vec_string(self) -> Vec { let mut v = ManuallyDrop::new(self.repr); let ptr = v.as_mut_ptr().cast::(); let len = v.len(); let cap = v.capacity(); unsafe { Vec::from_raw_parts(ptr, len, cap) } } pub fn as_vec_string(&self) -> &Vec { unsafe { &*(&self.repr as *const Vec as *const Vec) } } pub fn as_mut_vec_string(&mut self) -> &mut Vec { unsafe { &mut *(&mut self.repr as *mut Vec as *mut Vec) } } }