Struct icu::collator::provider::CollationReorderingV1
source · pub struct CollationReorderingV1<'data> {
pub min_high_no_reorder: u32,
pub reorder_table: ZeroVec<'data, u8>,
pub reorder_ranges: ZeroVec<'data, u32>,
}
Expand description
Script reordering data
Fields§
§min_high_no_reorder: u32
Limit of last reordered range. 0 if no reordering or no split bytes.
Comment from ICU4C’s collationsettings.h
reorder_table: ZeroVec<'data, u8>
256-byte table for reordering permutation of primary lead bytes; NULL if no reordering. A 0 entry at a non-zero index means that the primary lead byte is “split” (there are different offsets for primaries that share that lead byte) and the reordering offset must be determined via the reorderRanges.
Comment from ICU4C’s collationsettings.h
reorder_ranges: ZeroVec<'data, u32>
Primary-weight ranges for script reordering, to be used by reorder(p) for split-reordered primary lead bytes.
Each entry is a (limit, offset) pair. The upper 16 bits of the entry are the upper 16 bits of the exclusive primary limit of a range. Primaries between the previous limit and this one have their lead bytes modified by the signed offset (-0xff..+0xff) stored in the lower 16 bits.
CollationData::makeReorderRanges() writes a full list where the first range (at least for terminators and separators) has a 0 offset. The last range has a non-zero offset. minHighNoReorder is set to the limit of that last range.
In the settings object, the initial ranges before the first split lead byte are omitted for efficiency; they are handled by reorder(p) via the reorderTable. If there are no split-reordered lead bytes, then no ranges are needed.
Comment from ICU4C’s collationsettings.h
; names refer to
ICU4C.
Trait Implementations§
source§impl<'data> Bake for CollationReorderingV1<'data>
impl<'data> Bake for CollationReorderingV1<'data>
source§fn bake(&self, env: &CrateEnv) -> TokenStream
fn bake(&self, env: &CrateEnv) -> TokenStream
source§impl<'data> BakeSize for CollationReorderingV1<'data>
impl<'data> BakeSize for CollationReorderingV1<'data>
source§fn borrows_size(&self) -> usize
fn borrows_size(&self) -> usize
source§impl<'data> Clone for CollationReorderingV1<'data>
impl<'data> Clone for CollationReorderingV1<'data>
source§fn clone(&self) -> CollationReorderingV1<'data>
fn clone(&self) -> CollationReorderingV1<'data>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<'data> Debug for CollationReorderingV1<'data>
impl<'data> Debug for CollationReorderingV1<'data>
source§impl<'de, 'data> Deserialize<'de> for CollationReorderingV1<'data>where
'de: 'data,
impl<'de, 'data> Deserialize<'de> for CollationReorderingV1<'data>where
'de: 'data,
source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<CollationReorderingV1<'data>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<CollationReorderingV1<'data>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
source§impl<'data> PartialEq for CollationReorderingV1<'data>
impl<'data> PartialEq for CollationReorderingV1<'data>
source§fn eq(&self, other: &CollationReorderingV1<'data>) -> bool
fn eq(&self, other: &CollationReorderingV1<'data>) -> bool
self
and other
values to be equal, and is used by ==
.source§impl<'data> Serialize for CollationReorderingV1<'data>
impl<'data> Serialize for CollationReorderingV1<'data>
source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
source§impl<'a> Yokeable<'a> for CollationReorderingV1<'static>
impl<'a> Yokeable<'a> for CollationReorderingV1<'static>
source§type Output = CollationReorderingV1<'a>
type Output = CollationReorderingV1<'a>
Self
with the 'static
replaced with 'a
, i.e. Self<'a>
source§fn transform_owned(
self,
) -> <CollationReorderingV1<'static> as Yokeable<'a>>::Output
fn transform_owned( self, ) -> <CollationReorderingV1<'static> as Yokeable<'a>>::Output
source§unsafe fn make(
this: <CollationReorderingV1<'static> as Yokeable<'a>>::Output,
) -> CollationReorderingV1<'static>
unsafe fn make( this: <CollationReorderingV1<'static> as Yokeable<'a>>::Output, ) -> CollationReorderingV1<'static>
Self<'a>
’s lifetime. Read moresource§fn transform_mut<F>(&'a mut self, f: F)where
F: 'static + for<'b> FnOnce(&'b mut <CollationReorderingV1<'static> as Yokeable<'a>>::Output),
fn transform_mut<F>(&'a mut self, f: F)where
F: 'static + for<'b> FnOnce(&'b mut <CollationReorderingV1<'static> as Yokeable<'a>>::Output),
self
between &'a mut Self<'static>
and &'a mut Self<'a>
,
and pass it to f
. Read moresource§impl<'zf, 'zf_inner> ZeroFrom<'zf, CollationReorderingV1<'zf_inner>> for CollationReorderingV1<'zf>
impl<'zf, 'zf_inner> ZeroFrom<'zf, CollationReorderingV1<'zf_inner>> for CollationReorderingV1<'zf>
source§fn zero_from(
this: &'zf CollationReorderingV1<'zf_inner>,
) -> CollationReorderingV1<'zf>
fn zero_from( this: &'zf CollationReorderingV1<'zf_inner>, ) -> CollationReorderingV1<'zf>
C
into a struct that may retain references into C
.impl<'data> StructuralPartialEq for CollationReorderingV1<'data>
Auto Trait Implementations§
impl<'data> Freeze for CollationReorderingV1<'data>
impl<'data> RefUnwindSafe for CollationReorderingV1<'data>
impl<'data> Send for CollationReorderingV1<'data>
impl<'data> Sync for CollationReorderingV1<'data>
impl<'data> Unpin for CollationReorderingV1<'data>
impl<'data> UnwindSafe for CollationReorderingV1<'data>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more