// This file is part of ICU4X. For terms of use, please see the file // called LICENSE at the top level of the ICU4X source tree // (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ). use crate::vecs::{Index16, Index32}; use crate::{ule::VarULE, VarZeroSlice, VarZeroVec}; use databake::*; impl Bake for VarZeroVec<'_, T, Index16> { fn bake(&self, env: &CrateEnv) -> TokenStream { env.insert("zerovec"); if self.is_empty() { quote! { zerovec::vecs::VarZeroVec16::new() } } else { let bytes = databake::Bake::bake(&self.as_bytes(), env); // Safety: bytes was obtained from a VarZeroVec via as_bytes() above, // and thus is valid for unchecked construction. quote! { unsafe { zerovec::vecs::VarZeroVec16::from_bytes_unchecked(#bytes) } } } } } impl Bake for VarZeroVec<'_, T, Index32> { fn bake(&self, env: &CrateEnv) -> TokenStream { env.insert("zerovec"); if self.is_empty() { quote! { zerovec::vecs::VarZeroVec32::new() } } else { let bytes = databake::Bake::bake(&self.as_bytes(), env); // Safety: bytes was obtained from a VarZeroVec via as_bytes() above, // and thus is valid for unchecked construction. quote! { unsafe { zerovec::vecs::VarZeroVec32::from_bytes_unchecked(#bytes) } } } } } impl BakeSize for VarZeroVec<'_, T, Index16> { fn borrows_size(&self) -> usize { self.as_bytes().len() } } impl BakeSize for VarZeroVec<'_, T, Index32> { fn borrows_size(&self) -> usize { self.as_bytes().len() } } impl Bake for &VarZeroSlice { fn bake(&self, env: &CrateEnv) -> TokenStream { env.insert("zerovec"); if self.is_empty() { quote! { zerovec::vecs::VarZeroSlice16::new_empty() } } else { let bytes = databake::Bake::bake(&self.as_bytes(), env); // Safety: bytes was obtained from a VarZeroSlice via as_bytes() above, // and thus is valid for unchecked construction. quote! { unsafe { zerovec::vecs::VarZeroSlice16::from_bytes_unchecked(#bytes) } } } } } impl Bake for &VarZeroSlice { fn bake(&self, env: &CrateEnv) -> TokenStream { env.insert("zerovec"); if self.is_empty() { quote! { zerovec::vecs::VarZeroSlice32::new_empty() } } else { let bytes = databake::Bake::bake(&self.as_bytes(), env); // Safety: bytes was obtained from a VarZeroSlice via as_bytes() above, // and thus is valid for unchecked construction. quote! { unsafe { zerovec::vecs::VarZeroSlice32::from_bytes_unchecked(#bytes) } } } } } impl BakeSize for &VarZeroSlice { fn borrows_size(&self) -> usize { if self.is_empty() { 0 } else { self.as_bytes().len() } } } impl BakeSize for &VarZeroSlice { fn borrows_size(&self) -> usize { if self.is_empty() { 0 } else { self.as_bytes().len() } } } #[test] fn test_baked_vec() { test_bake!( VarZeroVec, const, crate::vecs::VarZeroVec16::new(), zerovec ); test_bake!( VarZeroVec, const, unsafe { crate::vecs::VarZeroVec16::from_bytes_unchecked(b"\x02\0\0\0\0\0\x05\0helloworld") }, zerovec ); } #[test] fn test_baked_slice() { test_bake!( &VarZeroSlice, const, crate::vecs::VarZeroSlice16::new_empty(), zerovec ); test_bake!( &VarZeroSlice, const, unsafe { crate::vecs::VarZeroSlice16::from_bytes_unchecked(b"\x02\0\0\0\0\0\x05\0helloworld") }, zerovec ); }